xpointerelementhandler.java

来自「JAVA 所有包」· Java 代码 · 共 760 行 · 第 1/2 页

JAVA
760
字号
/* * The Apache Software License, Version 1.1 * * * Copyright (c) 2001-2003 The Apache Software Foundation.  All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, *    if any, must include the following acknowledgment: *       "This product includes software developed by the *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache", *    nor may "Apache" appear in their name, without prior written *    permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation and was * originally based on software copyright (c) 1999, International * Business Machines, Inc., http://www.apache.org.  For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. */package com.sun.org.apache.xerces.internal.xinclude;import java.util.Enumeration;import java.util.StringTokenizer;import java.util.Stack;import com.sun.org.apache.xerces.internal.impl.Constants;import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter;import com.sun.org.apache.xerces.internal.impl.dtd.DTDGrammar;import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;import com.sun.org.apache.xerces.internal.xni.Augmentations;import com.sun.org.apache.xerces.internal.xni.NamespaceContext;import com.sun.org.apache.xerces.internal.xni.QName;import com.sun.org.apache.xerces.internal.xni.XMLAttributes;import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler;import com.sun.org.apache.xerces.internal.xni.XMLLocator;import com.sun.org.apache.xerces.internal.xni.XMLResourceIdentifier;import com.sun.org.apache.xerces.internal.xni.XMLString;import com.sun.org.apache.xerces.internal.xni.XNIException;import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarDescription;import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool;import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;import com.sun.org.apache.xerces.internal.xni.parser.XMLEntityResolver;import com.sun.org.apache.xerces.internal.impl.dtd.XMLDTDValidator;/** * @author Arun Yadav, Sun Microsystem */public class XPointerElementHandler implements XPointerSchema {            // recognized features and properties        /** Property identifier: error handler. */    protected static final String ERROR_REPORTER =    Constants.XERCES_PROPERTY_PREFIX + Constants.ERROR_REPORTER_PROPERTY;        /** Property identifier: grammar pool . */    protected static final String GRAMMAR_POOL =    Constants.XERCES_PROPERTY_PREFIX + Constants.XMLGRAMMAR_POOL_PROPERTY;        /** Property identifier: grammar pool . */    protected static final String ENTITY_RESOLVER =    Constants.XERCES_PROPERTY_PREFIX + Constants.ENTITY_RESOLVER_PROPERTY;        protected static final String XPOINTER_SCHEMA =    Constants.XERCES_PROPERTY_PREFIX + Constants.XPOINTER_SCHEMA_PROPERTY;        /** Recognized features. */    private static final String[] RECOGNIZED_FEATURES = {    };        /** Feature defaults. */    private static final Boolean[] FEATURE_DEFAULTS = {    };        /** Recognized properties. */        private static final String[] RECOGNIZED_PROPERTIES =    { ERROR_REPORTER, GRAMMAR_POOL, ENTITY_RESOLVER, XPOINTER_SCHEMA };        /** Property defaults. */    private static final Object[] PROPERTY_DEFAULTS = { null, null, null,null };        // Data        protected XMLDocumentHandler fDocumentHandler;    protected XMLDocumentSource fDocumentSource;        protected XIncludeHandler fParentXIncludeHandler;        protected XMLLocator fDocLocation;    protected XIncludeNamespaceSupport fNamespaceContext;    protected XMLErrorReporter fErrorReporter;    protected XMLGrammarPool fGrammarPool;    protected XMLGrammarDescription fGrammarDesc;    protected DTDGrammar fDTDGrammar;    protected XMLEntityResolver fEntityResolver;    protected ParserConfigurationSettings fSettings;    //protected String fPointerSchema;    protected StringBuffer fPointer;    private int elemCount = 0;            // The current element depth.    // This is used to access the appropriate level of the following stacks.    private int fDepth;        // The depth of the first element to actually be part of the result infoset.    // This will normally be 1, but it could be larger when the top-level item    // is an include, and processing goes to the fallback.    private int fRootDepth;        // this value must be at least 1    private static final int INITIAL_SIZE = 8;            // Used to ensure that fallbacks are always children of include elements,    // and that include elements are never children of other include elements.    // An index contains true if the ancestor of the current element which resides    // at that depth was an include element.    private boolean[] fSawInclude = new boolean[INITIAL_SIZE];            // Ensures that only one fallback element can be at a single depth.    // An index contains true if we have seen any fallback elements at that depth,    // and it is only reset to false when the end tag of the parent is encountered.    private boolean[] fSawFallback = new boolean[INITIAL_SIZE];            // The state of the processor at each given depth.    private int[] fState = new int[INITIAL_SIZE];        QName foundElement = null;    boolean skip = false;    // Constructors        public XPointerElementHandler() {                        fDepth = 0;        fRootDepth = 0;        fSawFallback[fDepth] = false;        fSawInclude[fDepth] = false;        fSchemaName="element";                    }        // START OF IMPLEMENTATION OF XMLComponent methods //////        public void reset(){        elemCount =0;        fPointerToken = null;        fCurrentTokenint=0;        fCurrentTokenString=null;        fCurrentTokenType=0 ;        fElementCount =0;        fCurrentToken =0;        includeElement = false;        foundElement = null;        skip = false;        fSubResourceIdentified=false;    }        public void reset(XMLComponentManager componentManager)    throws XNIException {        fNamespaceContext = null;        elemCount =0;        fDepth = 0;        fRootDepth = 0;        fPointerToken = null;        fCurrentTokenint=0;        fCurrentTokenString=null;        fCurrentTokenType=0 ;        foundElement = null;        includeElement = false;        skip = false;        fSubResourceIdentified=false;                                        try {            setErrorReporter(            (XMLErrorReporter)componentManager.getProperty(ERROR_REPORTER));        }        catch (XMLConfigurationException e) {            fErrorReporter = null;        }        try {            fGrammarPool =            (XMLGrammarPool)componentManager.getProperty(GRAMMAR_POOL);        }        catch (XMLConfigurationException e) {            fGrammarPool = null;        }        try {            fEntityResolver =            (XMLEntityResolver)componentManager.getProperty(            ENTITY_RESOLVER);        }        catch (XMLConfigurationException e) {            fEntityResolver = null;        }                fSettings = new ParserConfigurationSettings();                Enumeration xercesFeatures = Constants.getXercesFeatures();        while (xercesFeatures.hasMoreElements()) {            String featureId = (String)xercesFeatures.nextElement();            fSettings.addRecognizedFeatures(new String[] { featureId });            try {                fSettings.setFeature(                featureId,                componentManager.getFeature(featureId));            }            catch (XMLConfigurationException e) {                // componentManager doesn't support this feature,                // so we won't worry about it            }        }/*		try{          dtdValidator =   (XMLDTDValidator)componentManager.getProperty( Constants.XERCES_PROPERTY_PREFIX + Constants.DTD_VALIDATOR_PROPERTY);                }Catch(Exception ex){                        ex.printStackTrace();                }*/            } // reset(XMLComponentManager)        /**     * Returns a list of feature identifiers that are recognized by     * this component. This method may return null if no features     * are recognized by this component.     */    public String[] getRecognizedFeatures() {        return RECOGNIZED_FEATURES;    } // getRecognizedFeatures():String[]        /**     * Sets the state of a feature. This method is called by the component     * manager any time after reset when a feature changes state.     * <p>     * <strong>Note:</strong> Components should silently ignore features     * that do not affect the operation of the component.     *     * @param featureId The feature identifier.     * @param state     The state of the feature.     *     * @throws SAXNotRecognizedException The component should not throw     *                                   this exception.     * @throws SAXNotSupportedException The component should not throw     *                                  this exception.     */    public void setFeature(String featureId, boolean state)    throws XMLConfigurationException {        if (fSettings != null) {            fSettings.setFeature(featureId, state);        }            } // setFeature(String,boolean)        /**     * Returns a list of property identifiers that are recognized by     * this component. This method may return null if no properties     * are recognized by this component.     */    public String[] getRecognizedProperties() {        return RECOGNIZED_PROPERTIES;    } // getRecognizedProperties():String[]        /**     * Sets the value of a property. This method is called by the component     * manager any time after reset when a property changes value.     * <p>     * <strong>Note:</strong> Components should silently ignore properties     * that do not affect the operation of the component.     *     * @param propertyId The property identifier.     * @param value      The value of the property.     *     * @throws SAXNotRecognizedException The component should not throw     *                                   this exception.     * @throws SAXNotSupportedException The component should not throw     *                                  this exception.     */    public void setProperty(String propertyId, Object value)    throws XMLConfigurationException {        if (propertyId.equals(ERROR_REPORTER)) {            setErrorReporter((XMLErrorReporter)value);        }        if (propertyId.equals(GRAMMAR_POOL)) {            fGrammarPool = (XMLGrammarPool)value;        }        if (propertyId.equals(ENTITY_RESOLVER)) {            fEntityResolver = (XMLEntityResolver)value;        }            } // setProperty(String,Object)        /**     * Returns the default state for a feature, or null if this     * component does not want to report a default value for this     * feature.     *     * @param featureId The feature identifier.     *     * @since Xerces 2.2.0     */    public Boolean getFeatureDefault(String featureId) {        for (int i = 0; i < RECOGNIZED_FEATURES.length; i++) {            if (RECOGNIZED_FEATURES[i].equals(featureId)) {                return FEATURE_DEFAULTS[i];            }        }        return null;    } // getFeatureDefault(String):Boolean        /**     * Returns the default state for a property, or null if this     * component does not want to report a default value for this     * property.     *     * @param propertyId The property identifier.     *     * @since Xerces 2.2.0     */    public Object getPropertyDefault(String propertyId) {        for (int i = 0; i < RECOGNIZED_PROPERTIES.length; i++) {            if (RECOGNIZED_PROPERTIES[i].equals(propertyId)) {                return PROPERTY_DEFAULTS[i];            }        }        return null;    } // getPropertyDefault(String):Object        private void setErrorReporter(XMLErrorReporter reporter) {        fErrorReporter = reporter;        if (fErrorReporter != null) {            fErrorReporter.putMessageFormatter(            XIncludeMessageFormatter.XINCLUDE_DOMAIN,            new XIncludeMessageFormatter());

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?