org.apache.xalan.templates
Class StylesheetRoot

java.lang.Object
  |
  +--org.apache.xml.utils.UnImplNode
        |
        +--org.apache.xalan.templates.ElemTemplateElement
              |
              +--org.apache.xalan.templates.Stylesheet
                    |
                    +--org.apache.xalan.templates.StylesheetComposed
                          |
                          +--org.apache.xalan.templates.StylesheetRoot

public class StylesheetRoot
extends StylesheetComposed
implements java.io.Serializable, Templates

This class represents the root object of the stylesheet tree.

See Also:
Serialized Form

Fields inherited from class org.apache.xalan.templates.Stylesheet
STYLESHEET_EXT
 
Constructor Summary
StylesheetRoot(ErrorListener errorListener)
          Uses an XSL stylesheet document.
StylesheetRoot(XSLTSchema schema, ErrorListener listener)
          Creates a StylesheetRoot and retains a pointer to the schema used to create this StylesheetRoot.
 
Method Summary
 boolean canStripWhiteSpace()
          Get information about whether or not whitespace can be stripped.
 java.util.Vector getAttributeSetComposed(QName name)
          Get a list "xsl:attribute-set" properties that match the qname.
 java.util.Hashtable getAvailableElements()
          Get the hashtable of available elements.
 java.text.DecimalFormatSymbols getDecimalFormatComposed(QName name)
          Given a valid element decimal-format name, return the decimalFormatSymbols with that name.
 java.util.Properties getDefaultOutputProps()
           
 ElemTemplate getDefaultRootRule()
          **For advanced use only** Get the default template for a root node.
 ElemTemplate getDefaultRule()
          **For advanced use only** Get the default template for elements.
 ElemTemplate getDefaultTextRule()
          **For advanced use only** Get the default template for text.
 StylesheetComposed getGlobalImport(int i)
          Get a stylesheet from the global import list.
 int getGlobalImportCount()
          Get the total number of imports in the global import list.
 int getImportNumber(StylesheetComposed sheet)
          Given a stylesheet, return the number of the stylesheet in the global import list.
 java.util.Vector getKeysComposed()
          Get the composed "xsl:key" properties.
 NamespaceAlias getNamespaceAliasComposed(java.lang.String uri)
          Get the "xsl:namespace-alias" property.
 OutputProperties getOutputComposed()
          Get the combined "xsl:output" property with the properties combined from the included stylesheets.
 java.util.Properties getOutputProperties()
          Get the static properties for xsl:output.
 ElemTemplate getTemplateComposed(QName qname)
          Get an "xsl:template" property.
 ElemTemplate getTemplateComposed(XPathContext xctxt, Node targetNode, QName mode, int maxImportLevel, boolean quietConflictWarnings)
          Get an "xsl:template" property by node match.
 TemplateList getTemplateListComposed()
          Accessor method to retrieve the TemplateList associated with this StylesheetRoot.
 ElemVariable getVariableOrParamComposed(QName qname)
          Get an "xsl:variable" property.
 java.util.Vector getVariablesAndParamsComposed()
          Get all global "xsl:variable" properties in scope for this stylesheet.
 WhiteSpaceInfo getWhiteSpaceInfo(XPathContext support, Element targetElement)
          Get information about whether or not an element should strip whitespace.
 boolean isOutputMethodSet()
          **For internal use only** Find out if an output method has been set by the user.
 boolean isRoot()
          Tell if this is the root of the stylesheet tree.
 Transformer newTransformer()
          Create a new transformation context for this Templates object.
 void recompose()
          Recompose the values of all "composed" properties, meaning properties that need to be combined or calculated from the combination of imported and included stylesheets.
 void setTemplateListComposed(TemplateList templateList)
          Mutator method to set the TemplateList associated with this StylesheetRoot.
 boolean shouldCheckWhitespace()
          Check to see if the caller should bother with check for whitespace nodes.
 boolean shouldStripWhiteSpace(XPathContext support, Element targetElement)
          Get information about whether or not an element should strip whitespace.
 
Methods inherited from class org.apache.xalan.templates.StylesheetComposed
getImportComposed, getImportCountComposed, getIncludeComposed, getIncludeCountComposed, isAggregatedType, recompose, recomposeTemplates
 
