01 September, 2000

OB

1. Document Object Model Core

Editors
Arnaud Le Hors, IBM

Table of contents

1.1. DOM Level 3 Core

(ED: Although the following defines a set of new interfaces that extend the DOM Level 2 interfaces the current plan is not to actually add any new interfaces but instead to expand the existing ones.)
Issue Level-3-Core-1:
Instead of extending the core interfaces should we define some kind of DOMUtility interface which could be optional?
Interface Entity3

This interface extends the Entity interface with additional attributes to provide information on the text declaration of external parsed entities.


IDL Definition
interface Entity3 : Entity {
           attribute DOMString        actualEncoding;
           attribute DOMString        encoding;
           attribute DOMString        version;
};

Attributes
actualEncoding of type DOMString
An attribute specifying the actual encoding of this entity, when it is an external parsed entity. This is null otherwise.

encoding of type DOMString
An attribute specifying, as part of the text declaration, the encoding of this entity, when it is an external parsed entity. This is null otherwise.

version of type DOMString
An attribute specifying, as part of the text declaration, the version number of this entity, when it is an external parsed entity. This is null otherwise.

Interface Document3

This interface extends the Document interface with additional attributes and methods.


IDL Definition
interface Document3 : Document {
           attribute DOMString        actualEncoding;
           attribute DOMString        encoding;
           attribute boolean          standalone;
           attribute boolean          strictErrorChecking;
           attribute DOMString        version;
  Node               adoptNode(in Node source)
                                        raises(DOMException);
  NodeList           getElementsByAttributeValue(in DOMString namespaceURI, 
                                                 in DOMString localName, 
                                                 in DOMString value);
};

Attributes
actualEncoding of type DOMString
An attribute specifying the actual encoding of this document. This is null otherwise.

encoding of type DOMString
An attribute specifying, as part of the XML declaration, the encoding of this document. This is null when unspecified.

standalone of type boolean
An attribute specifying, as part of the XML declaration, whether this document is standalone.

strictErrorChecking of type boolean
An attribute specifying whether errors checking is enforced or not. When set to false, the implementation is free to not test every possible error case normally defined on DOM operations, and not raise any DOMException. In case of error, the behavior is undefined. This attribute is true by defaults.

version of type DOMString
An attribute specifying, as part of the XML declaration, the version number of this document. This is null when unspecified.

Methods
adoptNode
Changes the ownerDocument of a node, its children, as well as the attached attribute nodes if there are any. If the node has a parent it is first removed from its parent child list. This effectively allows moving a subtree from one document to another. The following list describes the specifics for each type of node.
ATTRIBUTE_NODE
The ownerElement attribute is set to null and the specified flag is set to true on the adopted Attr. The descendants of the source Attr are recursively adopted.
DOCUMENT_FRAGMENT_NODE
The descendants of the source node are recursively adopted.
DOCUMENT_NODE
Document nodes cannot be adopted.
DOCUMENT_TYPE_NODE
DocumentType nodes cannot be adopted.
ELEMENT_NODE
Specified attribute nodes of the source element are adopted, and the generated Attr nodes. Default attributes are discarded, though if the document being adopted into defines default attributes for this element name, those are assigned. The descendants of the source element are recursively adopted.
ENTITY_NODE
Entity nodes can be adopted, however in the current release of the DOM the DocumentType is readonly. Ability to add these adopted nodes to a DocumentType will be considered for addition to a future release of the DOM. The descendants of the the source entity are recursively adopted.
ENTITY_REFERENCE_NODE
Only the EntityReference node itself is adopted, the descendants are discarded, since the source and destination documents might have defined the entity differently. If the document being imported into provides a definition for this entity name, its value is assigned.
NOTATION_NODE
Notation nodes can be adopted, however in the current release of the DOM the DocumentType is readonly. Ability to add these adopted nodes to a DocumentType will be considered for addition to a future release of the DOM.
PROCESSING_INSTRUCTION_NODE, TEXT_NODE, CDATA_SECTION_NODE, COMMENT_NODE
These nodes can all be adopted. No specifics.
Issue adoptNode-1:
Should this method simply return null when it fails? How "exceptional" is failure for this method?
Resolution: Stick with raising exceptions only in exceptional circumstances, return null on failure (F2F 19 Jun 2000).
Issue adoptNode-2:
Can an entity node really be adopted?
Parameters
source of type Node
The node to move into this document.

Return Value

Node

The adopted node, or null if this operation fails, such as when the source node comes from a different implementation.

Exceptions

DOMException

NOT_SUPPORTED_ERR: Raised if the source node is of type DOCUMENT, DOCUMENT_TYPE.

NO_MODIFICATION_ALLOWED_ERR: Raised when the source node is readonly.

