net.sf.saxon.dom.DocumentBuilderFactoryImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of saxon9 Show documentation
Show all versions of saxon9 Show documentation
Provides a basic XSLT 2.0 and XQuery 1.0 processor (W3C Recommendations,
January 2007). Command line interfaces and implementations of several
Java APIs (DOM, XPath, s9api) are also included.
The newest version!
package net.sf.saxon.dom;
import net.sf.saxon.Configuration;
import net.sf.saxon.FeatureKeys;
import net.sf.saxon.value.Whitespace;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
/**
* Implementation of JAXP 1.1 DocumentBuilderFactory. To build a Document using
* Saxon, set the system property javax.xml.parsers.DocumentBuilderFactory to
* "net.sf.saxon.om.DocumentBuilderFactoryImpl" and then call
* DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(InputSource);
*/
public class DocumentBuilderFactoryImpl extends DocumentBuilderFactory {
Configuration config = null;
boolean xIncludeAware = false;
public DocumentBuilderFactoryImpl() {
setCoalescing(true);
setExpandEntityReferences(true);
setIgnoringComments(false);
setIgnoringElementContentWhitespace(false);
setNamespaceAware(true);
setValidating(false);
}
/**
* Allows the user to set specific attributes on the underlying
* implementation.
* @param name The name of the attribute. For Saxon this must be one of the
* names defined in {@link FeatureKeys}
* @param value The value of the attribute.
* @exception IllegalArgumentException thrown if the underlying
* implementation doesn't recognize the attribute.
*/
public void setAttribute(String name, Object value) {
if (name.equals(FeatureKeys.CONFIGURATION)) {
config = (Configuration)value;
} else {
if (config == null) {
config = new Configuration();
}
config.setConfigurationProperty(name, value);
}
}
/**
* Allows the user to retrieve specific attributes on the underlying
* implementation.
* @param name The name of the attribute. For Saxon this must be one of the
* names defined in {@link FeatureKeys}
* @return value The value of the attribute.
* @exception IllegalArgumentException thrown if the underlying
* implementation doesn't recognize the attribute.
*/
public Object getAttribute(String name) {
if (name.equals(FeatureKeys.CONFIGURATION)) {
return config;
} else {
if (config == null) {
config = new Configuration();
}
return config.getConfigurationProperty(name);
}
}
/**
* Creates a new instance of a {@link javax.xml.parsers.DocumentBuilder}
* using the currently configured parameters.
*
* @exception ParserConfigurationException if a DocumentBuilder
* cannot be created which satisfies the configuration requested.
* @return A new instance of a DocumentBuilder. For Saxon the returned DocumentBuilder
* will be an instance of {@link DocumentBuilderImpl}
*/
public DocumentBuilder newDocumentBuilder() throws ParserConfigurationException {
// Check that configuration options are all available
if (!isExpandEntityReferences()) {
throw new ParserConfigurationException(
"Saxon parser always expands entity references");
}
if (isIgnoringComments()) {
throw new ParserConfigurationException(
"Saxon parser does not allow comments to be ignored");
}
if (isIgnoringElementContentWhitespace()) {
throw new ParserConfigurationException(
"Saxon parser does not allow whitespace in element content to be ignored");
}
if (!isNamespaceAware()) {
throw new ParserConfigurationException(
"Saxon parser is always namespace aware");
}
DocumentBuilderImpl builder = new DocumentBuilderImpl();
builder.setValidating(isValidating());
builder.setXIncludeAware(xIncludeAware);
if (isIgnoringElementContentWhitespace()) {
builder.setStripSpace(Whitespace.IGNORABLE);
}
builder.setConfiguration(config);
return builder;
}
/**
* Set a feature for this DocumentBuilderFactory
and DocumentBuilder
s created by this factory.
*
*
* Feature names are fully qualified {@link java.net.URI}s.
* Implementations may define their own features.
* An {@link javax.xml.parsers.ParserConfigurationException} is thrown if this DocumentBuilderFactory
or the
* DocumentBuilder
s it creates cannot support the feature.
* It is possible for an DocumentBuilderFactory
to expose a feature value but be unable to change its state.
*
*
*
* All implementations are required to support the {@link javax.xml.XMLConstants#FEATURE_SECURE_PROCESSING} feature.
* When the feature is:
*
* -
*
true
: the implementation will limit XML processing to conform to implementation limits.
* Examples include entity expansion limits and XML Schema constructs that would consume large amounts of resources.
* If XML processing is limited for security reasons, it will be reported via a call to the registered
* {@link org.xml.sax.ErrorHandler#fatalError(org.xml.sax.SAXParseException exception)}.
* See {@link javax.xml.parsers.DocumentBuilder#setErrorHandler(org.xml.sax.ErrorHandler errorHandler)}.
*
* -
*
false
: the implementation will processing XML according to the XML specifications without
* regard to possible implementation limits.
*
*
*
* @param name Feature name.
* @param value Is feature state true
or false
.
* @throws javax.xml.parsers.ParserConfigurationException
* if this DocumentBuilderFactory
or the DocumentBuilder
s
* it creates cannot support this feature.
* @throws NullPointerException If the name
parameter is null.
*/
public void setFeature(String name, boolean value) throws ParserConfigurationException {
if (name.equals(FEATURE_SECURE_PROCESSING) && !value) {
// no action
} else {
throw new ParserConfigurationException("Unsupported feature or value: " + name);
}
}
/**
* Get the state of the named feature.
*
*
* Feature names are fully qualified {@link java.net.URI}s.
* Implementations may define their own features.
* An {@link javax.xml.parsers.ParserConfigurationException} is thrown if this DocumentBuilderFactory
or the
* DocumentBuilder
s it creates cannot support the feature.
* It is possible for an DocumentBuilderFactory
to expose a feature value but be unable to change its state.
*
*
* @param name Feature name.
* @return State of the named feature.
* @throws javax.xml.parsers.ParserConfigurationException
* if this DocumentBuilderFactory
* or the DocumentBuilder
s it creates cannot support this feature.
*/
public boolean getFeature(String name) throws ParserConfigurationException {
if (name.equals(FEATURE_SECURE_PROCESSING)) {
return false;
} else {
throw new ParserConfigurationException("Unsupported feature: " + name);
}
}
/**
* Get state of XInclude processing.
*
* @return current state of XInclude processing
* @throws UnsupportedOperationException For backward compatibility, when implementations for
* earlier versions of JAXP is used, this exception will be
* thrown.
* @since 1.5
*/
public boolean isXIncludeAware() {
return xIncludeAware;
}
/**
* Set state of XInclude processing.
*
* If XInclude markup is found in the document instance, should it be
* processed as specified in
* XML Inclusions (XInclude) Version 1.0.
*
* XInclude processing defaults to false
.
*
* @param state Set XInclude processing to true
or
* false
* @throws UnsupportedOperationException For backward compatibility, when implementations for
* earlier versions of JAXP is used, this exception will be
* thrown.
* @since 1.5
*/
public void setXIncludeAware(boolean state) {
xIncludeAware = state;
}
private static String FEATURE_SECURE_PROCESSING = "http://javax.xml.XMLConstants/feature/secure-processing";
// XMLConstants.FEATURE_SECURE_PROCESSING in JDK 1.5
}
//
// The contents of this file are subject to the Mozilla Public License Version 1.0 (the "License");
// you may not use this file except in compliance with the License. You may obtain a copy of the
// License at http://www.mozilla.org/MPL/
//
// Software distributed under the License is distributed on an "AS IS" basis,
// WITHOUT WARRANTY OF ANY KIND, either express or implied.
// See the License for the specific language governing rights and limitations under the License.
//
// The Original Code is: all this file.
//
// The Initial Developer of the Original Code is Michael H. Kay
//
// Portions created by (your name) are Copyright (C) (your legal entity). All Rights Reserved.
//
// Contributor(s): none
//
© 2015 - 2025 Weber Informatics LLC | Privacy Policy