This document is also available in these non-normative formats: XML file, plain text, PostScript file, PDF file, single HTML file, and ZIP file.
Copyright ©2003 W3C® (MIT, ERCIM, Keio), All Rights Reserved. W3C liability, trademark, document use and software licensing rules apply.
This specification defines the Document Object Model Validation Level 3, a platform- and language-neutral interface. This module provides the guidance to programs and scripts to dynamically update the content and the structure of documents while ensuring that the document remains valid, or to ensure that the document becomes valid.
This section describes the status of this document at the time of its publication. Other documents may supersede this document. The latest status of this document series is maintained at the W3C.
This is the Candidate Recommendation specification of "DOM Level 3 Validation". This version is based on the feedback during the Last Call period. The DOM Working Group expects to request that the Director advance this specification to Proposed Recommendation after the DOM Working Group documents two interoperable implementations of at least one normative binding. Basic tests of features of this specification will be produced and used in this effort. The two implementations must be produced by different organizations. The estimated end of the Candidate Recommendation period is 31 August 2003. Comments on this document are invited and are to be sent to the public mailing list www-dom@w3.org, before the end of the review period. An archive is available at http://lists.w3.org/Archives/Public/www-dom/.
Individuals or organizations are also invited to send a message to the public mailing list if they intend to produce an implementation of this module. The implementation report is also available.
This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to use W3C Working Drafts as reference material or to cite them as other than "work in progress". This is work in progress and does not imply endorsement by, or the consensus of, either W3C or participants of the DOM working group.
This document has been produced as part of the W3C DOM Activity. The authors of this document are the DOM Working Group participants.
Patent disclosures relevant to this specification may be found on the Working Group's patent disclosure page.
A list of current W3C Recommendations and other technical documents can be found at http://www.w3.org/TR.
Copyright © 2003 World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved.
This document is published under the W3C® Document Copyright Notice and License. The bindings within this document are published under the W3C® Software Copyright Notice and License. The software license requires "Notice of any changes or modifications to the W3C files, including the date changes were made." Consequently, modified versions of the DOM bindings must document that they do not conform to the W3C standard; in the case of the IDL definitions, the pragma prefix can no longer be 'w3c.org'; in the case of the Java language binding, the package names can no longer be in the 'org.w3c' package.
Note: This section is a copy of the W3C® Document Notice and License and could be found at http://www.w3.org/Consortium/Legal/2002/copyright-documents-20021231.
Copyright © 2003 World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved.
http://www.w3.org/Consortium/Legal/2002/copyright-documents-20021231
Public documents on the W3C site are provided by the copyright holders under the following license. By using and/or copying this document, or the W3C document from which this statement is linked, you (the licensee) agree that you have read, understood, and will comply with the following terms and conditions:
Permission to copy, and distribute the contents of this document, or the W3C document from which this statement is linked, in any medium for any purpose and without fee or royalty is hereby granted, provided that you include the following on ALL copies of the document, or portions thereof, that you use:
When space permits, inclusion of the full text of this NOTICE should be provided. We request that authorship attribution be provided in any software, documents, or other items or products that you create pursuant to the implementation of the contents of this document, or any portion thereof.
No right to create modifications or derivatives of W3C documents is granted pursuant to this license. However, if additional requirements (documented in the Copyright FAQ) are satisfied, the right to create modifications or derivatives is sometimes granted by the W3C to individuals complying with those requirements.
THIS DOCUMENT IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, OR TITLE; THAT THE CONTENTS OF THE DOCUMENT ARE SUITABLE FOR ANY PURPOSE; NOR THAT THE IMPLEMENTATION OF SUCH CONTENTS WILL NOT INFRINGE ANY THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE DOCUMENT OR THE PERFORMANCE OR IMPLEMENTATION OF THE CONTENTS THEREOF.
The name and trademarks of copyright holders may NOT be used in advertising or publicity pertaining to this document or its contents without specific, written prior permission. Title to copyright in this document will at all times remain with copyright holders.
Note: This section is a copy of the W3C® Software Copyright Notice and License and could be found at http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
Copyright © 2003 World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved.
http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
This work (and included software, documentation such as READMEs, or other related items) is being provided by the copyright holders under the following license. By obtaining, using and/or copying this work, you (the licensee) agree that you have read, understood, and will comply with the following terms and conditions.
Permission to copy, modify, and distribute this software and its documentation, with or without modification, for any purpose and without fee or royalty is hereby granted, provided that you include the following on ALL copies of the software and documentation or portions thereof, including modifications:
THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO, WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION.
The name and trademarks of copyright holders may NOT be used in advertising or publicity pertaining to the software without specific, written prior permission. Title to copyright in this software and any associated documentation will at all times remain with copyright holders.
Note: This section is a copy of the W3C® Short Software Notice and could be found at http://www.w3.org/Consortium/Legal/2002/copyright-software-short-notice-20021231
Copyright © 2003 World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved.
Copyright © [$date-of-software] World Wide Web Consortium, (Massachusetts Institute of Technology, European Research Consortium for Informatics and Mathematics, Keio University). All Rights Reserved. This work is distributed under the W3C® Software License [1] in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
[1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
This chapter describes the optional DOM Level 3 Validation feature. This module provides APIs to guide construction and editing of XML documents. Examples of such guided editing are queries of the nature that combine questions like "what does the schema allow me to insert/delete here?" and "if I insert/delete here, will the document still be valid?".
Users may also want to know several levels of details, e.g., all the possible children, those which would be valid given what precedes this point, lists of defined symbols of a given kind, in order to help in editing and creating an XML document. Some of these queries would prompt checks and warn you if you're about to conflict with or overwrite such data.
       Finally, users would like to validate an edited or newly 
       constructed document before serializing it or passing it to other
       users.  To some, they may edit, come up with an invalid document,
       then edit again to result in a valid document.  During this process,
       these APIs can allow the user to check the validity of the document
       or sub-tree on demand; and if needed can also require that the 
       document or sub-tree remain valid during this editing process via
       the DocumentEditVAL.continuousValidityChecking flag.
    
       A DOM application can use the hasFeature(feature,
       version) method of the DOMImplementation
       interface to determine with parameter values
       "Validation" and "3.0", respectively,
       whether or not these interfaces are supported by the
       implementation.  In order to fully support this feature, an
       implementation must also support the "Core" feature
       defined in [DOM Level 2 Core] or newer. The requirements
       for conformance to a DOM Level 3 module is defined in the
       conformance
       section of [DOM Level 3 Core].      
    
This chapter focuses on the editing aspects used in the XML document editing world and usage of such information. The appendix describes in detail all the possible outcomes of the validation operations on the different node types.
This section describes the "VAL-DOC-EDIT" exceptions.
      Some Validation operations may throw an ExceptionVAL as 
      described in their descriptions.
    
exception ExceptionVAL { unsigned short code; }; // ExceptionVALCode const unsigned short NO_SCHEMA_AVAILABLE_ERR = 71;
An integer indicating the type of error generated.
NO_SCHEMA_AVAILABLE_ERRThis section contains "Document Editing" methods as described in the
       DocumentEditVAL, NodeEditVAL, 
       ElementEditVAL, and CharacterDataEditVAL
       interfaces.
    
This interface extends the NodeEditVAL interface with additional methods for document editing.  An object implementing this interface must also implement the Document interface.
interface DocumentEditVAL : NodeEditVAL { attribute boolean continuousValidityChecking; // raises(DOMException, // ExceptionVAL, // DOMException) on setting readonly attribute DOMConfiguration config; NameList getDefinedElements(in DOMString namespaceURI); unsigned short validateDocument(); };
config of type DOMConfiguration, readonlyDOMConfiguration interface.
            continuousValidityChecking of type booleantrue, the implementation may raise certain 
              exceptions, depending on the situation (see the following).  
              This attribute is false by default.
            | 
 | NOT_SUPPORTED_ERR: Raised if the implementation 
                     does not support setting this attribute to
		      | 
| NO_SCHEMA_AVAILABLE_ERR: Raised if this 
                      attribute is set to  | |
| 
 | VALIDATION_ERR: Raised if an operation makes
		      this document not compliant with the 
		       | 
getDefinedElementsnamespaceURI of type 
DOMStringnamespaceURI of namespace.  For DTDs,
		   this is null.| 
 | 
List of all element information item names belonging to the
		 specified namespace or  | 
validateDocumentDOMConfiguration interface, with all errors
               being SEVERITY_ERROR as defined in the 
               DOMError interface.
            
| 
 | A validation state constant. | 
This interface is similar to the [DOM Level 3 Core] Node interface, with methods for guided document editing.
interface NodeEditVAL { // validationType const unsigned short VAL_WF = 1; const unsigned short VAL_NS_WF = 2; const unsigned short VAL_INCOMPLETE = 3; const unsigned short VAL_SCHEMA = 4; // validationState const unsigned short VAL_TRUE = 5; const unsigned short VAL_FALSE = 6; const unsigned short VAL_UNKNOWN = 7; readonly attribute DOMString defaultValue; readonly attribute DOMStringList enumeratedValues; unsigned short canInsertBefore(in Node newChild, in Node refChild); unsigned short canRemoveChild(in Node oldChild); unsigned short canReplaceChild(in Node newChild, in Node oldChild); unsigned short canAppendChild(in Node newChild); unsigned short nodeValidity(in unsigned short valType); };
An integer indicating the validation type.
	       Other specifications can define stricter 
	       validation types/constants by extending 
	       the NodeEditVAL interface.
            
VAL_INCOMPLETEVAL_NS_WF. 
              VAL_NS_WFVAL_SCHEMAVAL_NS_WF.
              VAL_WFAn integer indicating the validation state, or whether the operation can or cannot be done.
VAL_FALSEVAL_TRUEVAL_UNKNOWNdefaultValue of type DOMString, readonlynull if unspecified.  If the schema is an XML Schema,
              this is the canonical lexical representation of the default value.
            enumeratedValues of type DOMStringList, readonlyDOMStringList, as 
	        described in [DOM Level 3 Core], 
                of distinct values for an attribute 
                or an element declaration or null
		if unspecified.  If the schema is an XML Schema, this is a 
		list of strings which are lexical representations corresponding
                to the values in the [value] property of the enumeration 
		component for the type of the attribute or element.  It is
		recommended that the canonical lexical representations of the
		values be used.
            canAppendChildNode.appendChild operation 
	      would make this document not compliant with the VAL_INCOMPLETE 
	      validity type. newChild of type 
NodeNode to be appended.| 
 | A validation state constant. | 
canInsertBeforeNode.insertBefore operation 
	      would make this document not compliant with the VAL_INCOMPLETE
	      validity type. newChild of type 
NodeNode to be inserted.refChild of type 
NodeNode.| 
 | A validation state constant. | 
canRemoveChildNode.removeChild operation 
	      would make this document not compliant with the VAL_INCOMPLETE
	      validity type. oldChild of type 
NodeNode to be removed.| 
 | A validation state constant. | 
canReplaceChildNode.replaceChild operation 
	      would make this document not compliant with the VAL_INCOMPLETE 
	      validity type. newChild of type 
NodeNode.oldChild of type 
NodeNode to be replaced.| 
 | A validation state constant. | 
nodeValidityvalType. This operation 
            doesn't normalize before checking if it is valid.
	    To do so, one would need to explicitly call a normalize
	    method.  The difference between this method and the 
	    DocumentEditVAL.validateDocument() method 
            is that the latter method only checks to 
            determine whether the entire document is valid.
            valType of type 
unsigned short| 
 | A validation state constant. | 
This interface extends the NodeEditVAL interface 
             with additional methods for guided document editing. An
	     object implementing this interface must also implement the
             Element interface.
          
             This interface also has attributes that are a
             NameList of elements or attributes which can
             appear in the specified context.  Some schema languages,
             i.e., XML
             Schema, define wildcards which provide for validation
             of attribute and element information items dependent on
             their namespace names but independent of their local names.
          
To expose wildcards, the NameList returns the
          values that represent the namespace
          constraint:
          
{namespaceURI, name}
             is {null, ##any} if any;
         {namespaceURI, name} 
             is {namespace_a, ##other} if 
             not and a namespace name (namespace_a);
         {namespaceURI, name} 
             is {null, ##other} if
             not and absent;
         {namespaceURI, name} with values
             {a_namespaceURI | null, null} if 
             a set whose members are either namespace
             names or absent.
         interface ElementEditVAL : NodeEditVAL { // ContentTypeVAL const unsigned short VAL_EMPTY_CONTENTTYPE = 1; const unsigned short VAL_ANY_CONTENTTYPE = 2; const unsigned short VAL_MIXED_CONTENTTYPE = 3; const unsigned short VAL_ELEMENTS_CONTENTTYPE = 4; const unsigned short VAL_SIMPLE_CONTENTTYPE = 5; readonly attribute NameList allowedChildren; readonly attribute NameList allowedFirstChildren; readonly attribute NameList allowedParents; readonly attribute NameList allowedNextSiblings; readonly attribute NameList allowedPreviousSiblings; readonly attribute NameList allowedAttributes; readonly attribute NameList requiredAttributes; readonly attribute unsigned short contentType; unsigned short canSetTextContent(in DOMString possibleTextContent); unsigned short canSetAttribute(in DOMString attrname, in DOMString attrval); unsigned short canSetAttributeNode(in Attr attrNode); unsigned short canSetAttributeNS(in DOMString namespaceURI, in DOMString qualifiedName, in DOMString value); unsigned short canRemoveAttribute(in DOMString attrname); unsigned short canRemoveAttributeNode(in Node attrNode); unsigned short canRemoveAttributeNS(in DOMString namespaceURI, in DOMString localName); unsigned short isElementDefined(in DOMString name); unsigned short isElementDefinedNS(in DOMString namespaceURI, in DOMString name); };
An integer indicating the content type of an element.
VAL_ANY_CONTENTTYPEANY content model.            
              VAL_ELEMENTS_CONTENTTYPEelement content content model; and if the schema
              is an XML Schema, this is the
              element-only content type.
              VAL_EMPTY_CONTENTTYPEempty content type; and if the schema is a DTD,
              this corresponds to the EMPTY content model.
              VAL_MIXED_CONTENTTYPEmixed
              content type.       
              VAL_SIMPLE_CONTENTTYPEVAL_SIMPLE_CONTENTTYPE
	    if the type of the element is a simple type definition,
	    or the type of the element is a complexType whose
	    {content type} is a simple type definition.
            allowedAttributes of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible attribute information items
           or wildcards
           that can appear as attributes of this element, or null
           if this element has no context or schema.
           Duplicate pairs of {namespaceURI, name} are eliminated.             
            allowedChildren of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible element information items or
           wildcards
           that can appear as children of this element, or null
           if this element has no context or schema.
           Duplicate pairs of {namespaceURI, name} are eliminated.             
            allowedFirstChildren of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible element information items or
           wildcards
           that can appear as a first child of this element, or null
           if this element has no context or schema.
           Duplicate pairs of {namespaceURI, name} are eliminated.
            allowedNextSiblings of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible element information items
           or wildcards
           that can appear as a next sibling of this element, or null
           if this element has no context or schema.
           Duplicate pairs of {namespaceURI, name} are eliminated.             
            allowedParents of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible element information items
           that can appear as a parent this element, or null
           if this element has no context or schema.
            allowedPreviousSiblings of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of all possible element information items
           or wildcards
           that can appear as a previous sibling of this element, or null
           if this element has no context or schema.
            contentType of type unsigned short, readonlyrequiredAttributes of type NameList, readonlyNameList, as described in [DOM Level 3 Core],
           of required attribute information items
           that must appear on this element, or null
           if this element has no context or schema.
            canRemoveAttributeattrname of type 
DOMString| 
 | A validation state constant. | 
canRemoveAttributeNSnamespaceURI of type 
DOMStringlocalName of type 
DOMString| 
 | A validation state constant. | 
canRemoveAttributeNodeattrNode of type 
NodeAttr node to remove from the attribute list.| 
 | A validation state constant. | 
canSetAttributeattrname of type 
DOMStringattrval of type 
DOMString| 
 | A validation state constant. | 
canSetAttributeNSnamespaceURI of type 
DOMStringnamespaceURI of namespace.qualifiedName of type 
DOMStringvalue of type 
DOMString| 
 | A validation state constant. | 
canSetAttributeNodeattrNode of type 
AttrNode in which the attribute can possibly be set.| 
 | A validation state constant. | 
canSetTextContentpossibleTextContent of type 
DOMString| 
 | A validation state constant. | 
isElementDefinedname is defined in the schema.
               This only applies to global declarations.  This method is for non-namespace aware schemas.
            name of type 
DOMString| 
 | A validation state constant. | 
isElementDefinedNSname in this namespace is defined in the
	      current context.  Thus not only does this apply to global declarations.
              but depending on the content, this may also apply to local 
              definitions.  This method is for namespace aware schemas.
            namespaceURI of type 
DOMStringnamespaceURI of namespace.name of type 
DOMString| 
 | A validation state constant. | 
This interface extends the NodeEditVAL interface with additional methods for document editing. An object
	    implementing this interface must also implement CharacterData interface.
	    When validating CharacterData nodes, the 
            NodeEditVAL.nodeValidity(valType)
            operation must find the nearest parent node in order to do this; if
            no parent node is found, 
            NodeEditVAL.VAL_UNKNOWN is returned.  In addition, when 
            NodeEditVAL.VAL_INCOMPLETE is passed in as an argument to the NodeEditVAL.nodeValidity 
            operation to operate on such nodes, the operation considers all the text and not just some of it.
          
interface CharacterDataEditVAL : NodeEditVAL { unsigned short isWhitespaceOnly(); unsigned short canSetData(in DOMString arg); unsigned short canAppendData(in DOMString arg); unsigned short canReplaceData(in unsigned long offset, in unsigned long count, in DOMString arg) raises(DOMException); unsigned short canInsertData(in unsigned long offset, in DOMString arg) raises(DOMException); unsigned short canDeleteData(in unsigned long offset, in unsigned long count) raises(DOMException); };
canAppendDataarg of type 
DOMString| 
 | A validation state constant. | 
canDeleteDataoffset of type 
unsigned longcount of type 
unsigned long| 
 | A validation state constant. | 
| 
 | INDEX_SIZE_ERR: Raised if the specified offset is negative or greater than the number of 16-bit units in data, or if the specified count is negative. | 
canInsertDataoffset of type 
unsigned longarg of type 
DOMString| 
 | A validation state constant. | 
| 
 | INDEX_SIZE_ERR: Raised if the specified offset is negative or greater than the number of 16-bit units in data. | 
canReplaceDataoffset of type 
unsigned longcount of type 
unsigned longarg of type 
DOMString| 
 | A validation state constant. | 
| 
 | INDEX_SIZE_ERR: Raised if the specified offset is negative or greater than the number of 16-bit units in data, or if the specified count is negative. | 
canSetDataarg of type 
DOMString| 
 | A validation state constant. | 
isWhitespaceOnly| 
 | A validation state constant. | 
 
      The following table describes all possible validation outcomes of
      the NodeEditVAL.nodeValidity(valType) method.
    
| Validation Type | Validity outcome | ||
|---|---|---|---|
| VAL_TRUE | VAL_FALSE | VAL_UNKNOWN | |
| VAL_WF | The node is well-formed. | The node is not well-formed. | Not applicable. | 
| VAL_NS_WF | The node is well-formed. Processor must take into account all the in-scope namespace declarations. | The node is not namespace well-formed. Processor must take into account all the in-scope namespace declarations. | Not applicable. | 
| VAL_NS_WF | The node is well-formed. Processor must take into account all namespace declarations in scope. | The node is not namespace well-formed. Processor must take into account all the in-scope namespace declarations. | Not applicable. | 
| VAL_SCHEMA | The node is valid: it complies with all the constraints expressed in the schema. | The node fails to comply to all the constraints expressed in the schema. | If the schema is an XML Schema, PSVI [validity] property value is unknown. | 
| VAL_INCOMPLETE | The node is valid: it complies with the VAL_INCOMPLETEdefinition. | The node is invalid with regard to the VAL_INCOMPLETEdefinition. | If the schema is an XML Schema, PSVI [validity] property value is unknown. | 
      The following table describes the outcome of the
      DocumentEditVAL.validateDocument() and
      NodeEditVAL.nodeValidity(valType) methods, with the
      latter called on the DocumentEditVAL node with
      validationType NodeEditVAL.VAL_SCHEMA.
    
| Methods | Validity outcome | ||
|---|---|---|---|
| VAL_TRUE | VAL_FALSE | VAL_UNKNOWN | |
| validateDocumentandnodeValidity,
	    called on theDocumentnode with validationTypeVAL_SCHEMA. | If the schema is a DTD, then the document valid constraint is
	    satisfied.  If the schema is an XML Schema, then the
	    document validity is the same as the validity of the validation root, i.e., documentElement: PSVI [validity] valid. | Fails to satisfy the constraints defined. | If the schema is an XML Schema, then schema is not found or the declaration for the validation root is not found: PSVI [validity] unknown. | 
      The following table describes outcomes for the
      NodeEditVAL.nodeValidity(valType) method called with
      the validationType NodeEditVAL.VAL_SCHEMA:
    
| Node types | Validity outcome | ||
|---|---|---|---|
| VAL_TRUE | VAL_FALSE | VAL_UNKNOWN | |
| Element | If the schema is a DTD, then element and attribute validity constraints, including attribute validity constraint defined below are satisfied. If the schema is an XML Schema, then PSVI [validity] valid. | Fails to satisfy the constraints defined. | If the schema is an XML Schema, then PSVI [validity] unknown. | 
| Attr | If the schema is a DTD, then all validity constraints defined in section 3.3.1, "Attribute Type", required and fixed attribute are satisfied. If the schema is an XML Schema, then PSVI [validity] valid. | Fails to satisfy the constraints defined. | If the schema is an XML Schema, then PSVI [validity] unknown. | 
| Text | The node is well-formed. | The node is not well-formed. | If no parent node is found. | 
| CDATASection | The node is well-formed. | The node is not well-formed. | If no parent node is found. | 
| ProcessingInstruction | The node is well-formed. | The node is not well-formed. | If no parent node is found. | 
| Comment | The node is well-formed. | The node is not well-formed. | If no parent node is found. | 
| EntityReference | Entity is declared. | Entity is not declared. | Not applicable. | 
| Entity | Implementation-specific. | Implementation-specific. | Implementation-specific. | 
| Notation | Implementation-specific. | Implementation-specific. | Implementation-specific. | 
| DocumentType | Implementation-specific. | Implementation-specific. | Implementation-specific. | 
| DocumentFragment | Not applicable. | Not applicable. | Not applicable. | 
 
      The table below describes validation outcomes from can*
      validation operations, such as
      NodeEditVAL.canRemoveChild(), or
      ElementEditVAL.canSetAttributeNS,
      CharacterDataEditVAL.canAppendData().  All these operations
      attempt to validate with validityType
      NodeEditVAL.VAL_INCOMPLETE.
    
| VAL_TRUE | VAL_FALSE | VAL_UNKNOWN | 
|---|---|---|
| If the associated operation is performed, then the node would
	    be valid with regards to the VAL_INCOMPLETEdefinition or if there is no schema found. | If the associated operation is performed, then the node would
	    be invalid with regards to the VAL_INCOMPLETEdefinition. | Not applicable. | 
      Note: If the document includes more than one type of schema, e.g., DTD and XML Schema, and
      the DOMConfiguration "schema-type"
      parameter is not specified, the validation outcome for
      NodeEditVAL.VAL_INCOMPLETE and
      NodeEditVAL.VAL_SCHEMA is implementation-specific.
    
This appendix contains the complete OMG IDL [OMG IDL] for the Level 3 Document Object Model Validation definitions.
The IDL files are also available as: http://www.w3.org/TR/2003/CR-DOM-Level-3-Val-20030730/idl.zip
// File: validation.idl
#ifndef _VALIDATION_IDL_
#define _VALIDATION_IDL_
#include "dom.idl"
#pragma prefix "dom.w3c.org"
module validation
{
  typedef dom::DOMString DOMString;
  typedef dom::DOMStringList DOMStringList;
  typedef dom::Node Node;
  typedef dom::NameList NameList;
  typedef dom::Attr Attr;
  typedef dom::DOMConfiguration DOMConfiguration;
  exception ExceptionVAL {
    unsigned short   code;
  };
  // ExceptionVALCode
  const unsigned short      NO_SCHEMA_AVAILABLE_ERR        = 71;
  interface NodeEditVAL {
    // validationType
    const unsigned short      VAL_WF                         = 1;
    const unsigned short      VAL_NS_WF                      = 2;
    const unsigned short      VAL_INCOMPLETE                 = 3;
    const unsigned short      VAL_SCHEMA                     = 4;
    // validationState
    const unsigned short      VAL_TRUE                       = 5;
    const unsigned short      VAL_FALSE                      = 6;
    const unsigned short      VAL_UNKNOWN                    = 7;
    readonly attribute DOMString       defaultValue;
    readonly attribute DOMStringList   enumeratedValues;
    unsigned short     canInsertBefore(in Node newChild, 
                                       in Node refChild);
    unsigned short     canRemoveChild(in Node oldChild);
    unsigned short     canReplaceChild(in Node newChild, 
                                       in Node oldChild);
    unsigned short     canAppendChild(in Node newChild);
    unsigned short     nodeValidity(in unsigned short valType);
  };
  interface ElementEditVAL : NodeEditVAL {
    // ContentTypeVAL
    const unsigned short      VAL_EMPTY_CONTENTTYPE          = 1;
    const unsigned short      VAL_ANY_CONTENTTYPE            = 2;
    const unsigned short      VAL_MIXED_CONTENTTYPE          = 3;
    const unsigned short      VAL_ELEMENTS_CONTENTTYPE       = 4;
    const unsigned short      VAL_SIMPLE_CONTENTTYPE         = 5;
    readonly attribute NameList        allowedChildren;
    readonly attribute NameList        allowedFirstChildren;
    readonly attribute NameList        allowedParents;
    readonly attribute NameList        allowedNextSiblings;
    readonly attribute NameList        allowedPreviousSiblings;
    readonly attribute NameList        allowedAttributes;
    readonly attribute NameList        requiredAttributes;
    readonly attribute unsigned short  contentType;
    unsigned short     canSetTextContent(in DOMString possibleTextContent);
    unsigned short     canSetAttribute(in DOMString attrname, 
                                       in DOMString attrval);
    unsigned short     canSetAttributeNode(in Attr attrNode);
    unsigned short     canSetAttributeNS(in DOMString namespaceURI, 
                                         in DOMString qualifiedName, 
                                         in DOMString value);
    unsigned short     canRemoveAttribute(in DOMString attrname);
    unsigned short     canRemoveAttributeNode(in Node attrNode);
    unsigned short     canRemoveAttributeNS(in DOMString namespaceURI, 
                                            in DOMString localName);
    unsigned short     isElementDefined(in DOMString name);
    unsigned short     isElementDefinedNS(in DOMString namespaceURI, 
                                          in DOMString name);
  };
  interface CharacterDataEditVAL : NodeEditVAL {
    unsigned short     isWhitespaceOnly();
    unsigned short     canSetData(in DOMString arg);
    unsigned short     canAppendData(in DOMString arg);
    unsigned short     canReplaceData(in unsigned long offset, 
                                      in unsigned long count, 
                                      in DOMString arg)
                                        raises(dom::DOMException);
    unsigned short     canInsertData(in unsigned long offset, 
                                     in DOMString arg)
                                        raises(dom::DOMException);
    unsigned short     canDeleteData(in unsigned long offset, 
                                     in unsigned long count)
                                        raises(dom::DOMException);
  };
  interface DocumentEditVAL : NodeEditVAL {
             attribute boolean         continuousValidityChecking;
                                        // raises(dom::DOMException, 
                                        //        ExceptionVAL, 
                                        //        dom::DOMException) on setting
    readonly attribute DOMConfiguration config;
    NameList           getDefinedElements(in DOMString namespaceURI);
    unsigned short     validateDocument();
  };
};
#endif // _VALIDATION_IDL_
This appendix contains the complete Java [Java] bindings for the Level 3 Document Object Model Validation.
The Java files are also available as http://www.w3.org/TR/2003/CR-DOM-Level-3-Val-20030730/java-binding.zip
package org.w3c.dom.validation;
public class ExceptionVAL extends RuntimeException {
    public ExceptionVAL(short code, String message) {
       super(message);
       this.code = code;
    }
    public short   code;
    // ExceptionVALCode
    public static final short NO_SCHEMA_AVAILABLE_ERR   = 71;
}
package org.w3c.dom.validation;
import org.w3c.dom.DOMConfiguration;
import org.w3c.dom.DOMException;
import org.w3c.dom.NameList;
public interface DocumentEditVAL extends NodeEditVAL {
    public boolean getContinuousValidityChecking();
    public void setContinuousValidityChecking(boolean continuousValidityChecking)
 throws DOMException, ExceptionVAL, DOMException;
    public DOMConfiguration getConfig();
    public NameList getDefinedElements(String namespaceURI);
    public short validateDocument();
}
package org.w3c.dom.validation;
import org.w3c.dom.Node;
import org.w3c.dom.DOMStringList;
public interface NodeEditVAL {
    // validationType
    public static final short VAL_WF                    = 1;
    public static final short VAL_NS_WF                 = 2;
    public static final short VAL_INCOMPLETE            = 3;
    public static final short VAL_SCHEMA                = 4;
    // validationState
    public static final short VAL_TRUE                  = 5;
    public static final short VAL_FALSE                 = 6;
    public static final short VAL_UNKNOWN               = 7;
    public String getDefaultValue();
    public DOMStringList getEnumeratedValues();
    public short canInsertBefore(Node newChild, 
                                 Node refChild);
    public short canRemoveChild(Node oldChild);
    public short canReplaceChild(Node newChild, 
                                 Node oldChild);
    public short canAppendChild(Node newChild);
    public short nodeValidity(short valType);
}
package org.w3c.dom.validation;
import org.w3c.dom.Node;
import org.w3c.dom.Attr;
import org.w3c.dom.NameList;
public interface ElementEditVAL extends NodeEditVAL {
    // ContentTypeVAL
    public static final short VAL_EMPTY_CONTENTTYPE     = 1;
    public static final short VAL_ANY_CONTENTTYPE       = 2;
    public static final short VAL_MIXED_CONTENTTYPE     = 3;
    public static final short VAL_ELEMENTS_CONTENTTYPE  = 4;
    public static final short VAL_SIMPLE_CONTENTTYPE    = 5;
    public NameList getAllowedChildren();
    public NameList getAllowedFirstChildren();
    public NameList getAllowedParents();
    public NameList getAllowedNextSiblings();
    public NameList getAllowedPreviousSiblings();
    public NameList getAllowedAttributes();
    public NameList getRequiredAttributes();
    public short getContentType();
    public short canSetTextContent(String possibleTextContent);
    public short canSetAttribute(String attrname, 
                                 String attrval);
    public short canSetAttributeNode(Attr attrNode);
    public short canSetAttributeNS(String namespaceURI, 
                                   String qualifiedName, 
                                   String value);
    public short canRemoveAttribute(String attrname);
    public short canRemoveAttributeNode(Node attrNode);
    public short canRemoveAttributeNS(String namespaceURI, 
                                      String localName);
    public short isElementDefined(String name);
    public short isElementDefinedNS(String namespaceURI, 
                                    String name);
}
package org.w3c.dom.validation;
import org.w3c.dom.DOMException;
public interface CharacterDataEditVAL extends NodeEditVAL {
    public short isWhitespaceOnly();
    public short canSetData(String arg);
    public short canAppendData(String arg);
    public short canReplaceData(int offset, 
                                int count, 
                                String arg)
                                throws DOMException;
    public short canInsertData(int offset, 
                               String arg)
                               throws DOMException;
    public short canDeleteData(int offset, 
                               int count)
                               throws DOMException;
}
This appendix contains the complete ECMAScript [ECMAScript] binding for the Level 3 Document Object Model Validation definitions.
Many people contributed to the DOM specifications (Level 1, 2 or 3), including members of the DOM Working Group and the DOM Interest Group. We especially thank the following:
Andrew Watson (Object Management Group), Andy Heninger (IBM), Angel Diaz (IBM), Arnaud Le Hors (W3C and IBM), Ashok Malhotra (IBM and Microsoft), Ben Chang (Oracle), Bill Smith (Sun), Bill Shea (Merrill Lynch), Bob Sutor (IBM), Chris Lovett (Microsoft), Chris Wilson (Microsoft), David Brownell (Sun), David Ezell (Hewlett Packard Company), David Singer (IBM), Dimitris Dimitriadis (Improve AB and invited expert), Don Park (invited), Elena Litani (IBM), Eric Vasilik (Microsoft), Gavin Nicol (INSO), Ian Jacobs (W3C), James Clark (invited), James Davidson (Sun), Jared Sorensen (Novell), Jeroen van Rotterdam (X-Hive Corporation), Joe Kesselman (IBM), Joe Lapp (webMethods), Joe Marini (Macromedia), Johnny Stenback (Netscape/AOL), Jon Ferraiolo (Adobe), Jonathan Marsh (Microsoft), Jonathan Robie (Texcel Research and Software AG), Kim Adamson-Sharpe (SoftQuad Software Inc.), Lauren Wood (SoftQuad Software Inc., former Chair), Laurence Cable (Sun), Mark Davis (IBM), Mark Scardina (Oracle), Martin Dürst (W3C), Mary Brady (NIST), Mick Goulish (Software AG), Mike Champion (Arbortext and Software AG), Miles Sabin (Cromwell Media), Patti Lutsky (Arbortext), Paul Grosso (Arbortext), Peter Sharpe (SoftQuad Software Inc.), Phil Karlton (Netscape), Philippe Le Hégaret (W3C, W3C team contact and former Chair), Ramesh Lekshmynarayanan (Merrill Lynch), Ray Whitmer (iMall, Excite@Home, and Netscape/AOL, Chair), Rezaur Rahman (Intel), Rich Rollman (Microsoft), Rick Gessner (Netscape), Rick Jelliffe (invited), Rob Relyea (Microsoft), Scott Isaacs (Microsoft), Sharon Adler (INSO), Steve Byrne (JavaSoft), Tim Bray (invited), Tim Yu (Oracle), Tom Pixley (Netscape/AOL), Vidur Apparao (Netscape), Vinod Anupam (Lucent).
Thanks to all those who have helped to improve this specification by sending suggestions and corrections (Please, keep bugging us with your issues!).
Special thanks to the DOM Conformance Test Suites contributors: Curt Arnold, Fred Drake, Mary Brady (NIST), Rick Rivello (NIST), Robert Clary (Netscape).
This specification was written in XML. The HTML, OMG IDL, Java and ECMAScript bindings were all produced automatically.
Thanks to Joe English, author of cost, which was used as the basis for producing DOM Level 1. Thanks also to Gavin Nicol, who wrote the scripts which run on top of cost. Arnaud Le Hors and Philippe Le Hégaret maintained the scripts.
After DOM Level 1, we used Xerces as the basis DOM implementation and wish to thank the authors. Philippe Le Hégaret and Arnaud Le Hors wrote the Java programs which are the DOM application.
Thanks also to Jan Kärrman, author of html2ps, which we use in creating the PostScript version of the specification.
Several of the following term definitions have been borrowed or modified from similar definitions in other W3C or standards documents. See the links within the definitions for more information.
For the latest version of any W3C specification please consult the list of W3C Technical Reports available at http://www.w3.org/TR.
The references listed in this section are normatives.