aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Ahlborn <jtahlborn@yahoo.com>2013-09-17 02:22:06 +0000
committerJames Ahlborn <jtahlborn@yahoo.com>2013-09-17 02:22:06 +0000
commit8b8fca0fce8aed540eccf979955493aa52db3664 (patch)
tree5355a21d3764f63b7d3a39086a2668517a113bb5
parent4b0ba583ec02c00362ccc50f01ba59abf56f31a6 (diff)
downloadjackcess-8b8fca0fce8aed540eccf979955493aa52db3664.tar.gz
jackcess-8b8fca0fce8aed540eccf979955493aa52db3664.zip
add some ole javadocs
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@804 f203690c-595d-4dc9-a70b-905162fa7fd2
-rw-r--r--src/main/java/com/healthmarketscience/jackcess/impl/OleUtil.java19
-rw-r--r--src/main/java/com/healthmarketscience/jackcess/util/OleBlob.java119
2 files changed, 120 insertions, 18 deletions
diff --git a/src/main/java/com/healthmarketscience/jackcess/impl/OleUtil.java b/src/main/java/com/healthmarketscience/jackcess/impl/OleUtil.java
index 4cef254..7af74fd 100644
--- a/src/main/java/com/healthmarketscience/jackcess/impl/OleUtil.java
+++ b/src/main/java/com/healthmarketscience/jackcess/impl/OleUtil.java
@@ -51,7 +51,7 @@ public class OleUtil
* Interface used to allow optional inclusion of the poi library for working
* with compound ole data.
*/
- public interface CompoundPackageFactory
+ interface CompoundPackageFactory
{
public ContentImpl createCompoundPackageContent(
OleBlobImpl blob, String prettyName, String className, String typeName,
@@ -98,10 +98,17 @@ public class OleUtil
COMPOUND_FACTORY = compoundFactory;
}
+ /**
+ * Parses an access database blob structure and returns an appropriate
+ * OleBlob instance.
+ */
public static OleBlob parseBlob(byte[] bytes) {
return new OleBlobImpl(bytes);
}
+ /**
+ * Creates a new OlBlob instance using the given information.
+ */
public static OleBlob createBlob(OleBlob.Builder oleBuilder)
throws IOException
{
@@ -258,7 +265,7 @@ public class OleUtil
return headerBytes;
}
-
+
private static byte[] writePackageStreamFooter(OleBlob.Builder oleBuilder) {
// note, these are _not_ zero terminated
@@ -280,7 +287,10 @@ public class OleUtil
return footerBytes;
}
- private static ContentImpl createContent(OleBlobImpl blob)
+ /**
+ * creates the appropriate ContentImpl for the given blob.
+ */
+ private static ContentImpl parseContent(OleBlobImpl blob)
throws IOException
{
ByteBuffer bb = PageChannel.wrap(blob.getBytes());
@@ -453,6 +463,7 @@ public class OleUtil
return (str + '\0').getBytes(OLE_CHARSET);
}
+
static final class OleBlobImpl implements OleBlob
{
private byte[] _bytes;
@@ -468,7 +479,7 @@ public class OleUtil
public Content getContent() throws IOException {
if(_content == null) {
- _content = createContent(this);
+ _content = parseContent(this);
}
return _content;
}
diff --git a/src/main/java/com/healthmarketscience/jackcess/util/OleBlob.java b/src/main/java/com/healthmarketscience/jackcess/util/OleBlob.java
index 54fdcca..529ea0e 100644
--- a/src/main/java/com/healthmarketscience/jackcess/util/OleBlob.java
+++ b/src/main/java/com/healthmarketscience/jackcess/util/OleBlob.java
@@ -32,8 +32,71 @@ import java.util.List;
import com.healthmarketscience.jackcess.impl.OleUtil;
/**
- *
- * Note, implementation is read-only.
+ * Extentions of the Blob interface with additional functionality for working
+ * with the OLE content from an access database. The ole data type in access
+ * has a wide range of functionality (including wrappers with nested wrappers
+ * with nested filesystems!), and jackcess only supports a small portion of
+ * it. That said, jackcess should support the bulk of the common
+ * functionality.
+ * <p/>
+ * The main Blob methods will interact with the <i>entire</i> OLE field data
+ * which, in most cases, contains additional wrapper information. In order to
+ * access the ultimate "content" contained within the OLE data, the {@link
+ * #getContent} method should be used. The type of this content may be a
+ * variety of formats, so additional sub-interfaces are available to interact
+ * with it. The most specific sub-interface can be determined by the {@link
+ * ContentType} of the Content.
+ * <p/>
+ * Once an OleBlob is no longer useful, <i>it should be closed</i> using
+ * {@link #free} or {@link #close} methods (after which, the instance will no
+ * longer be functional).
+ * <p/>
+ * Note, the OleBlob implementation is read-only (through the interface). In
+ * order to modify blob contents, create a new OleBlob instance using {@link
+ * OleBlob.Builder} and write it to the access database.
+ * <p/>
+ * <b>Example for interpreting an existing OLE field:</b>
+ * <pre>
+ * byte[] oleBytes = (byte[])row.get("MyOleColumn");
+ * OleBlob oleBlob = null;
+ * try {
+ * oleBlob = OleBlob.Builder.fromInternalData(oleBlob);
+ * Content content = oleBlob.getContent()
+ * if(content.getType() == OleBlob.ContentType.SIMPLE_PACKAGE) {
+ * FileOutputStream out = ...;
+ * ((SimplePackageContent)content).writeTo(out);
+ * out.closee();
+ * }
+ * } finally {
+ * if(oleBlob != null) { oleBlob.close(); }
+ * }
+ * </pre>
+ * <p/>
+ * <b>Example for creating new, embedded ole data:</b>
+ * <pre>
+ * OleBlob oleBlob = null;
+ * try {
+ * oleBlob = new OleBlob.Builder()
+ * .setSimplePackage(new File("some_data.txt"))
+ * .toBlob();
+ * db.addRow(1, oleBlob);
+ * } finally {
+ * if(oleBlob != null) { oleBlob.close(); }
+ * }
+ * </pre>
+ * <p/>
+ * <b>Example for creating new, linked ole data:</b>
+ * <pre>
+ * OleBlob oleBlob = null;
+ * try {
+ * oleBlob = new OleBlob.Builder()
+ * .setLink(new File("some_data.txt"))
+ * .toBlob();
+ * db.addRow(1, oleBlob);
+ * } finally {
+ * if(oleBlob != null) { oleBlob.close(); }
+ * }
+ * </pre>
*
* @author James Ahlborn
*/
@@ -43,7 +106,7 @@ public interface OleBlob extends Blob, Closeable
supported/understood */
public enum ContentType {
/** the blob contents are a link (file path) to some external content.
- Content will be an instance LinkContent */
+ Content will be an instance of LinkContent */
LINK,
/** the blob contents are a simple wrapper around some embedded content
and related file names/paths. Content will be an instance
@@ -51,8 +114,8 @@ public interface OleBlob extends Blob, Closeable
SIMPLE_PACKAGE,
/** the blob contents are a complex embedded data known as compound
storage (aka OLE2). Working with compound storage requires the
- optional POI library Content will be an instance CompoundContent. If
- the POI library is not available on the classpath, then compound
+ optional POI library. Content will be an instance of CompoundContent.
+ If the POI library is not available on the classpath, then compound
storage data will instead be returned as type {@link #OTHER}. */
COMPOUND_STORAGE,
/** the top-level blob wrapper is understood, but the nested blob contents
@@ -92,6 +155,9 @@ public interface OleBlob extends Blob, Closeable
public OleBlob getBlob();
}
+ /**
+ * Intermediate sub-interface for Content which has a nested package.
+ */
public interface PackageContent extends Content
{
public String getPrettyName() throws IOException;
@@ -101,6 +167,9 @@ public interface OleBlob extends Blob, Closeable
public String getTypeName() throws IOException;
}
+ /**
+ * Intermediate sub-interface for Content which has embedded content.
+ */
public interface EmbeddedContent extends Content
{
public long length();
@@ -110,6 +179,11 @@ public interface OleBlob extends Blob, Closeable
public void writeTo(OutputStream out) throws IOException;
}
+ /**
+ * Sub-interface for Content which has the {@link ContentType#LINK} type.
+ * The actual content is external to the access database and can be found at
+ * {@link #getLinkPath}.
+ */
public interface LinkContent extends PackageContent
{
public String getFileName();
@@ -121,6 +195,12 @@ public interface OleBlob extends Blob, Closeable
public InputStream getLinkStream() throws IOException;
}
+ /**
+ * Sub-interface for Content which has the {@link
+ * ContentType#SIMPLE_PACKAGE} type. The actual content is embedded within
+ * the access database (but the original file source path can also be found
+ * at {@link #getFilePath}).
+ */
public interface SimplePackageContent
extends PackageContent, EmbeddedContent
{
@@ -131,6 +211,19 @@ public interface OleBlob extends Blob, Closeable
public String getLocalFilePath();
}
+ /**
+ * Sub-interface for Content which has the {@link
+ * ContentType#COMPOUND_STORAGE} type. Compound storage is a complex
+ * embedding format also known as OLE2. In some situations (mostly
+ * non-microsoft office file formats) the actual content is available from
+ * the {@link #getContentsEntryStream} method (if {@link #hasContentsEntry}
+ * returns {@code true}). In other situations (e.g. microsoft office file
+ * formats), the actual content is most or all of the compound content (but
+ * retrieving the final file may be a complex operation, beyond the scope of
+ * jackcess). Note that the CompoundContent type will only be available if
+ * the POI library is in the classpath, otherwise compound content will be
+ * returned as OtherContent.
+ */
public interface CompoundContent extends PackageContent, EmbeddedContent
{
public List<String> getEntries() throws IOException;
@@ -142,20 +235,18 @@ public interface OleBlob extends Blob, Closeable
public InputStream getContentsEntryStream() throws IOException;
}
+ /**
+ * Sub-interface for Content which has the {@link ContentType#OTHER} type.
+ * This may be a simple embedded file or some other, currently not
+ * understood complex type.
+ */
public interface OtherContent extends PackageContent, EmbeddedContent
{
}
/**
- * Builder style class for constructing an OleBlob. The {@link
- * #fromInternalData} method can be used for interpreting existing ole data.
- * <p/>
- * Example for creating new ole data:
- * <pre>
- * OleBlob oleBlob = new OleBlob.Builder()
- * .setSimplePackageFile(contentFile)
- * .toBlob();
- * </pre>
+ * Builder style class for constructing an OleBlob. See {@link OleBlob} for
+ * example usage.
*/
public class Builder
{