Methods inherited from class org.apache.xalan.templates.Stylesheet
containsExcludeResultPrefix, containsExtensionElementURI, getAttributeSet, getAttributeSetCount, getDecimalFormat, getDecimalFormat, getDecimalFormatCount, getExcludeResultPrefix, getExcludeResultPrefixCount, getExtensionElementPrefix, getExtensionElementPrefixCount, getHref, getId, getImport, getImportCount, getInclude, getIncludeCount, getKey, getKeyCount, getNamespaceAlias, getNamespaceAliasCount, getNodeName, getNodeType, getNonXslTopLevel, getOutput, getOutputCount, getParam, getPreserveSpace, getPreserveSpaceCount, getStripSpace, getStripSpaceCount, getStylesheet, getStylesheetComposed, getStylesheetParent, getStylesheetRoot, getTemplate, getTemplateCount, getVariable, getVariableOrParam, getVariableOrParam, getVariableOrParamCount, getVersion, getXmlnsXsl, getXSLToken, replaceTemplate, setAttributeSet, setDecimalFormat, setExcludeResultPrefixes, setExtensionElementPrefixes, setHref, setId, setImport, setInclude, setKey, setLocaterInfo, setNamespaceAlias, setNonXslTopLevel, setOutput, setParam, setPreserveSpaces, setStripSpaces, setStylesheetParent, setStylesheetRoot, setTemplate, setVariable, setVersion, setXmlnsXsl
 
Methods inherited from class org.apache.xalan.templates.ElemTemplateElement
appendChild, compareTo, compose, error, execute, getBaseIdentifier, getChildNodes, getColumnNumber, getDeclaredPrefixes, getDOMBackPointer, getFirstChild, getFirstChildElem, getLastChild, getLength, getLineNumber, getNamespaceForPrefix, getNamespaceForPrefix, getNextSibling, getNextSiblingElem, getOwnerDocument, getParentElem, getParentNode, getPrefixes, getPreviousSibling, getPublicId, getSystemId, getTagName, getUid, getXmlSpace, hasChildNodes, isCompiledTemplate, item, recompose, removeChild, replaceChild, resolvePrefixTables, runtimeInit, setDOMBackPointer, setPrefixes, setPrefixes, setUid, setXmlSpace
 
Methods inherited from class org.apache.xml.utils.UnImplNode
appendData, cloneNode, createAttribute, createAttributeNS, createCDATASection, createComment, createDocumentFragment, createElement, createElementNS, createEntityReference, createProcessingInstruction, createTextNode, deleteData, error, getAttribute, getAttributeNode, getAttributeNodeNS, getAttributeNS, getAttributes, getDoctype, getDocumentElement, getElementById, getElementsByTagName, getElementsByTagNameNS, getImplementation, getLocalName, getNamespaceURI, getNodeValue, getOwnerElement, getPrefix, getSpecified, hasAttribute, hasAttributeNS, hasAttributes, importNode, insertBefore, insertData, isSupported, normalize, removeAttribute, removeAttributeNode, removeAttributeNS, removeChild, replaceData, setAttribute, setAttributeNode, setAttributeNodeNS, setAttributeNS, setData, setNodeValue, setPrefix, setValue, splitText, substringData
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

StylesheetRoot

public StylesheetRoot(ErrorListener errorListener)
               throws TransformerConfigurationException
Uses an XSL stylesheet document.
Throws:
TransformerConfigurationException - if the baseIdentifier can not be resolved to a URL.

StylesheetRoot

public StylesheetRoot(XSLTSchema schema,
                      ErrorListener listener)
               throws TransformerConfigurationException
Creates a StylesheetRoot and retains a pointer to the schema used to create this StylesheetRoot. The schema may be needed later for an element-available() function call.
Parameters:
schema - The schema used to create this stylesheet
Throws:
TransformerConfigurationException - if the baseIdentifier can not be resolved to a URL.
Method Detail

isRoot

public boolean isRoot()
Tell if this is the root of the stylesheet tree.
Returns:
True since this is the root of the stylesheet tree.
Overrides:
isRoot in class Stylesheet

getAvailableElements

