117 lines
3.6 KiB
Java
117 lines
3.6 KiB
Java
/* ====================================================================
|
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
contributor license agreements. See the NOTICE file distributed with
|
|
this work for additional information regarding copyright ownership.
|
|
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
(the "License"); you may not use this file except in compliance with
|
|
the License. You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
==================================================================== */
|
|
|
|
package org.apache.poi.hssf.record;
|
|
|
|
import org.apache.poi.hssf.record.common.FtrHeader;
|
|
import org.apache.poi.util.LittleEndianOutput;
|
|
|
|
/**
|
|
* Title: FeatHdr (Feature Header) Record
|
|
* <P>
|
|
* This record specifies common information for Shared Features, and
|
|
* specifies the beginning of a collection of records to define them.
|
|
* The collection of data (Globals Substream ABNF, macro sheet substream
|
|
* ABNF or worksheet substream ABNF) specifies Shared Feature data.
|
|
*/
|
|
public final class FeatHdrRecord extends StandardRecord implements Cloneable {
|
|
/**
|
|
* Specifies the enhanced protection type. Used to protect a
|
|
* shared workbook by restricting access to some areas of it
|
|
*/
|
|
public static final int SHAREDFEATURES_ISFPROTECTION = 0x02;
|
|
/**
|
|
* Specifies that formula errors should be ignored
|
|
*/
|
|
public static final int SHAREDFEATURES_ISFFEC2 = 0x03;
|
|
/**
|
|
* Specifies the smart tag type. Recognises certain
|
|
* types of entries (proper names, dates/times etc) and
|
|
* flags them for action
|
|
*/
|
|
public static final int SHAREDFEATURES_ISFFACTOID = 0x04;
|
|
/**
|
|
* Specifies the shared list type. Used for a table
|
|
* within a sheet
|
|
*/
|
|
public static final int SHAREDFEATURES_ISFLIST = 0x05;
|
|
|
|
|
|
public final static short sid = 0x0867;
|
|
|
|
private FtrHeader futureHeader;
|
|
private int isf_sharedFeatureType; // See SHAREDFEATURES_
|
|
private byte reserved; // Should always be one
|
|
/**
|
|
* 0x00000000 = rgbHdrData not present
|
|
* 0xffffffff = rgbHdrData present
|
|
*/
|
|
private long cbHdrData;
|
|
/** We need a BOFRecord to make sense of this... */
|
|
private byte[] rgbHdrData;
|
|
|
|
public FeatHdrRecord() {
|
|
futureHeader = new FtrHeader();
|
|
futureHeader.setRecordType(sid);
|
|
}
|
|
|
|
public short getSid() {
|
|
return sid;
|
|
}
|
|
|
|
public FeatHdrRecord(RecordInputStream in) {
|
|
futureHeader = new FtrHeader(in);
|
|
|
|
isf_sharedFeatureType = in.readShort();
|
|
reserved = in.readByte();
|
|
cbHdrData = in.readInt();
|
|
// Don't process this just yet, need the BOFRecord
|
|
rgbHdrData = in.readRemainder();
|
|
}
|
|
|
|
public String toString() {
|
|
StringBuffer buffer = new StringBuffer();
|
|
buffer.append("[FEATURE HEADER]\n");
|
|
|
|
// TODO ...
|
|
|
|
buffer.append("[/FEATURE HEADER]\n");
|
|
return buffer.toString();
|
|
}
|
|
|
|
public void serialize(LittleEndianOutput out) {
|
|
futureHeader.serialize(out);
|
|
|
|
out.writeShort(isf_sharedFeatureType);
|
|
out.writeByte(reserved);
|
|
out.writeInt((int)cbHdrData);
|
|
out.write(rgbHdrData);
|
|
}
|
|
|
|
protected int getDataSize() {
|
|
return 12 + 2+1+4+rgbHdrData.length;
|
|
}
|
|
|
|
@Override
|
|
public FeatHdrRecord clone() {
|
|
//HACK: do a "cheat" clone, see Record.java for more information
|
|
return (FeatHdrRecord)cloneViaReserialise();
|
|
}
|
|
|
|
|
|
}
|