org.apache.xalan.xsltc.trax

Class TransformerFactoryImpl

public class TransformerFactoryImpl extends SAXTransformerFactory implements SourceLoader, ErrorListener

Implementation of a JAXP1.1 TransformerFactory for Translets.

Author: G. Todd Miller Morten Jorgensen Santiago Pericas-Geertsen

Field Summary
static StringAUTO_TRANSLET
static StringDEBUG
static StringDESTINATION_DIRECTORY
static StringENABLE_INLINING
static StringGENERATE_TRANSLET
static StringINDENT_NUMBER
static StringJAR_NAME
static StringPACKAGE_NAME
static StringTRANSLET_NAME
static StringUSE_CLASSPATH
Constructor Summary
TransformerFactoryImpl()
javax.xml.transform.sax.TransformerFactory implementation.
Method Summary
voiderror(TransformerException e)
Receive notification of a recoverable error.
voidfatalError(TransformerException e)
Receive notification of a non-recoverable error.
SourcegetAssociatedStylesheet(Source source, String media, String title, String charset)
javax.xml.transform.sax.TransformerFactory implementation.
ObjectgetAttribute(String name)
javax.xml.transform.sax.TransformerFactory implementation.
ErrorListenergetErrorListener()
javax.xml.transform.sax.TransformerFactory implementation.
booleangetFeature(String name)
javax.xml.transform.sax.TransformerFactory implementation.
URIResolvergetURIResolver()
javax.xml.transform.sax.TransformerFactory implementation.
InputSourceloadSource(String href, String context, XSLTC xsltc)
This method implements XSLTC's SourceLoader interface.
TemplatesnewTemplates(Source source)
javax.xml.transform.sax.TransformerFactory implementation.
TemplatesHandlernewTemplatesHandler()
javax.xml.transform.sax.SAXTransformerFactory implementation.
TransformernewTransformer()
javax.xml.transform.sax.TransformerFactory implementation.
TransformernewTransformer(Source source)
javax.xml.transform.sax.TransformerFactory implementation.
TransformerHandlernewTransformerHandler()
javax.xml.transform.sax.SAXTransformerFactory implementation.
TransformerHandlernewTransformerHandler(Source src)
javax.xml.transform.sax.SAXTransformerFactory implementation.
TransformerHandlernewTransformerHandler(Templates templates)
javax.xml.transform.sax.SAXTransformerFactory implementation.
XMLFilternewXMLFilter(Source src)
javax.xml.transform.sax.SAXTransformerFactory implementation.
XMLFilternewXMLFilter(Templates templates)
javax.xml.transform.sax.SAXTransformerFactory implementation.
voidsetAttribute(String name, Object value)
javax.xml.transform.sax.TransformerFactory implementation.
voidsetErrorListener(ErrorListener listener)
javax.xml.transform.sax.TransformerFactory implementation.
voidsetFeature(String name, boolean value)

Set a feature for this TransformerFactory and Transformers or Templates created by this factory.

Feature names are fully qualified {@link java.net.URI}s.

voidsetURIResolver(URIResolver resolver)
javax.xml.transform.sax.TransformerFactory implementation.
voidwarning(TransformerException e)
Receive notification of a warning.

Field Detail

AUTO_TRANSLET

public static final String AUTO_TRANSLET

DEBUG

public static final String DEBUG

DESTINATION_DIRECTORY

public static final String DESTINATION_DIRECTORY

ENABLE_INLINING

public static final String ENABLE_INLINING

GENERATE_TRANSLET

public static final String GENERATE_TRANSLET

INDENT_NUMBER

public static final String INDENT_NUMBER

JAR_NAME

public static final String JAR_NAME

PACKAGE_NAME

public static final String PACKAGE_NAME

TRANSLET_NAME

public static final String TRANSLET_NAME

USE_CLASSPATH

public static final String USE_CLASSPATH

Constructor Detail

TransformerFactoryImpl

public TransformerFactoryImpl()
javax.xml.transform.sax.TransformerFactory implementation.

Method Detail

error