public java.util.Hashtable getAvailableElements()
Get the hashtable of available elements.
Returns:
table of available elements, keyed by qualified names, and with values of the same qualified names.

newTransformer

public Transformer newTransformer()
Create a new transformation context for this Templates object.
Specified by:
newTransformer in interface Templates
Returns:
A Transformer instance, never null.

getDefaultOutputProps

public java.util.Properties getDefaultOutputProps()

getOutputProperties

public java.util.Properties getOutputProperties()
Get the static properties for xsl:output. The object returned will be a clone of the internal values, and thus it can be mutated without mutating the Templates object, and then handed in to the process method.

For XSLT, Attribute Value Templates attribute values will be returned unexpanded (since there is no context at this point).

Specified by:
getOutputProperties in interface Templates
Returns:
A Properties object, not null.

recompose

public void recompose()
               throws TransformerException
Recompose the values of all "composed" properties, meaning properties that need to be combined or calculated from the combination of imported and included stylesheets. This method determines the proper import precedence of all imported stylesheets. It then iterates through all of the elements and properties in the proper order and triggers the individual recompose methods.
Throws:
TransformerException -  

getGlobalImport

public StylesheetComposed getGlobalImport(int i)
Get a stylesheet from the global import list. TODO: JKESS PROPOSES SPECIAL-CASE FOR NO IMPORT LIST, TO MATCH COUNT.
Parameters:
i - Index of stylesheet to get from global import list
Returns:
The stylesheet at the given index

getGlobalImportCount

public int getGlobalImportCount()
Get the total number of imports in the global import list.
Returns:
The total number of imported stylesheets, including the root stylesheet, thus the number will always be 1 or greater. TODO: JKESS PROPOSES SPECIAL-CASE FOR NO IMPORT LIST, TO MATCH DESCRIPTION.

getImportNumber

public int getImportNumber(StylesheetComposed sheet)
Given a stylesheet, return the number of the stylesheet in the global import list.
Parameters:
sheet - The stylesheet which will be located in the global import list.
Returns:
The index into the global import list of the given stylesheet, or -1 if it is not found (which should never happen).

getOutputComposed

public OutputProperties getOutputComposed()
Get the combined "xsl:output" property with the properties combined from the included stylesheets. If a xsl:output is not declared in this stylesheet or an included stylesheet, look in the imports. Please note that this returns a reference to the OutputProperties object, not a cloned object, like getOutputProperties does.
Returns:
non-null reference to composed output properties object.
See Also:
output in XSLT Specification

isOutputMethodSet

public boolean isOutputMethodSet()
**For internal use only** Find out if an output method has been set by the user.
Returns:
Value indicating whether an output method has been set by the user

getAttributeSetComposed

public java.util.Vector getAttributeSetComposed(QName name)
                                         throws java.lang.ArrayIndexOutOfBoundsException
Get a list "xsl:attribute-set" properties that match the qname.
Parameters:
name - Qualified name of attribute set properties to get
Returns:
A vector of attribute sets matching the given name
Throws:
java.lang.ArrayIndexOutOfBoundsException -  
See Also:
attribute-sets in XSLT Specification

getDecimalFormatComposed

public java.text.DecimalFormatSymbols getDecimalFormatComposed(QName name)
Given a valid element decimal-format name, return the decimalFormatSymbols with that name.

It is an error to declare either the default decimal-format or a decimal-format with a given name more than once (even with different import precedence), unless it is declared every time with the same value for all attributes (taking into account any default values).

Which means, as far as I can tell, the decimal-format properties are not additive.

Parameters:
name - Qualified name of the decimal format to find
Returns:
DecimalFormatSymbols object matching the given name or null if name is not found.

getKeysComposed

public java.util.Vector getKeysComposed()
Get the composed "xsl:key" properties.
Returns:
A vector of the composed "xsl:key" properties.
See Also:
key in XSLT Specification

getNamespaceAliasComposed

public NamespaceAlias getNamespaceAliasComposed(java.lang.String uri)
Get the "xsl:namespace-alias" property. Return the NamespaceAlias for a given namespace uri.
Parameters:
uri - non-null reference to namespace that is to be aliased.
Returns:
NamespaceAlias that matches uri, or null if no match.
See Also:
literal-result-element in XSLT Specification

