psvielementnsimpl.java

来自「JAVA的一些源码 JAVA2 STANDARD EDITION DEVELO」· Java 代码 · 共 331 行

JAVA
331
字号
/* * The Apache Software License, Version 1.1 * * * Copyright (c) 2002-2004 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.dom;import java.io.IOException;import java.io.NotSerializableException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import com.sun.org.apache.xerces.internal.xs.ElementPSVI;import com.sun.org.apache.xerces.internal.xs.*;/** * Element namespace implementation; stores PSVI element items. *  * @author Sandy Gao, IBM *  * @version $Id: PSVIElementNSImpl.java,v 1.7 2004/02/05 18:26:31 mrglavas Exp $ */public class PSVIElementNSImpl extends ElementNSImpl implements ElementPSVI {    /** Serialization version. */    static final long serialVersionUID = 6815489624636016068L;        /**     * Construct an element node.     */    public PSVIElementNSImpl(CoreDocumentImpl ownerDocument, String namespaceURI,                              String qualifiedName, String localName) {        super(ownerDocument, namespaceURI, qualifiedName, localName);    }        /**     * Construct an element node.     */    public PSVIElementNSImpl(CoreDocumentImpl ownerDocument, String namespaceURI,                              String qualifiedName) {        super(ownerDocument, namespaceURI, qualifiedName);    }        /** element declaration */    protected XSElementDeclaration fDeclaration = null;    /** type of element, could be xsi:type */    protected XSTypeDefinition fTypeDecl = null;    /** true if clause 3.2 of Element Locally Valid (Element) (3.3.4)       * is satisfied, otherwise false       */    protected boolean fNil = false;    /** false if the element value was provided by the schema; true otherwise.      */    protected boolean fSpecified = true;    /** schema normalized value property */    protected String fNormalizedValue = null;    /** schema actual value */    protected Object fActualValue = null;    /** schema actual value type */    protected short fActualValueType = XSConstants.UNAVAILABLE_DT;    /** actual value types if the value is a list */    protected ShortList fItemValueTypes = null;    /** http://www.w3.org/TR/xmlschema-1/#e-notation*/    protected XSNotationDeclaration fNotation = null;    /** member type definition against which element was validated */    protected XSSimpleTypeDefinition fMemberType = null;    /** validation attempted: none, partial, full */    protected short fValidationAttempted = ElementPSVI.VALIDATION_NONE;    /** validity: valid, invalid, unknown */    protected short fValidity = ElementPSVI.VALIDITY_NOTKNOWN;    /** error codes */    protected StringList fErrorCodes = null;    /** validation context: could be QName or XPath expression*/    protected String fValidationContext = null;    /** the schema information property */    protected XSModel fSchemaInformation = null;        //    // ElementPSVI methods    //    /**     * [schema default]     *     * @return The canonical lexical representation of the declaration's {value constraint} value.     * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-schema_default>XML Schema Part 1: Structures [schema default]</a>     */    public String getSchemaDefault() {        return fDeclaration == null ? null : fDeclaration.getConstraintValue();    }    /**     * [schema normalized value]     *     *     * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-schema_normalized_value>XML Schema Part 1: Structures [schema normalized value]</a>     * @return the normalized value of this item after validation     */    public String getSchemaNormalizedValue() {        return fNormalizedValue;    }    /**     * [schema specified]      * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-schema_specified">XML Schema Part 1: Structures [schema specified]</a>     * @return false value was specified in schema, true value comes from the infoset     */    public boolean getIsSchemaSpecified() {        return fSpecified;    }    /**     * Determines the extent to which the document has been validated     *     * @return return the [validation attempted] property. The possible values are     *         NO_VALIDATION, PARTIAL_VALIDATION and FULL_VALIDATION     */    public short getValidationAttempted() {        return fValidationAttempted;    }    /**     * Determine the validity of the node with respect     * to the validation being attempted     *     * @return return the [validity] property. Possible values are:     *         UNKNOWN_VALIDITY, INVALID_VALIDITY, VALID_VALIDITY     */    public short getValidity() {        return fValidity;    }    /**     * A list of error codes generated from validation attempts.     * Need to find all the possible subclause reports that need reporting     *     * @return Array of error codes     */    public StringList getErrorCodes() {        return fErrorCodes;    }    // This is the only information we can provide in a pipeline.    public String getValidationContext() {        return fValidationContext;    }    /**     * [nil]     * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-nil>XML Schema Part 1: Structures [nil]</a>     * @return true if clause 3.2 of Element Locally Valid (Element) (3.3.4) above is satisfied, otherwise false     */    public boolean getNil() {        return fNil;    }    /**     * [notation]      * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-notation>XML Schema Part 1: Structures [notation]</a>     * @return The notation declaration.      */    public XSNotationDeclaration getNotation() {        return fNotation;    }    /**     * An item isomorphic to the type definition used to validate this element.     *      * @return  a type declaration     */    public XSTypeDefinition getTypeDefinition() {        return fTypeDecl;    }        /**     * If and only if that type definition is a simple type definition     * with {variety} union, or a complex type definition whose {content type}     * is a simple thype definition with {variety} union, then an item isomorphic     * to that member of the union's {member type definitions} which actually     * validated the element item's normalized value.     *      * @return  a simple type declaration     */    public XSSimpleTypeDefinition getMemberTypeDefinition() {        return fMemberType;    }    /**     * An item isomorphic to the element declaration used to validate     * this element.     *      * @return  an element declaration     */    public XSElementDeclaration getElementDeclaration() {        return fDeclaration;    }    /**     * [schema information]     * @see <a href="http://www.w3.org/TR/xmlschema-1/#e-schema_information">XML Schema Part 1: Structures [schema information]</a>     * @return The schema information property if it's the validation root,     *         null otherwise.     */    public XSModel getSchemaInformation() {        return fSchemaInformation;    }        /**     * Copy PSVI properties from another psvi item.     *      * @param attr  the source of attribute PSVI items     */    public void setPSVI(ElementPSVI elem) {        this.fDeclaration = elem.getElementDeclaration();        this.fNotation = elem.getNotation();        this.fValidationContext = elem.getValidationContext();        this.fTypeDecl = elem.getTypeDefinition();        this.fSchemaInformation = elem.getSchemaInformation();        this.fValidity = elem.getValidity();        this.fValidationAttempted = elem.getValidationAttempted();        this.fErrorCodes = elem.getErrorCodes();        this.fNormalizedValue = elem.getSchemaNormalizedValue();        this.fActualValue = elem.getActualNormalizedValue();        this.fActualValueType = elem.getActualNormalizedValueType();        this.fItemValueTypes = elem.getItemValueTypes();        this.fMemberType = elem.getMemberTypeDefinition();        this.fSpecified = elem.getIsSchemaSpecified();    }    /* (non-Javadoc)     * @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValue()     */    public Object getActualNormalizedValue() {        return this.fActualValue;    }    /* (non-Javadoc)     * @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getActualNormalizedValueType()     */    public short getActualNormalizedValueType() {        return this.fActualValueType;    }    /* (non-Javadoc)     * @see com.sun.org.apache.xerces.internal.xs.ItemPSVI#getItemValueTypes()     */    public ShortList getItemValueTypes() {        return this.fItemValueTypes;    }        // REVISIT: Forbid serialization of PSVI DOM until    // we support object serialization of grammars -- mrglavas        private void writeObject(ObjectOutputStream out)        throws IOException {        throw new NotSerializableException(getClass().getName());    }    private void readObject(ObjectInputStream in)         throws IOException, ClassNotFoundException {        throw new NotSerializableException(getClass().getName());    }}

⌨️ 快捷键说明

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