| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectcom.adobe.xmp.XMPUtils
public class XMPUtils
Utility methods for XMP. I included only those that are different from the Java default conversion utilities.
| Method Summary | |
|---|---|
| static void | appendProperties(XMPMeta source,
                 XMPMeta dest,
                 boolean doAllProperties,
                 boolean replaceOldValues)Alias without the new option deleteEmptyValues. | 
| static void | appendProperties(XMPMeta source,
                 XMPMeta dest,
                 boolean doAllProperties,
                 boolean replaceOldValues,
                 boolean deleteEmptyValues)Append properties from one XMP object to another. | 
| static java.lang.String | catenateArrayItems(XMPMeta xmp,
                   java.lang.String schemaNS,
                   java.lang.String arrayName,
                   java.lang.String separator,
                   java.lang.String quotes,
                   boolean allowCommas)Create a single edit string from an array of strings. | 
| static java.lang.String | convertFromBoolean(boolean value)Convert from boolean to string. | 
| static java.lang.String | convertFromDate(XMPDateTime value)Convert from XMPDateTimeto string. | 
| static java.lang.String | convertFromDouble(double value)Convert from long to string. | 
| static java.lang.String | convertFromInteger(int value)Convert from int to string. | 
| static java.lang.String | convertFromLong(long value)Convert from long to string. | 
| static boolean | convertToBoolean(java.lang.String value)Convert from string to Boolean. | 
| static XMPDateTime | convertToDate(java.lang.String rawValue)Converts a string value to an XMPDateTime. | 
| static double | convertToDouble(java.lang.String rawValue)Converts a string value to a double. | 
| static int | convertToInteger(java.lang.String rawValue)Converts a string value to an int. | 
| static long | convertToLong(java.lang.String rawValue)Converts a string value to a long. | 
| static byte[] | decodeBase64(java.lang.String base64String)Decode from Base64 encoded string to raw data. | 
| static java.lang.String | encodeBase64(byte[] buffer)Convert from a byte array to a base64 encoded string. | 
| static void | removeProperties(XMPMeta xmp,
                 java.lang.String schemaNS,
                 java.lang.String propName,
                 boolean doAllProperties,
                 boolean includeAliases)Remove multiple properties from an XMP object. | 
| static void | separateArrayItems(XMPMeta xmp,
                   java.lang.String schemaNS,
                   java.lang.String arrayName,
                   java.lang.String catedStr,
                   PropertyOptions arrayOptions,
                   boolean preserveCommas)Separate a single edit string into an array of strings. | 
| Methods inherited from class java.lang.Object | 
|---|
| equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Method Detail | 
|---|
public static java.lang.String catenateArrayItems(XMPMeta xmp,
                                                  java.lang.String schemaNS,
                                                  java.lang.String arrayName,
                                                  java.lang.String separator,
                                                  java.lang.String quotes,
                                                  boolean allowCommas)
                                           throws XMPException
xmp - The XMP object containing the array to be catenated.schemaNS - The schema namespace URI for the array. Must not be null or
            the empty string.arrayName - The name of the array. May be a general path expression, must
            not be null or the empty string. Each item in the array must
            be a simple string value.separator - The string to be used to separate the items in the catenated
            string. Defaults to "; ", ASCII semicolon and space
            (U+003B, U+0020).quotes - The characters to be used as quotes around array items that
            contain a separator. Defaults to '"'allowCommas - Option flag to control the catenation.
XMPException - Forwards the Exceptions from the metadata processing
public static void separateArrayItems(XMPMeta xmp,
                                      java.lang.String schemaNS,
                                      java.lang.String arrayName,
                                      java.lang.String catedStr,
                                      PropertyOptions arrayOptions,
                                      boolean preserveCommas)
                               throws XMPException
xmp - The XMP object containing the array to be updated.schemaNS - The schema namespace URI for the array. Must not be null or
            the empty string.arrayName - The name of the array. May be a general path expression, must
            not be null or the empty string. Each item in the array must
            be a simple string value.catedStr - The string to be separated into the array items.arrayOptions - Option flags to control the separation.preserveCommas - Flag if commas shall be preserved
XMPException - Forwards the Exceptions from the metadata processing
public static void removeProperties(XMPMeta xmp,
                                    java.lang.String schemaNS,
                                    java.lang.String propName,
                                    boolean doAllProperties,
                                    boolean includeAliases)
                             throws XMPException
schemaNS and propName - The named property is
 removed if it is an external property, or if the 
 flag doAllProperties option is true. It does not matter whether the
 named property is an actual property or an alias.
 
 schemaNS and empty propName - The all external
 properties in the named schema are removed. Internal properties are also
 removed if the flag doAllProperties option is set. In addition,
 aliases from the named schema will be removed if the flag includeAliases 
 option is set.
 
 schemaNS and empty propName - All external properties in
 all schema are removed. Internal properties are also removed if the 
 flag doAllProperties option is passed. Aliases are implicitly handled
 because the associated actuals are internal if the alias is.
 schemaNS and non-empty propName.
xmp - The XMP object containing the properties to be removed.schemaNS - Optional schema namespace URI for the properties to be
            removed.propName - Optional path expression for the property to be removed.doAllProperties - Option flag to control the deletion: do internal properties in
          addition to external properties.includeAliases - Option flag to control the deletion: 
                        Include aliases in the "named schema" case above.
                        Note: Currently not supported.
