/* ====================================================================
|
Copyright 2002-2004 Apache Software Foundation
|
|
Licensed 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.
|
==================================================================== */
|
|
|
namespace HH.WMS.Utils.NPOI.HSSF.UserModel
|
{
|
using System;
|
using System.IO;
|
using System.Collections;
|
|
using HH.WMS.Utils.NPOI.HSSF.Record;
|
using HH.WMS.Utils.NPOI.Util;
|
using HH.WMS.Utils.NPOI.HSSF.Model;
|
using HH.WMS.Utils.NPOI.POIFS.FileSystem;
|
|
|
/**
|
* Represents binary object (i.e. OLE) data stored in the file. Eg. A GIF, JPEG etc...
|
*
|
* @author Daniel Noll
|
*/
|
public class HSSFObjectData
|
{
|
/**
|
* Underlying object record ultimately containing a reference to the object.
|
*/
|
private ObjRecord record;
|
|
/**
|
* Reference to the filesystem root, required for retrieving the object data.
|
*/
|
private DirectoryEntry _root;
|
|
/**
|
* Constructs object data by wrapping a lower level object record.
|
*
|
* @param record the low-level object record.
|
* @param poifs the filesystem, required for retrieving the object data.
|
*/
|
public HSSFObjectData(ObjRecord record, DirectoryEntry root)
|
{
|
this.record = record;
|
_root = root;
|
}
|
|
/**
|
* Returns the OLE2 Class Name of the object
|
*/
|
public String OLE2ClassName
|
{
|
get
|
{
|
return FindObjectRecord().OLEClassName;
|
}
|
}
|
|
/**
|
* Gets the object data. Only call for ones that have
|
* data though. See {@link #hasDirectoryEntry()}
|
*
|
* @return the object data as an OLE2 directory.
|
* @ if there was an error Reading the data.
|
*/
|
public DirectoryEntry GetDirectory()
|
{
|
EmbeddedObjectRefSubRecord subRecord = FindObjectRecord();
|
|
int? streamId = ((EmbeddedObjectRefSubRecord)subRecord).StreamId;
|
String streamName = "MBD" + HexDump.ToHex((int)streamId);
|
|
Entry entry = _root.GetEntry(streamName);
|
if (entry is DirectoryEntry)
|
{
|
return (DirectoryEntry)entry;
|
}
|
else
|
{
|
throw new IOException("Stream " + streamName + " was not an OLE2 directory");
|
}
|
}
|
|
/**
|
* Returns the data portion, for an ObjectData
|
* that doesn't have an associated POIFS Directory
|
* Entry
|
*/
|
public byte[] GetObjectData()
|
{
|
return FindObjectRecord().ObjectData;
|
}
|
|
/**
|
* Does this ObjectData have an associated POIFS
|
* Directory Entry?
|
* (Not all do, those that don't have a data portion)
|
*/
|
public bool HasDirectoryEntry()
|
{
|
EmbeddedObjectRefSubRecord subRecord = FindObjectRecord();
|
|
// 'stream id' field tells you
|
int? streamId = subRecord.StreamId;
|
return streamId != null && streamId != 0;
|
}
|
|
/**
|
* Finds the EmbeddedObjectRefSubRecord, or throws an
|
* Exception if there wasn't one
|
*/
|
public EmbeddedObjectRefSubRecord FindObjectRecord()
|
{
|
IEnumerator subRecordIter = record.SubRecords.GetEnumerator();
|
|
while (subRecordIter.MoveNext())
|
{
|
Object subRecord = subRecordIter.Current;
|
if (subRecord is EmbeddedObjectRefSubRecord)
|
{
|
return (EmbeddedObjectRefSubRecord)subRecord;
|
}
|
}
|
|
throw new InvalidOperationException("Object data does not contain a reference to an embedded object OLE2 directory");
|
}
|
}
|
}
|