- /*
- * 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());
- }
- }