Class OutputProperties

All Implemented Interfaces:
Serializable, Cloneable, SourceLocator, XSLTVisitable, PrefixResolver, ExpressionNode, WhitespaceStrippingElementMatcher, Document, Element, Node, NodeList

public class OutputProperties extends ElemTemplateElement implements Cloneable
This class provides information from xsl:output elements. It is mainly a wrapper for Properties, but can not extend that class because it must be part of the ElemTemplateElement heararchy.

An OutputProperties list can contain another OutputProperties list as its "defaults"; this second property list is searched if the property key is not found in the original property list.

See Also:
  • Constructor Details

    • OutputProperties

      public OutputProperties()
      Creates an empty OutputProperties with no default values.
    • OutputProperties

      public OutputProperties(Properties defaults)
      Creates an empty OutputProperties with the specified defaults.
      Parameters:
      defaults - the defaults.
    • OutputProperties

      public OutputProperties(String method)
      Creates an empty OutputProperties with the defaults specified by a property file. The method argument is used to construct a string of the form output_[method].properties (for instance, output_html.properties). The output_xml.properties file is always used as the base.

      At the moment, anything other than 'text', 'xml', and 'html', will use the output_xml.properties file.

      Parameters:
      method - non-null reference to method name.
  • Method Details

    • clone

      public Object clone()
      Clone this OutputProperties, including a clone of the wrapped Properties reference.
      Returns:
      A new OutputProperties reference, mutation of which should not effect this object.
    • setProperty

      public void setProperty(QName key, String value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • setProperty

      public void setProperty(String key, String value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • getProperty

      public String getProperty(QName key)
      Searches for the property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list with the specified key value.
    • getProperty

      public String getProperty(String key)
      Searches for the property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list with the specified key value.
    • setBooleanProperty

      public void setBooleanProperty(QName key, boolean value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • setBooleanProperty

      public void setBooleanProperty(String key, boolean value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • getBooleanProperty

      public boolean getBooleanProperty(QName key)
      Searches for the boolean property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns false if the property is not found, or if the value is other than "yes".
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a boolean value, or false if null or not "yes".
    • getBooleanProperty

      public boolean getBooleanProperty(String key)
      Searches for the boolean property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns false if the property is not found, or if the value is other than "yes".
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a boolean value, or false if null or not "yes".
    • setIntProperty

      public void setIntProperty(QName key, int value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • setIntProperty

      public void setIntProperty(String key, int value)
      Set an output property.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • getIntProperty

      public int getIntProperty(QName key)
      Searches for the int property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns false if the property is not found, or if the value is other than "yes".
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a int value, or false if null or not a number.
    • getIntProperty

      public int getIntProperty(String key)
      Searches for the int property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns false if the property is not found, or if the value is other than "yes".
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a int value, or false if null or not a number.
    • setQNameProperty

      public void setQNameProperty(QName key, QName value)
      Set an output property with a QName value. The QName will be turned into a string with the namespace in curly brackets.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • setMethodDefaults

      public void setMethodDefaults(String method)
      Reset the default properties based on the method.
      Parameters:
      method - the method value.
      See Also:
    • setQNameProperty

      public void setQNameProperty(String key, QName value)
      Set an output property with a QName value. The QName will be turned into a string with the namespace in curly brackets.
      Parameters:
      key - the key to be placed into the property list.
      value - the value corresponding to key.
      See Also:
    • getQNameProperty

      public QName getQNameProperty(QName key)
      Searches for the qname property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a QName value, or false if null or not "yes".
    • getQNameProperty

      public QName getQNameProperty(String key)
      Searches for the qname property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a QName value, or false if null or not "yes".
    • getQNameProperty

      public static QName getQNameProperty(String key, Properties props)
      Searches for the qname property with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      props - the list of properties to search in.
      Returns:
      the value in this property list as a QName value, or false if null or not "yes".
    • setQNameProperties

      public void setQNameProperties(QName key, Vector v)
      Set an output property with a QName list value. The QNames will be turned into strings with the namespace in curly brackets.
      Parameters:
      key - the key to be placed into the property list.
      v - non-null list of QNames corresponding to key.
      See Also:
    • setQNameProperties

      public void setQNameProperties(String key, Vector v)
      Set an output property with a QName list value. The QNames will be turned into strings with the namespace in curly brackets.
      Parameters:
      key - the key to be placed into the property list.
      v - non-null list of QNames corresponding to key.
      See Also:
    • getQNameProperties

      public Vector getQNameProperties(QName key)
      Searches for the list of qname properties with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a vector of QNames, or false if null or not "yes".
    • getQNameProperties

      public Vector getQNameProperties(String key)
      Searches for the list of qname properties with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      Returns:
      the value in this property list as a vector of QNames, or false if null or not "yes".
    • getQNameProperties

      public static Vector getQNameProperties(String key, Properties props)
      Searches for the list of qname properties with the specified key in the property list. If the key is not found in this property list, the default property list, and its defaults, recursively, are then checked. The method returns null if the property is not found.
      Parameters:
      key - the property key.
      props - the list of properties to search in.
      Returns:
      the value in this property list as a vector of QNames, or false if null or not "yes".
    • recompose

      public void recompose(StylesheetRoot root) throws TransformerException
      This function is called to recompose all of the output format extended elements.
      Overrides:
      recompose in class ElemTemplateElement
      Parameters:
      root - non-null reference to the stylesheet root object.
      Throws:
      TransformerException
    • compose

      public void compose(StylesheetRoot sroot) throws TransformerException
      This function is called after everything else has been recomposed, and allows the template to set remaining values that may be based on some other property that depends on recomposition.
      Overrides:
      compose in class ElemTemplateElement
      Throws:
      TransformerException
    • getProperties

      public Properties getProperties()
      Get the Properties object that this class wraps.
      Returns:
      non-null reference to Properties object.
    • copyFrom

      public void copyFrom(Properties src)
      Copy the keys and values from the source to this object. This will not copy the default values. This is meant to be used by going from a higher precedence object to a lower precedence object, so that if a key already exists, this method will not reset it.
      Parameters:
      src - non-null reference to the source properties.
    • copyFrom

      public void copyFrom(Properties src, boolean shouldResetDefaults)
      Copy the keys and values from the source to this object. This will not copy the default values. This is meant to be used by going from a higher precedence object to a lower precedence object, so that if a key already exists, this method will not reset it.
      Parameters:
      src - non-null reference to the source properties.
      shouldResetDefaults - true if the defaults should be reset based on the method property.
    • copyFrom

      public void copyFrom(OutputProperties opsrc) throws TransformerException
      Copy the keys and values from the source to this object. This will not copy the default values. This is meant to be used by going from a higher precedence object to a lower precedence object, so that if a key already exists, this method will not reset it.
      Parameters:
      opsrc - non-null reference to an OutputProperties.
      Throws:
      TransformerException
    • isLegalPropertyKey

      public static boolean isLegalPropertyKey(String key)
      Report if the key given as an argument is a legal xsl:output key.
      Parameters:
      key - non-null reference to key name.
      Returns:
      true if key is legal.
    • getDefaultMethodProperties

      public static Properties getDefaultMethodProperties(String method)
      Deprecated.
      Use org.apache.xml.serializer.OuputPropertiesFactory. getDefaultMethodProperties directly.
      Creates an empty OutputProperties with the defaults specified by a property file. The method argument is used to construct a string of the form output_[method].properties (for instance, output_html.properties). The output_xml.properties file is always used as the base.

      At the moment, anything other than 'text', 'xml', and 'html', will use the output_xml.properties file.

      Parameters:
      method - non-null reference to method name.
      Returns:
      Properties object that holds the defaults for the given method.