|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object net.sf.saxon.s9api.Processor
public class Processor
The Processor
class serves three purposes: it allows global Saxon configuration options to be set;
it acts as a factory for generating XQuery, XPath, and XSLT compilers; and it owns certain shared
resources such as the Saxon NamePool and compiled schemas. This is the first object that a
Saxon application should create. Once established, a Processor may be used in multiple threads.
It is possible to run more than one Saxon Processor concurrently, but only when running completely independent workloads. Nothing can be shared between Processor instances. Within a query or transformation, all source documents and schemas must be built using the same Processor, which must also be used to compile the query or stylesheet.
Constructor Summary | |
---|---|
Processor(boolean licensedEdition)
Create a Processor |
|
Processor(Configuration config)
Create a Processor based on an existing Configuration. |
|
Processor(Source source)
Create a Processor configured according to the settings in a supplied configuration file. |
Method Summary | |
---|---|
Object |
getConfigurationProperty(String name)
Get the value of a configuration property |
String |
getSaxonProductVersion()
Get the user-visible Saxon product version, for example "9.0.0.1" |
SchemaManager |
getSchemaManager()
Get the associated SchemaManager. |
Configuration |
getUnderlyingConfiguration()
Get the underlying Configuration object that underpins this Processor. |
String |
getXmlVersion()
Get the version of XML used by this Processor. |
boolean |
isSchemaAware()
Test whether this processor is schema-aware |
DocumentBuilder |
newDocumentBuilder()
Create a DocumentBuilder. |
Serializer |
newSerializer()
Create a Serializer |
Serializer |
newSerializer(File file)
Create a Serializer initialized to write to a given File. |
Serializer |
newSerializer(OutputStream stream)
Create a Serializer initialized to write to a given OutputStream. |
Serializer |
newSerializer(Writer writer)
Create a Serializer initialized to write to a given Writer. |
XPathCompiler |
newXPathCompiler()
Create an XPathCompiler. |
XQueryCompiler |
newXQueryCompiler()
Create an XQueryCompiler. |
XsltCompiler |
newXsltCompiler()
Create an XsltCompiler. |
void |
registerExtensionFunction(ExtensionFunctionDefinition function)
Register an extension function that is to be made available within any stylesheet, query, or XPath expression compiled under the control of this processor. |
void |
setConfigurationProperty(String name,
Object value)
Set a configuration property |
void |
setXmlVersion(String version)
Set the version of XML used by this Processor. |
void |
writeXdmValue(XdmValue value,
Destination destination)
Write an XdmValue to a given destination. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public Processor(boolean licensedEdition)
licensedEdition
- indicates whether the Processor requires features of Saxon that need a license
file (that is, features not available in Saxon HE (Home Edition). If true, the method will create
a Configuration appropriate to the version of the software that is running: for example, if running
Saxon-EE, it will create an EnterpriseConfiguration. The method does not at this stage check that a license
is available, and in the absence of a license, it should run successfully provided no features that
require licensing are actually used. If the argument is set to false, a plain Home Edition Configuration
is created unconditionally.public Processor(Configuration config)
config
- the Configuration to be used by this processorpublic Processor(Source source) throws SaxonApiException
source
- the Source of the configuration file
SaxonApiException
- if the configuration file cannot be read, or its contents are invalidMethod Detail |
---|
public DocumentBuilder newDocumentBuilder()
public XPathCompiler newXPathCompiler()
public XsltCompiler newXsltCompiler()
UnsupportedOperationException
- if this version of the Saxon product does not support XSLT processingpublic XQueryCompiler newXQueryCompiler()
UnsupportedOperationException
- if this version of the Saxon product does not support XQuery processingpublic Serializer newSerializer()
public Serializer newSerializer(OutputStream stream)
Closing the output stream after use is the responsibility of the caller.
stream
- The OutputStream to which the Serializer will write
public Serializer newSerializer(Writer writer)
Closing the writer after use is the responsibility of the caller.
writer
- The Writer to which the Serializer will write
public Serializer newSerializer(File file)
file
- The File to which the Serializer will write
public void registerExtensionFunction(ExtensionFunctionDefinition function)
ExtensionFunctionCall
, using an arbitrary name and namespace.
This supplements the ability to call arbitrary Java methods using a namespace and local name
that are related to the Java class and method name.
function
- the class that implements the extension function. This must be a class that extends
ExtensionFunctionCall
, and it must have a public zero-argument
constructor
IllegalArgumentException
- if the class cannot be instantiated or does not extend
ExtensionFunctionCall
public SchemaManager getSchemaManager()
public boolean isSchemaAware()
public String getSaxonProductVersion()
public void setXmlVersion(String version)
Note that source documents specifying xml version="1.0" or "1.1" are accepted regardless of this setting.
version
- must be one of the strings "1.0" or "1.1"
IllegalArgumentException
- if any string other than "1.0" or "1.1" is suppliedpublic String getXmlVersion()
public void setConfigurationProperty(String name, Object value)
name
- the name of the option to be set. The names of the options available are listed
as constants in class FeatureKeys
.value
- the value of the option to be set.
IllegalArgumentException
- if the property name is not recognizedpublic Object getConfigurationProperty(String name)
name
- the name of the option required. The names of the properties available are listed
as constants in class FeatureKeys
.
IllegalArgumentException
- if the property name is not recognizedpublic Configuration getUnderlyingConfiguration()
Configuration
object that underpins this Processor. This method
provides an escape hatch to internal Saxon implementation objects that offer a finer and lower-level
degree of control than the s9api classes and methods. Some of these classes and methods may change
from release to release.
public void writeXdmValue(XdmValue value, Destination destination) throws SaxonApiException
value
- the value to be writtendestination
- the destination to which the value is to be written
SaxonApiException
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |