diff options
Diffstat (limited to 'src/share/classes/com/sun/org/apache/xml/internal/dtm/DTMManager.java')
-rw-r--r-- | src/share/classes/com/sun/org/apache/xml/internal/dtm/DTMManager.java | 432 |
1 files changed, 432 insertions, 0 deletions
diff --git a/src/share/classes/com/sun/org/apache/xml/internal/dtm/DTMManager.java b/src/share/classes/com/sun/org/apache/xml/internal/dtm/DTMManager.java new file mode 100644 index 0000000..84908f5 --- /dev/null +++ b/src/share/classes/com/sun/org/apache/xml/internal/dtm/DTMManager.java @@ -0,0 +1,432 @@ +/* + * reserved comment block + * DO NOT REMOVE OR ALTER! + */ +/* + * Copyright 1999-2004 The Apache Software Foundation. + * + * Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +/* + * $Id: DTMManager.java,v 1.2.4.1 2005/09/15 08:14:54 suresh_emailid Exp $ + */ +package com.sun.org.apache.xml.internal.dtm; + +import com.sun.org.apache.xml.internal.res.XMLErrorResources; +import com.sun.org.apache.xml.internal.res.XMLMessages; +import com.sun.org.apache.xml.internal.utils.PrefixResolver; +import com.sun.org.apache.xml.internal.utils.XMLStringFactory; + +/** + * A DTMManager instance can be used to create DTM and + * DTMIterator objects, and manage the DTM objects in the system. + * + * <p>The system property that determines which Factory implementation + * to create is named "com.sun.org.apache.xml.internal.utils.DTMFactory". This + * property names a concrete subclass of the DTMFactory abstract + * class. If the property is not defined, a platform default is be used.</p> + * + * <p>An instance of this class <emph>must</emph> be safe to use across + * thread instances. It is expected that a client will create a single instance + * of a DTMManager to use across multiple threads. This will allow sharing + * of DTMs across multiple processes.</p> + * + * <p>Note: this class is incomplete right now. It will be pretty much + * modeled after javax.xml.transform.TransformerFactory in terms of its + * factory support.</p> + * + * <p>State: In progress!!</p> + */ +public abstract class DTMManager +{ + + /** The default property name to load the manager. */ + private static final String defaultPropName = + "com.sun.org.apache.xml.internal.dtm.DTMManager"; + + /** The default class name to use as the manager. */ + private static String defaultClassName = + "com.sun.org.apache.xml.internal.dtm.ref.DTMManagerDefault"; + + /** + * Factory for creating XMLString objects. + * %TBD% Make this set by the caller. + */ + protected XMLStringFactory m_xsf = null; + + /** + * Default constructor is protected on purpose. + */ + protected DTMManager(){} + + /** + * Get the XMLStringFactory used for the DTMs. + * + * + * @return a valid XMLStringFactory object, or null if it hasn't been set yet. + */ + public XMLStringFactory getXMLStringFactory() + { + return m_xsf; + } + + /** + * Set the XMLStringFactory used for the DTMs. + * + * + * @param xsf a valid XMLStringFactory object, should not be null. + */ + public void setXMLStringFactory(XMLStringFactory xsf) + { + m_xsf = xsf; + } + + /** + * Obtain a new instance of a <code>DTMManager</code>. + * This static method creates a new factory instance + * This method uses the following ordered lookup procedure to determine + * the <code>DTMManager</code> implementation class to + * load: + * <ul> + * <li> + * Use the <code>com.sun.org.apache.xml.internal.dtm.DTMManager</code> system + * property. + * </li> + * <li> + * Use the JAVA_HOME(the parent directory where jdk is + * installed)/lib/xalan.properties for a property file that contains the + * name of the implementation class keyed on the same value as the + * system property defined above. + * </li> + * <li> + * Use the Services API (as detailed in the JAR specification), if + * available, to determine the classname. The Services API will look + * for a classname in the file + * <code>META-INF/services/com.sun.org.apache.xml.internal.dtm.DTMManager</code> + * in jars available to the runtime. + * </li> + * <li> + * Use the default <code>DTMManager</code> classname, which is + * <code>com.sun.org.apache.xml.internal.dtm.ref.DTMManagerDefault</code>. + * </li> + * </ul> + * + * Once an application has obtained a reference to a <code> + * DTMManager</code> it can use the factory to configure + * and obtain parser instances. + * + * @return new DTMManager instance, never null. + * + * @throws DTMConfigurationException + * if the implementation is not available or cannot be instantiated. + */ + public static DTMManager newInstance(XMLStringFactory xsf) + throws DTMConfigurationException + { + DTMManager factoryImpl = null; + try + { + factoryImpl = (DTMManager) ObjectFactory + .createObject(defaultPropName, defaultClassName); + } + catch (ObjectFactory.ConfigurationError e) + { + throw new DTMConfigurationException(XMLMessages.createXMLMessage( + XMLErrorResources.ER_NO_DEFAULT_IMPL, null), e.getException()); + //"No default implementation found"); + } + + if (factoryImpl == null) + { + throw new DTMConfigurationException(XMLMessages.createXMLMessage( + XMLErrorResources.ER_NO_DEFAULT_IMPL, null)); + //"No default implementation found"); + } + + factoryImpl.setXMLStringFactory(xsf); + + return factoryImpl; + } + + /** + * Get an instance of a DTM, loaded with the content from the + * specified source. If the unique flag is true, a new instance will + * always be returned. Otherwise it is up to the DTMManager to return a + * new instance or an instance that it already created and may be being used + * by someone else. + * + * (More parameters may eventually need to be added for error handling + * and entity resolution, and to better control selection of implementations.) + * + * @param source the specification of the source object, which may be null, + * in which case it is assumed that node construction will take + * by some other means. + * @param unique true if the returned DTM must be unique, probably because it + * is going to be mutated. + * @param whiteSpaceFilter Enables filtering of whitespace nodes, and may + * be null. + * @param incremental true if the DTM should be built incrementally, if + * possible. + * @param doIndexing true if the caller considers it worth it to use + * indexing schemes. + * + * @return a non-null DTM reference. + */ + public abstract DTM getDTM(javax.xml.transform.Source source, + boolean unique, DTMWSFilter whiteSpaceFilter, + boolean incremental, boolean doIndexing); + + /** + * Get the instance of DTM that "owns" a node handle. + * + * @param nodeHandle the nodeHandle. + * + * @return a non-null DTM reference. + */ + public abstract DTM getDTM(int nodeHandle); + + /** + * Given a W3C DOM node, try and return a DTM handle. + * Note: calling this may be non-optimal. + * + * @param node Non-null reference to a DOM node. + * + * @return a valid DTM handle. + */ + public abstract int getDTMHandleFromNode(org.w3c.dom.Node node); + + /** + * Creates a DTM representing an empty <code>DocumentFragment</code> object. + * @return a non-null DTM reference. + */ + public abstract DTM createDocumentFragment(); + + /** + * Release a DTM either to a lru pool, or completely remove reference. + * DTMs without system IDs are always hard deleted. + * State: experimental. + * + * @param dtm The DTM to be released. + * @param shouldHardDelete True if the DTM should be removed no matter what. + * @return true if the DTM was removed, false if it was put back in a lru pool. + */ + public abstract boolean release(DTM dtm, boolean shouldHardDelete); + + /** + * Create a new <code>DTMIterator</code> based on an XPath + * <a href="http://www.w3.org/TR/xpath#NT-LocationPath>LocationPath</a> or + * a <a href="http://www.w3.org/TR/xpath#NT-UnionExpr">UnionExpr</a>. + * + * @param xpathCompiler ??? Somehow we need to pass in a subpart of the + * expression. I hate to do this with strings, since the larger expression + * has already been parsed. + * + * @param pos The position in the expression. + * @return The newly created <code>DTMIterator</code>. + */ + public abstract DTMIterator createDTMIterator(Object xpathCompiler, + int pos); + + /** + * Create a new <code>DTMIterator</code> based on an XPath + * <a href="http://www.w3.org/TR/xpath#NT-LocationPath>LocationPath</a> or + * a <a href="http://www.w3.org/TR/xpath#NT-UnionExpr">UnionExpr</a>. + * + * @param xpathString Must be a valid string expressing a + * <a href="http://www.w3.org/TR/xpath#NT-LocationPath>LocationPath</a> or + * a <a href="http://www.w3.org/TR/xpath#NT-UnionExpr">UnionExpr</a>. + * + * @param presolver An object that can resolve prefixes to namespace URLs. + * + * @return The newly created <code>DTMIterator</code>. + */ + public abstract DTMIterator createDTMIterator(String xpathString, + PrefixResolver presolver); + + /** + * Create a new <code>DTMIterator</code> based only on a whatToShow + * and a DTMFilter. The traversal semantics are defined as the + * descendant access. + * <p> + * Note that DTMIterators may not be an exact match to DOM + * NodeIterators. They are initialized and used in much the same way + * as a NodeIterator, but their response to document mutation is not + * currently defined. + * + * @param whatToShow This flag specifies which node types may appear in + * the logical view of the tree presented by the iterator. See the + * description of <code>NodeFilter</code> for the set of possible + * <code>SHOW_</code> values.These flags can be combined using + * <code>OR</code>. + * @param filter The <code>NodeFilter</code> to be used with this + * <code>DTMFilter</code>, or <code>null</code> to indicate no filter. + * @param entityReferenceExpansion The value of this flag determines + * whether entity reference nodes are expanded. + * + * @return The newly created <code>DTMIterator</code>. + */ + public abstract DTMIterator createDTMIterator(int whatToShow, + DTMFilter filter, boolean entityReferenceExpansion); + + /** + * Create a new <code>DTMIterator</code> that holds exactly one node. + * + * @param node The node handle that the DTMIterator will iterate to. + * + * @return The newly created <code>DTMIterator</code>. + */ + public abstract DTMIterator createDTMIterator(int node); + + /* Flag indicating whether an incremental transform is desired */ + public boolean m_incremental = false; + + /* + * Flag set by FEATURE_SOURCE_LOCATION. + * This feature specifies whether the transformation phase should + * keep track of line and column numbers for the input source + * document. + */ + public boolean m_source_location = false; + + /** + * Get a flag indicating whether an incremental transform is desired + * @return incremental boolean. + * + */ + public boolean getIncremental() + { + return m_incremental; + } + + /** + * Set a flag indicating whether an incremental transform is desired + * This flag should have the same value as the FEATURE_INCREMENTAL feature + * which is set by the TransformerFactory.setAttribut() method before a + * DTMManager is created + * @param incremental boolean to use to set m_incremental. + * + */ + public void setIncremental(boolean incremental) + { + m_incremental = incremental; + } + + /** + * Get a flag indicating whether the transformation phase should + * keep track of line and column numbers for the input source + * document. + * @return source location boolean + * + */ + public boolean getSource_location() + { + return m_source_location; + } + + /** + * Set a flag indicating whether the transformation phase should + * keep track of line and column numbers for the input source + * document. + * This flag should have the same value as the FEATURE_SOURCE_LOCATION feature + * which is set by the TransformerFactory.setAttribut() method before a + * DTMManager is created + * @param sourceLocation boolean to use to set m_source_location + */ + public void setSource_location(boolean sourceLocation){ + m_source_location = sourceLocation; + } + + + // -------------------- private methods -------------------- + + /** + * Temp debug code - this will be removed after we test everything + */ + private static boolean debug; + + static + { + try + { + debug = System.getProperty("dtm.debug") != null; + } + catch (SecurityException ex){} + } + + /** This value, set at compile time, controls how many bits of the + * DTM node identifier numbers are used to identify a node within a + * document, and thus sets the maximum number of nodes per + * document. The remaining bits are used to identify the DTM + * document which contains this node. + * + * If you change IDENT_DTM_NODE_BITS, be sure to rebuild _ALL_ the + * files which use it... including the IDKey testcases. + * + * (FuncGenerateKey currently uses the node identifier directly and + * thus is affected when this changes. The IDKEY results will still be + * _correct_ (presuming no other breakage), but simple equality + * comparison against the previous "golden" files will probably + * complain.) + * */ + public static final int IDENT_DTM_NODE_BITS = 16; + + + /** When this bitmask is ANDed with a DTM node handle number, the result + * is the low bits of the node's index number within that DTM. To obtain + * the high bits, add the DTM ID portion's offset as assigned in the DTM + * Manager. + */ + public static final int IDENT_NODE_DEFAULT = (1<<IDENT_DTM_NODE_BITS)-1; + + + /** When this bitmask is ANDed with a DTM node handle number, the result + * is the DTM's document identity number. + */ + public static final int IDENT_DTM_DEFAULT = ~IDENT_NODE_DEFAULT; + + /** This is the maximum number of DTMs available. The highest DTM is + * one less than this. + */ + public static final int IDENT_MAX_DTMS = (IDENT_DTM_DEFAULT >>> IDENT_DTM_NODE_BITS) + 1; + + + /** + * %TBD% Doc + * + * NEEDSDOC @param dtm + * + * NEEDSDOC ($objectName$) @return + */ + public abstract int getDTMIdentity(DTM dtm); + + /** + * %TBD% Doc + * + * NEEDSDOC ($objectName$) @return + */ + public int getDTMIdentityMask() + { + return IDENT_DTM_DEFAULT; + } + + /** + * %TBD% Doc + * + * NEEDSDOC ($objectName$) @return + */ + public int getNodeIdentityMask() + { + return IDENT_NODE_DEFAULT; + } + +} |