getElementsByAttributeValue
Get a list of all the elements which have a specific attribute.
Issue getElementsByAttributeValue-1:
Anyone still lobbying for this?
Resolution: No, killed! (F2F 1 Aug 2000)
Issue getElementsByAttributeValue-2:
Should we have getElementsByAttributeValue and getElementsByAttributeValueNS?
Resolution: Yes, but irrelevant, see above. (F2F 1 Aug 2000)
Issue getElementsByAttributeValue-3:
Should we have this on Element as well? We have getElementsByTagName there.
Resolution: Irrelevant, see above. (F2F 1 Aug 2000)
Parameters
namespaceURI of type DOMString
The namespace URI of the attribute to look for.

localName of type DOMString
The local name of the attribute to look for.

value of type DOMString
The value of the attribute to look for.

Return Value

NodeList

Returns a list containing the elements that have an attribute that matches the given namespace URI, local name, and value.

No Exceptions

Interface Node3

This interface extends the Node interface with several new methods. One allows to compare a node against another with regard to document order. Another methode allows to retrieve the content of a node and its descendants as a single DOMString. One allows to test whether two nodes are the same. Two methods provide for searching the namespace URI associated to a given prefix and to ensure the document is "namespace wellformed". Finally, a method allows to attach some user data to a Node. It also provides a new attribute to get the base URI of a node, as defined in the XML Infoset.

Issue namespace-wellformed:
The term namespace wellformed needs to be defined.
Resolution: Define it as "being conformant to the Namespaces in XML spec" in the glossary (Telcon 4 Jul 2000).

IDL Definition
interface Node3 {
  readonly attribute DOMString        baseURI;

  typedef enum _DocumentOrder {
    PRECEDING,
    FOLLOWING,
    SAME,
    UNORDERED
  };
 DocumentOrder;
  DocumentOrder      compareDocumentOrder(in Node other)
                                        raises(DOMException);

  typedef enum _TreePosition {
    PRECEDING,
    FOLLOWING,
    ANCESTOR,
    DESCENDANT,
    SAME,
    UNORDERED
  };
 TreePosition;
  TreePosition       compareTreePosition(in Node other)
                                        raises(DOMException);
           attribute DOMString        textContent;
  boolean            isSameNode(in Node other);
  DOMString          lookupNamespacePrefix(in DOMString namespaceURI);
  DOMString          lookupNamespaceURI(in DOMString prefix);
  void               normalizeNS();
  Object             setUserData(in Object data, 
                                 in DOMString key);
  Object             getUserData(in DOMString key);
  readonly attribute Object           key;
};

Type Definition DocumentOrder

A type to hold the document order of a node relative to another node.

Enumeration _DocumentOrder

An enumeration of the different orders the node can be in.
Enumerator Values
PRECEDING

The node preceds the reference node in document order.

FOLLOWING

The node follows the reference node in document order.

SAME

The two nodes have the same document order.

UNORDERED

The two nodes are unordered, they do not have any common ancestor.

Type Definition TreePosition

A type to hold the relative tree position of a node with respect to another node.

Enumeration _TreePosition

An enumeration of the different orders the node can be in.
Enumerator Values
PRECEDING

The node preceds the reference node.

FOLLOWING

The node follows the reference node.

ANCESTOR

The node is an ancestor of the reference node.

DESCENDANT

The node is a descendant of the reference node.

SAME

The two nodes have the same position.

UNORDERED

The two nodes are unordered, they do not have any common ancestor.

Attributes
baseURI of type DOMString, readonly
Returns the absolute base URI of this node.
Issue baseURI-1:
How will this be affected by resolution of relative namespace URIs issue?
Issue baseURI-2:
Should this only be on Document, Element, ProcessingInstruction, Entity, and Notation nodes, according to the infoset? If not, what is it equal to on other nodes? Null? An empty string?
Issue baseURI-3:
Should this be read-only and computed or and actual read-write attribute?
Resolution: The former (F2F 19 Jun 2000).

key of type Object, readonly
This attribute returns a unique key identifying this node.
Issue key-1:
What type should this really be?
Issue key-2:
In what space is this key unique (Document, DOMImplementation)?
Issue key-3:
What is the lifetime of the uniqueness of this key (Node, Document, ...)?

textContent of type DOMString
This attribute returns the text content of this node and its descendants. When set, any possible children this node may have are removed and replaced by a single Text node containing the string this attribute is set to. On getting, no serialization is performed, the returned string does not contain any markup. Similarly, on setting, no parsing is performed either, the input string is taken as pure textual content.
The string returned is made of the text content of this node depending on its type, as defined below:
Node typeContent
ELEMENT_NODE, ENTITY_NODE, ENTITY_REFERENCE_NODE, DOCUMENT_NODE, DOCUMENT_FRAGMENT_NODE concatenation of the textContent of the child nodes, excluding COMMENT_NODE and PROCESSING_INSTRUCTION_NODE nodes
ATTRIBUTE_NODE, TEXT_NODE, CDATA_SECTION_NODE, COMMENT_NODE, PROCESSING_INSTRUCTION_NODE nodeValue
DOCUMENT_TYPE_NODE, NOTATION_NODE empty string
Issue textContent-1:
Should any whitespace normalization be performed?
Issue textContent-2:
Should this be two methods instead?
Issue textContent-3:
What about the name?

