From f2528d15aa89b37d2619ac6381ce72cb8b02efe5 Mon Sep 17 00:00:00 2001
From: Rainer Klute
+ * Represents a property set in the Horrible Property Set Format
+ * (HPSF). These are usually metadata of a Microsoft Office
+ * document.
+ *
An application that wants to access these metadata should create + * an instance of this class or one of its subclasses by calling the + * factory method {@link PropertySetFactory#create} and then retrieve + * the information its needs by calling appropriate methods.
* - * An application that wants to access these metadata should create an instance - * of this class or one of its subclasses by calling the factory method {@link - * PropertySetFactory#create} and then retrieve the information its needs by - * calling appropriate methods.+ *
{@link PropertySetFactory#create} does its work by calling one + * of the constructors {@link PropertySet#PropertySet(InputStream)} or + * {@link PropertySet#PropertySet(byte[])}. If the constructor's + * argument is not in the Horrible Property Set Format, i.e. not a + * property set stream, or if any other error occurs, an appropriate + * exception is thrown.
* - * {@link PropertySetFactory#create} does its work by calling one of the - * constructors {@link PropertySet#PropertySet(InputStream)} or {@link - * PropertySet#PropertySet(byte[])}. If the constructor's argument is not in - * the Horrible Property Set Format, i.e. not a property set stream, or if any - * other error occurs, an appropriate exception is thrown.+ *
A {@link PropertySet} has a list of {@link Section}s, and each + * {@link Section} has a {@link Property} array. Use {@link + * #getSections} to retrieve the {@link Section}s, then call {@link + * Section#getProperties} for each {@link Section} to get hold of the + * {@link Property} arrays.
Since the vast majority of {@link + * PropertySet}s contains only a single {@link Section}, the + * convenience method {@link #getProperties} returns the properties of + * a {@link PropertySet}'s {@link Section} (throwing a {@link + * NoSingleSectionException} if the {@link PropertySet} contains more + * (or less) than exactly one {@link Section}). * - * A {@link PropertySet} has a list of {@link Section}s, and each {@link - * Section} has a {@link Property} array. Use {@link #getSections} to retrieve - * the {@link Section}s, then call {@link Section#getProperties} for each - * {@link Section} to get hold of the {@link Property} arrays. Since the - * vast majority of {@link PropertySet}s contains only a single {@link - * Section}, the convenience method {@link #getProperties} returns the - * properties of a {@link PropertySet}'s {@link Section} (throwing a {@link - * NoSingleSectionException} if the {@link PropertySet} contains more (or less) - * than exactly one {@link Section}). - * - *@author Rainer Klute (klute@rainer-klute.de) - *@author Drew Varner (Drew.Varner hanginIn sc.edu) - *@created May 10, 2002 - *@version $Id$ - *@since 2002-02-09 + * @author Rainer Klute (klute@rainer-klute.de) + * @author Drew Varner (Drew.Varner hanginIn sc.edu) + * @version $Id$ + * @since 2002-02-09 */ -public class PropertySet { - final static byte[] BYTE_ORDER_ASSERTION = - new byte[]{(byte) 0xFE, (byte) 0xFF}; - final static byte[] FORMAT_ASSERTION = - new byte[]{(byte) 0x00, (byte) 0x00}; - - private int byteOrder; - - - // Must equal BYTE_ORDER_ASSERTION +public class PropertySet +{ /** - *- * - * Returns the property set stream's low-level "byte order" field. It is - * always 0xFFFE .
- * - *@return The byteOrder value + *The "byteOrder" field must equal this value.
*/ - public int getByteOrder() { + final static byte[] BYTE_ORDER_ASSERTION = + new byte[]{(byte) 0xFE, (byte) 0xFF}; + + /** + *The "format" field must equal this value.
+ */ + final static byte[] FORMAT_ASSERTION = + new byte[]{(byte) 0x00, (byte) 0x00}; + + /** + *Specifies this {@link PropertySet}'s byte order. See the + * HPFS documentation for details!
+ */ + private int byteOrder; + + /** + *Returns the property set stream's low-level "byte order" + * field. It is always 0xFFFE .
+ * + * @return The property set stream's low-level "byte order" field. + */ + public int getByteOrder() + { return byteOrder; } + /** + *Specifies this {@link PropertySet}'s format. See the HPFS + * documentation for details!
+ */ private int format; - - // Must equal FORMAT_ASSERTION - /** - *+ *
Returns the property set stream's low-level "format" + * field. It is always 0x0000 .
* - * Returns the property set stream's low-level "format" field. It is always - * 0x0000 . - * - *@return The format value + * @return The property set stream's low-level "format" field. */ - public int getFormat() { + public int getFormat() + { return format; } - + + /** + *Specifies the version of the operating system that created + * this {@link PropertySet}. See the HPFS documentation for + * details!
+ */ private long osVersion; - /** - *+ *
Returns the property set stream's low-level "OS version" + * field.
* - * Returns the property set stream's low-level "OS version" field. - * - *@return The oSVersion value + * @return The property set stream's low-level "OS version" field. */ - public long getOSVersion() { + public long getOSVersion() + { return osVersion; } + /** + *Specifies this {@link PropertySet}'s "classID" field. See + * the HPFS documentation for details!
+ */ private ClassID classID; - /** - *+ *
Returns the property set stream's low-level "class ID" + * field.
* - * Returns the property set stream's low-level "class ID" field. - * - *@return The classID value + * @return The property set stream's low-level "class ID" field. */ - public ClassID getClassID() { + public ClassID getClassID() + { return classID; } + /** + *The number of sections in this {@link PropertySet}.
+ */ private long sectionCount; /** - *+ *
Returns the number of {@link Section}s in the property + * set.
* - * Returns the number of {@link Section}s in the property set. - * - *@return The sectionCount value + * @return The number of {@link Section}s in the property set. */ - public long getSectionCount() { + public long getSectionCount() + { return sectionCount; } + /** + *The sections in this {@link PropertySet}.
+ */ private List sections; /** - *+ *
Returns the {@link Section}s in the property set.
* - * Returns the {@link Section}s in the property set. - * - *@return The sections value + * @return The {@link Section}s in the property set. */ - public List getSections() { + public List getSections() + { return sections; } /** - *+ *
Creates an empty (uninitialized) {@link PropertySet}.
* - * Creates an empty (uninitialized) {@link PropertySet}.- * - * Please note: For the time being this constructor is - * protected since it is used for internal purposes only, but expect it to - * become public once the property set writing functionality is - * implemented.
+ *Please note: For the time being this + * constructor is protected since it is used for internal purposes + * only, but expect it to become public once the property set's + * writing functionality is implemented.
*/ - protected PropertySet() { } + protected PropertySet() + {} /** - *+ *
Creates a {@link PropertySet} instance from an {@link + * InputStream} in the Horrible Property Set Format.
* - * Creates a {@link PropertySet} instance from an {@link InputStream} in - * the Horrible Property Set Format.+ *
The constructor reads the first few bytes from the stream + * and determines whether it is really a property set stream. If + * it is, it parses the rest of the stream. If it is not, it + * resets the stream to its beginning in order to let other + * components mess around with the data and throws an + * exception.
* - * The constructor reads the first few bytes from the stream and determines - * whether it is really a property set stream. If it is, it parses the rest - * of the stream. If it is not, it resets the stream to its beginning in - * order to let other components mess around with the data and throws an - * exception. - * - *@param stream Description of the Parameter - *@exception NoPropertySetStreamException Description of the Exception - *@exception MarkUnsupportedException Description of the Exception - *@exception IOException Description of the Exception - *@throws NoPropertySetStreamException if the stream is not a property - * set stream. - *@throws MarkUnsupportedException if the stream does not support - * the {@link InputStream#markSupported} method. - *@throws IOException if the {@link InputStream} - * cannot not be accessed as needed. + * @param stream Holds the data making out the property set + * stream. + * @throws MarkUnsupportedException if the stream does not support + * the {@link InputStream#markSupported} method. + * @throws IOException if the {@link InputStream} cannot not be + * accessed as needed. */ public PropertySet(final InputStream stream) - throws NoPropertySetStreamException, MarkUnsupportedException, - IOException { - if (isPropertySetStream(stream)) { + throws NoPropertySetStreamException, MarkUnsupportedException, + IOException + { + if (isPropertySetStream(stream)) + { final int avail = stream.available(); final byte[] buffer = new byte[avail]; stream.read(buffer, 0, buffer.length); init(buffer, 0, buffer.length); - } else { - throw new NoPropertySetStreamException(); } + else + throw new NoPropertySetStreamException(); } /** - *+ *
Creates a {@link PropertySet} instance from a byte array + * that represents a stream in the Horrible Property Set + * Format.
* - * Creates a {@link PropertySet} instance from a byte array that represents - * a stream in the Horrible Property Set Format. - * - *@param stream The byte array holding the - * stream data. - *@param offset The offset in stream - * where the stream data begin. If the stream data begin with the first - * byte in the array, the offset is 0. - *@param length The length of the stream data. - *@exception NoPropertySetStreamException Description of the Exception - *@throws NoPropertySetStreamException if the byte array is not a - * property set stream. + * @param stream The byte array holding the stream data. + * @param offset The offset in stream where the stream + * data begin. If the stream data begin with the first byte in the + * array, the offset is 0. + * @param length The length of the stream data. + * @throws NoPropertySetStreamException if the byte array is not a + * property set stream. */ public PropertySet(final byte[] stream, final int offset, final int length) - throws NoPropertySetStreamException { - if (isPropertySetStream(stream, offset, length)) { + throws NoPropertySetStreamException + { + if (isPropertySetStream(stream, offset, length)) init(stream, offset, length); - } else { + else throw new NoPropertySetStreamException(); - } } /** - *+ *
Creates a {@link PropertySet} instance from a byte array + * that represents a stream in the Horrible Property Set + * Format.
* - * Creates a {@link PropertySet} instance from a byte array that represents - * a stream in the Horrible Property Set Format. - * - *@param stream The byte array holding the - * stream data. The complete byte array contents is the stream data. - *@exception NoPropertySetStreamException Description of the Exception - *@throws NoPropertySetStreamException if the byte array is not a - * property set stream. + * @param stream The byte array holding the stream data. The + * complete byte array contents is the stream data. + * @throws NoPropertySetStreamException if the byte array is not a + * property set stream. */ - public PropertySet(final byte[] stream) - throws NoPropertySetStreamException { + public PropertySet(final byte[] stream) throws NoPropertySetStreamException + { this(stream, 0, stream.length); } /** - *+ *
Checks whether an {@link InputStream} is in the Horrible + * Property Set Format.
* - * Checks whether an {@link InputStream} is in the Horrible Property Set - * Format. - * - *@param stream The {@link InputStream} to check. In - * order to perform the check, the method reads the first bytes from - * the stream. After reading, the stream is reset to the position it - * had before reading. The {@link InputStream} must support the {@link - * InputStream#mark} method. - *@returntrue
if the stream is a
- * property set stream, else false
.
- *@exception IOException Description of the Exception
- *@throws MarkUnsupportedException if the {@link InputStream} does not
- * support the {@link InputStream#mark} method.
+ * @param stream The {@link InputStream} to check. In order to
+ * perform the check, the method reads the first bytes from the
+ * stream. After reading, the stream is reset to the position it
+ * had before reading. The {@link InputStream} must support the
+ * {@link InputStream#mark} method.
+ * @return true
if the stream is a property set
+ * stream, else false
.
+ * @throws MarkUnsupportedException if the {@link InputStream}
+ * does not support the {@link InputStream#mark} method.
*/
public static boolean isPropertySetStream(final InputStream stream)
- throws MarkUnsupportedException, IOException {
+ throws MarkUnsupportedException, IOException
+ {
/*
- * Read at most this many bytes.
+ * Read at most this many bytes.
*/
final int BUFFER_SIZE = 50;
/*
- * Mark the current position in the stream so that we can
- * reset to this position if the stream does not contain a
- * property set.
+ * Mark the current position in the stream so that we can
+ * reset to this position if the stream does not contain a
+ * property set.
*/
- if (!stream.markSupported()) {
+ if (!stream.markSupported())
throw new MarkUnsupportedException(stream.getClass().getName());
- }
- stream.mark(BUFFER_SIZE);
+ stream.mark(BUFFER_SIZE);
/*
- * Read a couple of bytes from the stream.
+ * Read a couple of bytes from the stream.
*/
final byte[] buffer = new byte[BUFFER_SIZE];
final int bytes =
- stream.read(buffer, 0,
- Math.min(buffer.length, stream.available()));
+ stream.read(buffer, 0,
+ Math.min(buffer.length, stream.available()));
final boolean isPropertySetStream =
- isPropertySetStream(buffer, 0, bytes);
+ isPropertySetStream(buffer, 0, bytes);
stream.reset();
return isPropertySetStream;
}
@@ -349,66 +358,63 @@ public class PropertySet {
/**
- * + *
Checks whether a byte array is in the Horrible Property Set + * Format.
* - * Checks whether a byte array is in the Horrible Property Set Format. - * - *@param src The byte array to check. - *@param offset The offset in the byte array. - *@param length The significant number of bytes in the byte array. Only - * this number of bytes will be checked. - *@returntrue
if the byte array is a property set
- * stream, false
if not.
+ * @param src The byte array to check.
+ * @param offset The offset in the byte array.
+ * @param length The significant number of bytes in the byte
+ * array. Only this number of bytes will be checked.
+ * @return true
if the byte array is a property set
+ * stream, false
if not.
*/
public static boolean isPropertySetStream(final byte[] src, int offset,
- final int length) {
+ final int length)
+ {
/*
- * Read the header fields of the stream. They must always be
- * there.
+ * Read the header fields of the stream. They must always be
+ * there.
*/
final int byteOrder = LittleEndian.getUShort(src, offset);
offset += LittleEndian.SHORT_SIZE;
byte[] temp = new byte[LittleEndian.SHORT_SIZE];
LittleEndian.putShort(temp,(short)byteOrder);
- if (!Util.equal(temp, BYTE_ORDER_ASSERTION)) {
+ if (!Util.equal(temp, BYTE_ORDER_ASSERTION))
return false;
- }
- final int format = LittleEndian.getUShort(src, offset);
+ final int format = LittleEndian.getUShort(src, offset);
offset += LittleEndian.SHORT_SIZE;
temp = new byte[LittleEndian.SHORT_SIZE];
LittleEndian.putShort(temp,(short)format);
- if (!Util.equal(temp, FORMAT_ASSERTION)) {
+ if (!Util.equal(temp, FORMAT_ASSERTION))
return false;
- }
- final long osVersion = LittleEndian.getUInt(src, offset);
+ final long osVersion = LittleEndian.getUInt(src, offset);
offset += LittleEndian.INT_SIZE;
final ClassID classID = new ClassID(src, offset);
offset += ClassID.LENGTH;
final long sectionCount = LittleEndian.getUInt(src, offset);
offset += LittleEndian.INT_SIZE;
- if (sectionCount < 1) {
+ if (sectionCount < 1)
return false;
- }
- return true;
+ return true;
}
/**
- * + *
Initializes this {@link PropertySet} instance from a byte + * array. The method assumes that it has been checked already that + * the byte array indeed represents a property set stream. It does + * no more checks on its own.
* - * Initializes this {@link PropertySet} instance from a byte array. The - * method assumes that it has been checked already that the byte array - * indeed represents a property set stream. It does no more checks on its - * own. - * - *@param src Description of the Parameter - *@param offset Description of the Parameter - *@param length Description of the Parameter + * @param src Byte array containing the property set stream + * @param offset The property set stream starts at this offset + * from the beginning of src + * @param length Length of the property set stream. */ - private void init(final byte[] src, int offset, final int length) { + private void init(final byte[] src, int offset, final int length) + { /* - * Read the stream's header fields. + * Read the stream's header fields. */ byteOrder = LittleEndian.getUShort(src, offset); offset += LittleEndian.SHORT_SIZE; @@ -422,25 +428,26 @@ public class PropertySet { offset += LittleEndian.INT_SIZE; /* - * Read the sections, which are following the header. They - * start with an array of section descriptions. Each one - * consists of a format ID telling what the section contains - * and an offset telling how many bytes from the start of the - * stream the section begins. + * Read the sections, which are following the header. They + * start with an array of section descriptions. Each one + * consists of a format ID telling what the section contains + * and an offset telling how many bytes from the start of the + * stream the section begins. */ /* - * Most property sets have only one section. The Document - * Summary Information stream has 2. Everything else is a rare - * exception and is no longer fostered by Microsoft. + * Most property sets have only one section. The Document + * Summary Information stream has 2. Everything else is a rare + * exception and is no longer fostered by Microsoft. */ sections = new ArrayList(2); /* - * Loop over the section descriptor array. Each descriptor - * consists of a ClassID and a DWord, and we have to increment - * "offset" accordingly. + * Loop over the section descriptor array. Each descriptor + * consists of a ClassID and a DWord, and we have to increment + * "offset" accordingly. */ - for (int i = 0; i < sectionCount; i++) { + for (int i = 0; i < sectionCount; i++) + { final Section s = new Section(src, offset); offset += ClassID.LENGTH + LittleEndian.INT_SIZE; sections.add(s); @@ -450,156 +457,152 @@ public class PropertySet { /** - *+ *
Checks whether this {@link PropertySet} represents a Summary + * Information.
* - * Checks whether this {@link PropertySet} represents a Summary - * Information. - * - *@return The summaryInformation value + * @returntrue
if this {@link PropertySet}
+ * represents a Summary Information, else false
.
*/
- public boolean isSummaryInformation() {
+ public boolean isSummaryInformation()
+ {
return Util.equal(((Section) sections.get(0)).getFormatID().getBytes(),
- SectionIDMap.SUMMARY_INFORMATION_ID);
+ SectionIDMap.SUMMARY_INFORMATION_ID);
}
/**
- * + *
Checks whether this {@link PropertySet} is a Document + * Summary Information.
* - * Checks whether this {@link PropertySet} is a Document Summary - * Information. - * - *@return The documentSummaryInformation value + * @returntrue
if this {@link PropertySet}
+ * represents a Document Summary Information, else false
.
*/
- public boolean isDocumentSummaryInformation() {
+ public boolean isDocumentSummaryInformation()
+ {
return Util.equal(((Section) sections.get(0)).getFormatID().getBytes(),
- SectionIDMap.DOCUMENT_SUMMARY_INFORMATION_ID);
+ SectionIDMap.DOCUMENT_SUMMARY_INFORMATION_ID);
}
/**
- * + *
Convenience method returning the {@link Property} array + * contained in this property set. It is a shortcut for getting + * the {@link PropertySet}'s {@link Section}s list and then + * getting the {@link Property} array from the first {@link + * Section}. However, it can only be used if the {@link + * PropertySet} contains exactly one {@link Section}, so check + * {@link #getSectionCount} first!
* - * Convenience method returning the {@link Property} array contained in - * this property set. It is a shortcut for getting the {@link - * PropertySet}'s {@link Section}s list and then getting the {@link - * Property} array from the first {@link Section}. However, it can only be - * used if the {@link PropertySet} contains exactly one {@link Section}, so - * check {@link #getSectionCount} first! - * - *@return The properties of the only {@link - * Section} of this {@link PropertySet}. - *@throws NoSingleSectionException if the {@link PropertySet} has more or - * less than one {@link Section}. + * @return The properties of the only {@link Section} of this + * {@link PropertySet}. + * @throws NoSingleSectionException if the {@link PropertySet} has + * more or less than one {@link Section}. */ public Property[] getProperties() - throws NoSingleSectionException { + throws NoSingleSectionException + { return getSingleSection().getProperties(); } /** - *+ *
Convenience method returning the value of the property with
+ * the specified ID. If the property is not available,
+ * null
is returned and a subsequent call to {@link
+ * #wasNull} will return true
.
null
is
- * returned and a subsequent call to {@link #wasNull} will return true
- * .
- *
- *@param id Description of the Parameter
- *@return The property value
- *@throws NoSingleSectionException if the {@link PropertySet} has more or
- * less than one {@link Section}.
+ * @param id The property ID
+ * @return The property value
+ * @throws NoSingleSectionException if the {@link PropertySet} has
+ * more or less than one {@link Section}.
*/
- protected Object getProperty(final int id)
- throws NoSingleSectionException {
+ protected Object getProperty(final int id) throws NoSingleSectionException
+ {
return getSingleSection().getProperty(id);
}
/**
- * + *
Convenience method returning the value of a boolean property
+ * with the specified ID. If the property is not available,
+ * false
is returned. A subsequent call to {@link
+ * #wasNull} will return true
to let the caller
+ * distinguish that case from a real property value of
+ * false
.
false
is
- * returned. A subsequent call to {@link #wasNull} will return true
- * to let the caller distinguish that case from a real property value of
- * false
.
- *
- *@param id Description of the Parameter
- *@return The propertyBooleanValue value
- *@throws NoSingleSectionException if the {@link PropertySet} has more or
- * less than one {@link Section}.
+ * @param id The property ID
+ * @return The property value
+ * @throws NoSingleSectionException if the {@link PropertySet} has
+ * more or less than one {@link Section}.
*/
protected boolean getPropertyBooleanValue(final int id)
- throws NoSingleSectionException {
+ throws NoSingleSectionException
+ {
return getSingleSection().getPropertyBooleanValue(id);
}
/**
- * + *
Convenience method returning the value of the numeric
+ * property with the specified ID. If the property is not
+ * available, 0 is returned. A subsequent call to {@link #wasNull}
+ * will return true
to let the caller distinguish
+ * that case from a real property value of 0.
true
to let
- * the caller distinguish that case from a real property value of 0.
- *
- *@param id Description of the Parameter
- *@return The propertyIntValue value
- *@throws NoSingleSectionException if the {@link PropertySet} has more or
- * less than one {@link Section}.
+ * @param id The property ID
+ * @return The propertyIntValue value
+ * @throws NoSingleSectionException if the {@link PropertySet} has
+ * more or less than one {@link Section}.
*/
protected int getPropertyIntValue(final int id)
- throws NoSingleSectionException {
+ throws NoSingleSectionException
+ {
return getSingleSection().getPropertyIntValue(id);
}
/**
- * + *
Checks whether the property which the last call to {@link + * #getPropertyIntValue} or {@link #getProperty} tried to access + * was available or not. This information might be important for + * callers of {@link #getPropertyIntValue} since the latter + * returns 0 if the property does not exist. Using {@link + * #wasNull}, the caller can distiguish this case from a + * property's real value of 0.
* - * Checks whether the property which the last call to {@link - * #getPropertyIntValue} or {@link #getProperty} tried to access was - * available or not. This information might be important for callers of - * {@link #getPropertyIntValue} since the latter returns 0 if the property - * does not exist. Using {@link #wasNull}, the caller can distiguish this - * case from a property's real value of 0. - * - *@returntrue
if the last call to
- * {@link #getPropertyIntValue} or {@link #getProperty} tried to access
- * a property that was not available, else false
.
- *@throws NoSingleSectionException if the {@link PropertySet} has more
- * than one {@link Section}.
+ * @return true
if the last call to {@link
+ * #getPropertyIntValue} or {@link #getProperty} tried to access a
+ * property that was not available, else false
.
+ * @throws NoSingleSectionException if the {@link PropertySet} has
+ * more than one {@link Section}.
*/
- public boolean wasNull() throws NoSingleSectionException {
+ public boolean wasNull() throws NoSingleSectionException
+ {
return getSingleSection().wasNull();
}
/**
- * + *
If the {@link PropertySet} has only a single section this + * method returns it.
* - * If the {@link PropertySet} has only a single section this method returns - * it. - * - *@return The singleSection value - *@throws NoSingleSectionException if the {@link PropertySet} has more or - * less than exactly one {@link Section}. + *@return The singleSection value + *@throws NoSingleSectionException if the {@link PropertySet} has + *more or less than exactly one {@link Section}. */ - public Section getSingleSection() { - if (sectionCount != 1) { - throw new NoSingleSectionException - ("Property set contains " + sectionCount + " sections."); - } - return ((Section) sections.get(0)); + public Section getSingleSection() + { + if (sectionCount != 1) + throw new NoSingleSectionException + ("Property set contains " + sectionCount + " sections."); + return ((Section) sections.get(0)); } } diff --git a/src/java/org/apache/poi/hpsf/wellknown/PropertyIDMap.java b/src/java/org/apache/poi/hpsf/wellknown/PropertyIDMap.java index 217a635734..dc7f32e6f9 100644 --- a/src/java/org/apache/poi/hpsf/wellknown/PropertyIDMap.java +++ b/src/java/org/apache/poi/hpsf/wellknown/PropertyIDMap.java @@ -57,222 +57,133 @@ package org.apache.poi.hpsf.wellknown; import java.util.*; /** - *+ *
This is a dictionary which maps property ID values to property + * ID strings.
* - * This is a dictionary mapping property IDs to property ID strings.+ *
The methods {@link #getSummaryInformationProperties} and {@link + * #getDocumentSummaryInformationProperties} return singleton {@link + * PropertyIDMap}s. An application that wants to extend these maps + * should treat them as unmodifiable, copy them and modifiy the + * copies.
* - * The methods {@link #getSummaryInformationProperties} and {@link - * #getDocumentSummaryInformationProperties} return singleton {@link - * PropertyIDMap}s. An application that wants to extend these maps should treat - * them as unmodifiable, copy them and modifiy the copies.+ *
FIXME: Make the singletons + * unmodifiable. However, since this requires to use a {@link HashMap} + * delegate instead of extending {@link HashMap} and thus requires a + * lot of stupid typing. I won't do that for the time being.
* - * FIXME: Make the singletons unmodifiable. However, since - * this requires use a {@link HashMap} delegate instead of extending {@link - * HashMap} and would require a lot of stupid typing, I won't do it for the - * time being. - * - *@author Rainer Klute (klute@rainer-klute.de) - *@created May 10, 2002 - *@version $Id$ - *@since 2002-02-09 + * @author Rainer Klute (klute@rainer-klute.de) + * @version $Id$ + * @since 2002-02-09 */ -public class PropertyIDMap extends HashMap { +public class PropertyIDMap extends HashMap +{ /* - * The following definitions are for the Summary Information. - */ - /** - * Description of the Field + * The following definitions are for the Summary Information. */ public final static int PID_TITLE = 2; - /** - * Description of the Field - */ public final static int PID_SUBJECT = 3; - /** - * Description of the Field - */ public final static int PID_AUTHOR = 4; - /** - * Description of the Field - */ public final static int PID_KEYWORDS = 5; - /** - * Description of the Field - */ public final static int PID_COMMENTS = 6; - /** - * Description of the Field - */ public final static int PID_TEMPLATE = 7; - /** - * Description of the Field - */ public final static int PID_LASTAUTHOR = 8; - /** - * Description of the Field - */ public final static int PID_REVNUMBER = 9; - /** - * Description of the Field - */ public final static int PID_EDITTIME = 10; - /** - * Description of the Field - */ public final static int PID_LASTPRINTED = 11; - /** - * Description of the Field - */ public final static int PID_CREATE_DTM = 12; - /** - * Description of the Field - */ public final static int PID_LASTSAVE_DTM = 13; - /** - * Description of the Field - */ public final static int PID_PAGECOUNT = 14; - /** - * Description of the Field - */ public final static int PID_WORDCOUNT = 15; - /** - * Description of the Field - */ public final static int PID_CHARCOUNT = 16; - /** - * Description of the Field - */ public final static int PID_THUMBNAIL = 17; - /** - * Description of the Field - */ public final static int PID_APPNAME = 18; - /** - * Description of the Field - */ public final static int PID_SECURITY = 19; /* - * The following definitions are for the Document Summary Information. - */ - /** - * Description of the Field + * The following definitions are for the Document Summary Information. */ public final static int PID_CATEGORY = 2; - /** - * Description of the Field - */ public final static int PID_PRESFORMAT = 3; - /** - * Description of the Field - */ public final static int PID_BYTECOUNT = 4; - /** - * Description of the Field - */ public final static int PID_LINECOUNT = 5; - /** - * Description of the Field - */ public final static int PID_PARCOUNT = 6; - /** - * Description of the Field - */ public final static int PID_SLIDECOUNT = 7; - /** - * Description of the Field - */ public final static int PID_NOTECOUNT = 8; - /** - * Description of the Field - */ public final static int PID_HIDDENCOUNT = 9; - /** - * Description of the Field - */ public final static int PID_MMCLIPCOUNT = 10; - /** - * Description of the Field - */ public final static int PID_SCALE = 11; - /** - * Description of the Field - */ public final static int PID_HEADINGPAIR = 12; - /** - * Description of the Field - */ public final static int PID_DOCPARTS = 13; - /** - * Description of the Field - */ public final static int PID_MANAGER = 14; - /** - * Description of the Field - */ public final static int PID_COMPANY = 15; - /** - * Description of the Field - */ public final static int PID_LINKSDIRTY = 16; + /** + *Contains the summary information property ID values and + * associated strings. See the overall HPSF documentation for + * details!
+ */ private static PropertyIDMap summaryInformationProperties; + + /** + *Contains the summary information property ID values and + * associated strings. See the overall HPSF documentation for + * details!
+ */ private static PropertyIDMap documentSummaryInformationProperties; /** - * Constructor for the PropertyIDMap object - * - *@param initialCapacity Description of the Parameter - *@param loadFactor Description of the Parameter + *Creates a {@link PropertyIDMap}.
*/ - public PropertyIDMap(int initialCapacity, float loadFactor) { + public PropertyIDMap(int initialCapacity, float loadFactor) + { super(initialCapacity, loadFactor); } /** - *+ *
Puts a ID string for an ID into the {@link + * PropertyIDMap}.
* - * Puts a ID string for an ID into the {@link PropertyIDMap}. - * - *@param id The ID. - *@param idString The ID string. - *@return Description of the Return Value + * @param id The ID. + * @param idString The ID string. + * @return As specified by the {@link Map} interface, this method + * returns the previous value associated with the specified + * id, ornull
if there was no mapping for
+ * key.
*/
- public Object put(int id, String idString) {
+ public Object put(int id, String idString)
+ {
return put(new Integer(id), idString);
}
/**
- * + *
Gets the ID string for an ID from the {@link + * PropertyIDMap}.
* - * Gets the ID string for an ID from the {@link PropertyIDMap}. - * - *@param id The ID. - *@return Description of the Return Value + * @param id The ID. + * @return The ID string associated with id. */ - public Object get(int id) { + public Object get(int id) + { return get(new Integer(id)); } /** - *- * - * Returns the Summary Information properties singleton.
- * - *@return The summaryInformationProperties value + *Returns the Summary Information properties singleton.
*/ - public static PropertyIDMap getSummaryInformationProperties() { - if (summaryInformationProperties == null) { + public static PropertyIDMap getSummaryInformationProperties() + { + if (summaryInformationProperties == null) + { PropertyIDMap m = new PropertyIDMap(17, (float) 1.0); m.put(PID_TITLE, "PID_TITLE"); m.put(PID_SUBJECT, "PID_SUBJECT"); @@ -300,14 +211,15 @@ public class PropertyIDMap extends HashMap { /** - *+ *
Returns the Document Summary Information properties + * singleton.
* - * Returns the Summary Information properties singleton. - * - *@return The documentSummaryInformationProperties value + * @return The Document Summary Information properties singleton. */ - public static PropertyIDMap getDocumentSummaryInformationProperties() { - if (documentSummaryInformationProperties == null) { + public static PropertyIDMap getDocumentSummaryInformationProperties() + { + if (documentSummaryInformationProperties == null) + { PropertyIDMap m = new PropertyIDMap(17, (float) 1.0); m.put(PID_CATEGORY, "PID_CATEGORY"); m.put(PID_PRESFORMAT, "PID_PRESFORMAT"); @@ -332,11 +244,10 @@ public class PropertyIDMap extends HashMap { /** - * Description of the Method - * - *@param args Description of the Parameter + *For the most basic testing.
*/ - public static void main(String args[]) { + public static void main(String args[]) + { PropertyIDMap s1 = getSummaryInformationProperties(); PropertyIDMap s2 = getDocumentSummaryInformationProperties(); System.out.println("s1: " + s1);