⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 xmlnamespacebinder.java

📁 java1.6众多例子参考
💻 JAVA
📖 第 1 页 / 共 3 页
字号:
/* * The Apache Software License, Version 1.1 * * * Copyright (c) 2000-2002 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.impl;import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter;import com.sun.org.apache.xerces.internal.util.SymbolTable;import com.sun.org.apache.xerces.internal.util.XMLSymbols;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.parser.XMLComponent;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.XMLDocumentFilter;import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;/** * This class performs namespace binding on the startElement and endElement * method calls and passes all other methods through to the registered * document handler. This class can be configured to only pass the * start and end prefix mappings (start/endPrefixMapping). * <p> * This component requires the following features and properties from the * component manager that uses it: * <ul> *  <li>http://xml.org/sax/features/namespaces</li> *  <li>http://apache.org/xml/properties/internal/symbol-table</li> *  <li>http://apache.org/xml/properties/internal/error-reporter</li> * </ul> *  * @xerces.internal * * @author Andy Clark, IBM * * @version $Id: XMLNamespaceBinder.java,v 1.1.2.1 2005/08/01 03:34:08 jeffsuttor Exp $ */public class XMLNamespaceBinder    implements XMLComponent, XMLDocumentFilter {    //    // Constants    //    // feature identifiers    /** Feature identifier: namespaces. */    protected static final String NAMESPACES =        Constants.SAX_FEATURE_PREFIX + Constants.NAMESPACES_FEATURE;    // property identifiers    /** Property identifier: symbol table. */    protected static final String SYMBOL_TABLE =        Constants.XERCES_PROPERTY_PREFIX + Constants.SYMBOL_TABLE_PROPERTY;    /** Property identifier: error reporter. */    protected static final String ERROR_REPORTER =        Constants.XERCES_PROPERTY_PREFIX + Constants.ERROR_REPORTER_PROPERTY;    // recognized features and properties    /** Recognized features. */    private static final String[] RECOGNIZED_FEATURES = {        NAMESPACES,    };    /** Feature defaults. */    private static final Boolean[] FEATURE_DEFAULTS = {        null,    };    /** Recognized properties. */    private static final String[] RECOGNIZED_PROPERTIES = {        SYMBOL_TABLE,        ERROR_REPORTER,    };    /** Property defaults. */    private static final Object[] PROPERTY_DEFAULTS = {        null,        null,    };    //    // Data    //    // features    /** Namespaces. */    protected boolean fNamespaces;    // properties    /** Symbol table. */    protected SymbolTable fSymbolTable;    /** Error reporter. */    protected XMLErrorReporter fErrorReporter;    // handlers    /** Document handler. */    protected XMLDocumentHandler fDocumentHandler;    protected XMLDocumentSource fDocumentSource;    // settings    /** Only pass start and end prefix mapping events. */    protected boolean fOnlyPassPrefixMappingEvents;    // shared context    /** Namespace context. */    private NamespaceContext fNamespaceContext;    // temp vars    /** Attribute QName. */    private QName fAttributeQName = new QName();    //    // Constructors    //    /** Default constructor. */    public XMLNamespaceBinder() {    } // <init>()    //    // Public methods    //    // settings    /**     * Sets whether the namespace binder only passes the prefix mapping     * events to the registered document handler or passes all document     * events.     *     * @param onlyPassPrefixMappingEvents True to pass only the prefix     *                                    mapping events; false to pass     *                                    all events.     */    public void setOnlyPassPrefixMappingEvents(boolean onlyPassPrefixMappingEvents) {        fOnlyPassPrefixMappingEvents = onlyPassPrefixMappingEvents;    } // setOnlyPassPrefixMappingEvents(boolean)    /**     * Returns true if the namespace binder only passes the prefix mapping     * events to the registered document handler; false if the namespace     * binder passes all document events.     */    public boolean getOnlyPassPrefixMappingEvents() {        return fOnlyPassPrefixMappingEvents;    } // getOnlyPassPrefixMappingEvents():boolean    //    // XMLComponent methods    //    /**     * Resets the component. The component can query the component manager     * about any features and properties that affect the operation of the     * component.     *     * @param componentManager The component manager.     *     * @throws SAXException Thrown by component on initialization error.     *                      For example, if a feature or property is     *                      required for the operation of the component, the     *                      component manager may throw a     *                      SAXNotRecognizedException or a     *                      SAXNotSupportedException.     */    public void reset(XMLComponentManager componentManager)        throws XNIException {        // features        try {            fNamespaces = componentManager.getFeature(NAMESPACES);        }        catch (XMLConfigurationException e) {            fNamespaces = true;        }        // Xerces properties        fSymbolTable = (SymbolTable)componentManager.getProperty(SYMBOL_TABLE);        fErrorReporter = (XMLErrorReporter)componentManager.getProperty(ERROR_REPORTER);    } // 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 (String[])(RECOGNIZED_FEATURES.clone());    } // 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 {    } // 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 (String[])(RECOGNIZED_PROPERTIES.clone());    } // getRecognizedProperties():String[]    /**     * Sets the value of a property during parsing.     *     * @param propertyId     * @param value     */

⌨️ 快捷键说明

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