XMPException - Forwards the Exceptions from the metadata processing
public static void appendProperties(XMPMeta source,
                                    XMPMeta dest,
                                    boolean doAllProperties,
                                    boolean replaceOldValues)
                             throws XMPException
deleteEmptyValues.
source - The source XMP object.dest - The destination XMP object.doAllProperties - Do internal properties in addition to external properties.replaceOldValues - Replace the values of existing properties.
XMPException - Forwards the Exceptions from the metadata processing
public static void appendProperties(XMPMeta source,
                                    XMPMeta dest,
                                    boolean doAllProperties,
                                    boolean replaceOldValues,
                                    boolean deleteEmptyValues)
                             throws XMPException
Append properties from one XMP object to another.
XMPUtils#appendProperties was created to support the File Info dialog's Append button, and
 has been been generalized somewhat from those specific needs. It appends information from one
 XMP object (source) to another (dest). The default operation is to append only external
 properties that do not already exist in the destination. The flag 
 doAllProperties can be used to operate on all properties, external and internal.
 The flag replaceOldValues option can be used to replace the values 
 of existing properties. The notion of external
 versus internal applies only to top level properties. The keep-or-replace-old notion applies
 within structs and arrays as described below.
 
replaceOldValues is true then the processing is restricted to the top 
 level properties. The processed properties from the source (according to 
 doAllProperties) are propagated to the destination, 
 replacing any existing values.Properties in the destination that are not in the source 
 are left alone.
 replaceOldValues is not passed then the processing is more complicated. 
 Top level properties are added to the destination if they do not already exist. 
 If they do exist but differ in form (simple/struct/array) then the destination is left alone.
 If the forms match, simple properties are left unchanged while structs and arrays are merged.
 
 deleteEmptyValues is passed then an empty value in the source XMP causes
 the corresponding destination XMP property to be deleted. The default is to treat empty 
 values the same as non-empty values. An empty value is any of a simple empty string, an array
 with no items, or a struct with no fields. Qualifiers are ignored.
 The detailed behavior is defined by the following pseudo-code:
 
    appendProperties ( sourceXMP, destXMP, doAllProperties, 
                        replaceOldValues, deleteEmptyValues ):
       for all source schema (top level namespaces):
          for all top level properties in sourceSchema:
             if doAllProperties or prop is external:
                appendSubtree ( sourceNode, destSchema, replaceOldValues, deleteEmptyValues )
 
    appendSubtree ( sourceNode, destParent, replaceOldValues, deleteEmptyValues ):
        if deleteEmptyValues and source value is empty:
            delete the corresponding child from destParent
        else if sourceNode not in destParent (by name):
           copy sourceNode's subtree to destParent
        else if replaceOld:
            delete subtree from destParent
            copy sourceNode's subtree to destParent
        else:
            // Already exists in dest and not replacing, merge structs and arrays
            if sourceNode and destNode forms differ:
                return, leave the destNode alone
            else if form is a struct:
                for each field in sourceNode:
                    AppendSubtree ( sourceNode.field, destNode, replaceOldValues )
            else if form is an alt-text array:
                copy new items by "xml:lang" value into the destination
            else if form is an array:
                copy new items by value into the destination, ignoring order and duplicates
 
 
 Note: appendProperties can be expensive if replaceOldValues is not passed and the XMP contains large arrays. The array item checking described above is n-squared. Each source item is checked to see if it already exists in the destination, without regard to order or duplicates.
Simple items are compared by value and "xml:lang" qualifier, other qualifiers are ignored. Structs are recursively compared by field names, without regard to field order. Arrays are compared by recursively comparing all items.
source - The source XMP object.dest - The destination XMP object.doAllProperties - Do internal properties in addition to external properties.replaceOldValues - Replace the values of existing properties.deleteEmptyValues - Delete destination values if source property is empty.
XMPException - Forwards the Exceptions from the metadata processing
public static boolean convertToBoolean(java.lang.String value)
                                throws XMPException
value - The string representation of the Boolean.
true and false are:
         XMPConst.TRUESTR and XMPConst.FALSESTR
                    XMPException - If an empty string is passed.public static java.lang.String convertFromBoolean(boolean value)
value - a boolean value
XMPConst.TRUESTR and
         XMPConst.FALSESTR.
public static int convertToInteger(java.lang.String rawValue)
                            throws XMPException
int.
rawValue - the string value
XMPException - If the rawValue is null or empty or the
             conversion fails.public static java.lang.String convertFromInteger(int value)
value - an int value
public static long convertToLong(java.lang.String rawValue)
                          throws XMPException
long.
rawValue - the string value
XMPException - If the rawValue is null or empty or the
             conversion fails.public static java.lang.String convertFromLong(long value)
value - a long value
public static double convertToDouble(java.lang.String rawValue)
                              throws XMPException
double.
rawValue - the string value
XMPException - If the rawValue is null or empty or the
             conversion fails.public static java.lang.String convertFromDouble(double value)
value - a long value
public static XMPDateTime convertToDate(java.lang.String rawValue)
                                 throws XMPException
XMPDateTime.
rawValue - the string value
XMPDateTime-object.
XMPException - If the rawValue is null or empty or the
             conversion fails.public static java.lang.String convertFromDate(XMPDateTime value)
XMPDateTime to string.
value - an XMPDateTime
public static java.lang.String encodeBase64(byte[] buffer)
buffer - the byte array to be converted
public static byte[] decodeBase64(java.lang.String base64String)
                           throws XMPException
base64String - a base64 encoded string
XMPException - Thrown if the given string is not property base64 encoded| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||