public void error(TransformerException e)
Receive notification of a recoverable error. The transformer must continue to provide normal parsing events after invoking this method. It should still be possible for the application to process the document through to the end.

Parameters: e The warning information encapsulated in a transformer exception.

Throws: TransformerException if the application chooses to discontinue the transformation (always does in our case).

fatalError

public void fatalError(TransformerException e)
Receive notification of a non-recoverable error. The application must assume that the transformation cannot continue after the Transformer has invoked this method, and should continue (if at all) only to collect addition error messages. In fact, Transformers are free to stop reporting events once this method has been invoked.

Parameters: e warning information encapsulated in a transformer exception.

Throws: TransformerException if the application chooses to discontinue the transformation (always does in our case).

getAssociatedStylesheet

public Source getAssociatedStylesheet(Source source, String media, String title, String charset)
javax.xml.transform.sax.TransformerFactory implementation. Get the stylesheet specification(s) associated via the xml-stylesheet processing instruction (see http://www.w3.org/TR/xml-stylesheet/) with the document document specified in the source parameter, and that match the given criteria.

Parameters: source The XML source document. media The media attribute to be matched. May be null, in which case the prefered templates will be used (i.e. alternate = no). title The value of the title attribute to match. May be null. charset The value of the charset attribute to match. May be null.

Returns: A Source object suitable for passing to the TransformerFactory.

Throws: TransformerConfigurationException

getAttribute

public Object getAttribute(String name)
javax.xml.transform.sax.TransformerFactory implementation. Returns the value set for a TransformerFactory attribute

Parameters: name The attribute name

Returns: An object representing the attribute value

Throws: IllegalArgumentException

getErrorListener

public ErrorListener getErrorListener()
javax.xml.transform.sax.TransformerFactory implementation. Get the error event handler for the TransformerFactory.

Returns: The error listener used with the TransformerFactory

getFeature

public boolean getFeature(String name)
javax.xml.transform.sax.TransformerFactory implementation. Look up the value of a feature (to see if it is supported). This method must be updated as the various methods and features of this class are implemented.

Parameters: name The feature name

Returns: 'true' if feature is supported, 'false' if not

getURIResolver

public URIResolver getURIResolver()
javax.xml.transform.sax.TransformerFactory implementation. Get the object that is used by default during the transformation to resolve URIs used in document(), xsl:import, or xsl:include.

Returns: The URLResolver used for this TransformerFactory and all Templates and Transformer objects created using this factory

loadSource

public InputSource loadSource(String href, String context, XSLTC xsltc)
This method implements XSLTC's SourceLoader interface. It is used to glue a TrAX URIResolver to the XSLTC compiler's Input and Import classes.

Parameters: href The URI of the document to load context The URI of the currently loaded document xsltc The compiler that resuests the document

Returns: An InputSource with the loaded document

newTemplates

public Templates newTemplates(Source source)
javax.xml.transform.sax.TransformerFactory implementation. Process the Source into a Templates object, which is a a compiled representation of the source.

Parameters: source The input stylesheet - DOMSource not supported!!!

Returns: A Templates object that can be used to create Transformers.

Throws: TransformerConfigurationException

newTemplatesHandler

public TemplatesHandler newTemplatesHandler()
javax.xml.transform.sax.SAXTransformerFactory implementation. Get a TemplatesHandler object that can process SAX ContentHandler events into a Templates object.

Returns: A TemplatesHandler object that can handle SAX events

Throws: TransformerConfigurationException

newTransformer

public Transformer newTransformer()
javax.xml.transform.sax.TransformerFactory implementation. Create a Transformer object that copies the input document to the result.

Returns: A Transformer object that simply copies the source to the result.

Throws: TransformerConfigurationException

newTransformer

public Transformer newTransformer(Source source)
javax.xml.transform.sax.TransformerFactory implementation. Process the Source into a Templates object, which is a a compiled representation of the source. Note that this method should not be used with XSLTC, as the time-consuming compilation is done for each and every transformation.

Returns: A Templates object that can be used to create Transformers.

Throws: TransformerConfigurationException

newTransformerHandler

public TransformerHandler newTransformerHandler()
javax.xml.transform.sax.SAXTransformerFactory implementation. Get a TransformerHandler object that can process SAX ContentHandler events into a Result. This method will return a pure copy transformer.

Returns: A TransformerHandler object that can handle SAX events

Throws: TransformerConfigurationException

newTransformerHandler

public TransformerHandler newTransformerHandler(Source src)
javax.xml.transform.sax.SAXTransformerFactory implementation. Get a TransformerHandler object that can process SAX ContentHandler events into a Result, based on the transformation instructions specified by the argument.

Parameters: src The source of the transformation instructions.

Returns: A TransformerHandler object that can handle SAX events

Throws: TransformerConfigurationException

newTransformerHandler

public TransformerHandler newTransformerHandler(Templates templates)
javax.xml.transform.sax.SAXTransformerFactory implementation. Get a TransformerHandler object that can process SAX ContentHandler events into a Result, based on the transformation instructions specified by the argument.

Parameters: templates Represents a pre-processed stylesheet

Returns: A TransformerHandler object that can handle SAX events

Throws: TransformerConfigurationException

newXMLFilter

public XMLFilter newXMLFilter(Source src)
javax.xml.transform.sax.SAXTransformerFactory implementation. Create an XMLFilter that uses the given source as the transformation instructions.

Parameters: src The source of the transformation instructions.

Returns: An XMLFilter object, or null if this feature is not supported.

Throws: TransformerConfigurationException

newXMLFilter

public XMLFilter newXMLFilter(Templates templates)
javax.xml.transform.sax.SAXTransformerFactory implementation. Create an XMLFilter that uses the given source as the transformation instructions.

Parameters: templates The source of the transformation instructions.

Returns: An XMLFilter object, or null if this feature is not supported.

Throws: TransformerConfigurationException

setAttribute

public void setAttribute(String name, Object value)
javax.xml.transform.sax.TransformerFactory implementation. Sets the value for a TransformerFactory attribute.

Parameters: name The attribute name value An object representing the attribute value

Throws: IllegalArgumentException

setErrorListener

public void setErrorListener(ErrorListener listener)
javax.xml.transform.sax.TransformerFactory implementation. Set the error event listener for the TransformerFactory, which is used for the processing of transformation instructions, and not for the transformation itself.

Parameters: listener The error listener to use with the TransformerFactory

Throws: IllegalArgumentException

setFeature

public void setFeature(String name, boolean value)

Set a feature for this TransformerFactory and Transformers or Templates created by this factory.

Feature names are fully qualified {@link java.net.URI}s. Implementations may define their own features. An {@link TransformerConfigurationException} is thrown if this TransformerFactory or the Transformers or Templates it creates cannot support the feature. It is possible for an TransformerFactory to expose a feature value but be unable to change its state.

See {@link javax.xml.transform.TransformerFactory} for full documentation of specific features.

Parameters: name Feature name. value Is feature state true or false.

Throws: TransformerConfigurationException if this TransformerFactory or the Transformers or Templates it creates cannot support this feature. NullPointerException If the name parameter is null.

setURIResolver

public void setURIResolver(URIResolver resolver)
javax.xml.transform.sax.TransformerFactory implementation. Set the object that is used by default during the transformation to resolve URIs used in document(), xsl:import, or xsl:include. Note that this does not affect Templates and Transformers that are already created with this factory.

Parameters: resolver The URLResolver used for this TransformerFactory and all Templates and Transformer objects created using this factory

warning

public void warning(TransformerException e)
Receive notification of a warning. Transformers can use this method to report conditions that are not errors or fatal errors. The default behaviour is to take no action. After invoking this method, the Transformer must continue with the transformation. It should still be possible for the application to process the document through to the end.

Parameters: e The warning information encapsulated in a transformer exception.

Throws: TransformerException if the application chooses to discontinue the transformation (never does in our case).

Copyright B) 2005 Apache XML Project. All Rights Reserved.