getTemplateListComposed

public final TemplateList getTemplateListComposed()
Accessor method to retrieve the TemplateList associated with this StylesheetRoot.
Returns:
The composed TemplateList.

setTemplateListComposed

public final void setTemplateListComposed(TemplateList templateList)
Mutator method to set the TemplateList associated with this StylesheetRoot. This method should only be used by the compiler. Normally, the template list is built during the recompose process and should not be altered by the user.
Parameters:
templateList - The new TemplateList for this StylesheetRoot.

getTemplateComposed

public ElemTemplate getTemplateComposed(XPathContext xctxt,
                                        Node targetNode,
                                        QName mode,
                                        int maxImportLevel,
                                        boolean quietConflictWarnings)
                                 throws TransformerException
Get an "xsl:template" property by node match. This looks in the imports as well as this stylesheet.
Parameters:
xctxt - non-null reference to XPath runtime execution context.
targetNode - non-null reference of node that the template must match.
mode - qualified name of the node, or null.
maxImportLevel - The maximum importCountComposed that we should consider or -1 if we should consider all import levels. This is used by apply-imports to access templates that have been overridden.
quietConflictWarnings - true if conflict warnings should not be reported.
Returns:
reference to ElemTemplate that is the best match for targetNode, or null if no match could be made.
Throws:
TransformerException -  
See Also:
section-Defining-Template-Rules in XSLT Specification

getTemplateComposed

public ElemTemplate getTemplateComposed(QName qname)
Get an "xsl:template" property. This looks in the imports as well as this stylesheet.
Parameters:
qname - non-null reference to qualified name of template.
Returns:
reference to named template, or null if not found.
See Also:
section-Defining-Template-Rules in XSLT Specification

getVariableOrParamComposed

public ElemVariable getVariableOrParamComposed(QName qname)
Get an "xsl:variable" property.
Parameters:
qname - Qualified name of variable or param
Returns:
The ElemVariable with the given qualified name
See Also:
top-level-variables in XSLT Specification

getVariablesAndParamsComposed

public java.util.Vector getVariablesAndParamsComposed()
Get all global "xsl:variable" properties in scope for this stylesheet.
Returns:
Vector of all variables and params in scope
See Also:
top-level-variables in XSLT Specification

shouldCheckWhitespace

public boolean shouldCheckWhitespace()
Check to see if the caller should bother with check for whitespace nodes.
Returns:
Whether the caller should bother with check for whitespace nodes.

getWhiteSpaceInfo

public WhiteSpaceInfo getWhiteSpaceInfo(XPathContext support,
                                        Element targetElement)
                                 throws TransformerException
Get information about whether or not an element should strip whitespace.
Parameters:
support - The XPath runtime state.
targetElement - Element to check
Returns:
WhiteSpaceInfo for the given element
Throws:
TransformerException -  
See Also:
strip in XSLT Specification

shouldStripWhiteSpace

public boolean shouldStripWhiteSpace(XPathContext support,
                                     Element targetElement)
                              throws TransformerException
Get information about whether or not an element should strip whitespace.
Parameters:
support - The XPath runtime state.
targetElement - Element to check
Returns:
true if the whitespace should be stripped.
Throws:
TransformerException -  
Overrides:
shouldStripWhiteSpace in class ElemTemplateElement
See Also:
strip in XSLT Specification

canStripWhiteSpace

public boolean canStripWhiteSpace()
Get information about whether or not whitespace can be stripped.
Returns:
true if the whitespace can be stripped.
Overrides:
canStripWhiteSpace in class ElemTemplateElement
See Also:
strip in XSLT Specification

getDefaultTextRule

public final ElemTemplate getDefaultTextRule()
**For advanced use only** Get the default template for text.
Returns:
the default template for text.

getDefaultRule

public final ElemTemplate getDefaultRule()
**For advanced use only** Get the default template for elements.
Returns:
the default template for elements.

getDefaultRootRule

public final ElemTemplate getDefaultRootRule()
**For advanced use only** Get the default template for a root node.
Returns:
The default template for a root node.


Copyright � 2000 Apache XML Project. All Rights Reserved.