Methods
compareDocumentOrder
Compares a node with this node with regard to document order.
Issue compareOrder-1:
Should an exception be raised when comparing attributes? Entities and notations? An element against an attribute? If yes, which one? HIERARCHY_REQUEST_ERR? Should the enum value "unordered" be killed then?
Resolution: No, return unordered for attributes (F2F 19 Jun 2000).
Issue compareOrder-2:
Should this method be moved to Node and take only one node in argument?
Resolution: Yes (F2F 19 Jun 2000).
Parameters
other of type Node
The node to compare against this node.

Return Value

DocumentOrder

Returns how the given node compares with this node in document order.

Exceptions

DOMException

WRONG_DOCUMENT_ERR: Raised if the given node does not belong to the same document as this node.

compareTreePosition
Compares a node with this node with regard to their position in the tree.
Parameters
other of type Node
The node to compare against this node.

Return Value

TreePosition

Returns how the given node is positioned relatively to this node.

Exceptions

DOMException

WRONG_DOCUMENT_ERR: Raised if the given node does not belong to the same document as this node.

getUserData
This method allows to retreive a user object previously attached to a Node with setUserData.
Parameters
key of type DOMString
The key to look for.

Return Value

Object

The object associated to this node and the given key or null.

No Exceptions

isSameNode
Returns whether this node is the same node as the given one.
Issue isIdentical-1:
Do we really want to make this different from equals?
Resolution: Yes, change name from isIdentical to isSameNode. (Telcon 4 Jul 2000).
Parameters
other of type Node
The node to test against.

Return Value

boolean

Returns true if the nodes are the same, false otherwise.

No Exceptions

lookupNamespacePrefix
Look up the prefix associated to the given namespace URI, starting from this node.
Parameters
namespaceURI of type DOMString
The namespace URI to look for.

Return Value

DOMString

Returns the associated namespace prefix or null if none is found.

No Exceptions

lookupNamespaceURI
Look up the namespace URI associated to the given prefix, starting from this node.
Issue lookupNamespaceURI-1:
Name? May need to change depending on ending of the relative namespace URI reference nightmare.
Parameters
prefix of type DOMString
The prefix to look for.

Return Value

DOMString

Returns the associated namespace URI or null if none is found.

No Exceptions

normalizeNS
This method walks down the tree, starting from this node, and adds namespace declarations where needed so that every namespace being used is properly declared. It also changes or assign prefixes when needed. This effectively makes this node subtree is "namespace wellformed".
What the generated prefixes are and/or how prefixes are changed to achieve this is implementation dependent.
Issue normalizeNS-1:
Any other name?
Issue normalizeNS-2:
How specific should this be? Should we not even specify that this should be done by walking down the tree?
Issue normalizeNS-3:
What does this do on attribute nodes?
Resolution: Doesn't do anything (F2F 1 Aug 2000).
Issue normalizeNS-4:
How does it work with entity reference subtree which may be broken?
Resolution: This doesn't affect entity references which are not visited in this operation (F2F 1 Aug 2000).
Issue normalizeNS-5:
Should this be really be on Node?
Resolution: Yes, but this only works on Document, Element, and DocumentFragment. On other types it is a no-op. (F2F 1 Aug 2000).
Issue normalizeNS-6:
What happens with read-only nodes?
Issue normalizeNS-7:
What/how errors should be reported? Are there any?

No Parameters
No Return Value
No Exceptions

setUserData
This method allows to attach a user object to a Node. This object can then be retreived using getUserData.
Issue setUserData-1:
Is this really worth it?
Issue setUserData-2:
Could we live without a key?
Issue setUserData-3:
What happens if the node is cloned, imported, adopted? Should some event mechanism be specified to notify the application?
Issue setUserData-4:
What happens if the node is cloned?
Issue setUserData-5:
What should Object be mapped to in ECMAScript? For IDL we need to define this type somehow.
Parameters
data of type Object
The piece of data to attach to this node.

key of type DOMString
The key to associate this data to.

Return Value

Object

The object previously associated to this node and the given key or null.

No Exceptions

Interface Text3

This interface extends the Text interface with a new attribute that allows one to find out whether a Text node only contains whitespace in element content.


IDL Definition
interface Text3 : Text {
  readonly attribute boolean          isWhitespaceInElementContent;
};

Attributes
isWhitespaceInElementContent of type boolean, readonly
Returns whether this text node contains whitespace in element content, often abusively called "ignorable whitespace".

Note: An implementation can only return true if, one way or another, it has access to the relevant information (e.g., the DTD or schema).