Package net.sf.saxon.om


package net.sf.saxon.om

This package defines the interface to the Saxon tree structure. This structure is used to represent both the source document and the stylesheet. Essentially, this class represents Saxon's realization of the XPath data model.

The classes in the package are rather a miscellany. What they have in common is that they describe the way the Saxon tree structure is accessed, in a way that it independent of the two tree implementations (in packages net.sf.saxon.tree and net.sf.saxon.tinytree).

Broadly speaking, the classes fall into four categories:

  • Interface classes: DocumentInfo, NodeInfo, Item, ValueRepresentation. These describe the interface offered by the object model to the rest of the system, including the application.
  • Iterator classes: SequenceIterator, AxisIterator, ArrayIterator, EmptyIterator, SingletonIterator, and others. These classes provide mechanisms for iterating over sequences. The most general, and the one which applications are most likely to use, is the SequenceIterator interface itself. AxisIterator is a specialization of this interface whose main difference is that it cannot throw exceptions. The other classes are implementations of SequenceIterator for use in particular circumstances.
  • Shared implementation classes: DocumentPool, NamePool, Navigator, XMLChar. These contain functionality that is shared between the various tree implementations. (However, there is also some shared functionality in the net.sf.saxon.tree package). These classes are not generally needed by applications, with the exception of NamePool, which complex applications may need to manipulate.
  • Information classes: Axis, NamespaceConstant. These contain constants.

Michael H. Kay
Saxonica Limited
9 February 2005

  • Class
    Description
    The AllElementStripper refines the Stripper class to do stripping of all whitespace nodes in a document
    ArrayIterator is used to enumerate items held in an array.
    AttributeCollection represents the collection of attributes available on a particular element node.
    AttributeCollectionImpl is an implementation of both the SAX2 interface Attributes and the Saxon equivalent AttributeCollection.
    An axis, that is a direction of navigation in the document structure.
    A SequenceIterator is used to iterate over a sequence.
    A SequenceIterator is used to iterate over a sequence.
    This interface represents a document node as defined in the XPath 2.0 data model.
    This class (which has one instance per Configuration) is used to allocate unique document numbers.
    An object representing the collection of documents handled during a single transformation.
    EmptyIterator: an iterator over an empty sequence.
    A class representing an empty set of namespace declarations
    This interface must be implemented by any third-party object model that can be wrapped with a wrapper that implements the Saxon Object Model (the NodeInfo interface).
    A simple implementation of a class similar to StringBuffer.
    This is a marker interface used to identify nodes that contain a namepool fingerprint.
    This interface is an extension to the SequenceIterator interface; it represents a SequenceIterator that is based on an in-memory representation of a sequence, and that is therefore capable of returned a SequenceValue containing all the items in the sequence.
    A value that exists in memory and that can be directly addressed
    A NamespaceResolver that resolves namespace prefixes by reference to a node in a document for which those namespaces are in-scope.
    An Item is an object that can occur as a member of a sequence.
    Class ListIterator, iterates over a sequence of items held in a Java ArrayList, or indeed in any other kind of List
    A SequenceIterator is used to iterate over a sequence.
    An extension of the NodeInfo interface defining a node that can be updated.
    The class checks names and characters against the rules of the XML 1.0 and XML Namespaces 1.0 specification
    The class checks names against the rules of the XML 1.1 and XML Namespaces 1.1 specification
    A NameChecker performs validation and analysis of XML names.
    A NamePool holds a collection of expanded names, each containing a namespace URI, a namespace prefix, and a local name; plus a collection of namespaces, each consisting of a prefix/URI pair.
    Uncaught Exception raised when some limit in the design of the name pool is exceeded
    This class provides an iterator over the namespace codes representing the in-scope namespaces of any node.
    This class is not instantiated, it exists to hold a set of constants representing known namespaces.
    This interface represents a collection of namespace declarations or undeclarations, typically those appearing together in an element start tag.
    An implementation of the NamespaceDeclarations interface, based on encapsulating an array of namespace codes.
    A NamespaceException represents an error condition whereby a QName (for example a variable name or template name) uses a namespace prefix that is not declared
    This class provides an implementation of the namespace axis over any implementation of the data model.
    Inner class: a model-independent representation of a namespace node
    Abstract class that supports lookup of a lexical QName to get the expanded QName.
    An implementation of NamespaceDeclarations that contains all the inscope namespaces made available by a NamespaceResolver.
    This class is a NamespaceResolver that modifies an underyling NamespaceResolver by changing the mapping of the null prefix to be a specified namespace, rather than the one used by the underlying namespace resolver.
    The Navigator class provides helper classes for navigating a tree, irrespective of its implementation
    General-purpose implementation of the ancestor and ancestor-or-self axes
    AxisFilter is an iterator that applies a NodeTest filter to the nodes returned by an underlying AxisIterator.
    BaseEnumeration is an abstract implementation of an AxisIterator, it simplifies the implementation of the underlying AxisIterator by requiring it to provide only two methods: advance(), and getAnother().
    General-purpose implementation of the descendant and descendant-or-self axes, in terms of the child axis.
    General purpose implementation of the following axis, in terms of the ancestor, child, and following-sibling axes
    Helper method to iterate over the preceding axis, or Saxon's internal preceding-or-ancestor axis, by making use of the ancestor, descendant, and preceding-sibling axes.
    An iterator over an array of nodes.
    The NodeInfo interface represents a node in Saxon's implementation of the XPath 2.0 data model.
    Specialization of ListIterator for use when the items in the list are all nodes
    A node (implementing the NodeInfo interface) representing an attribute, text node, comment, processing instruction, or namespace that has no parent (and of course no children).
     
    An iterator over nodes, that prepends a given node to the nodes returned by another iterator.
    ProcInstParser is used to parse pseudo-attributes within Processing Instructions
    A QNameException represents an error condition whereby a QName (for example a variable name or template name) is malformed
    ReverseArrayIterator is used to enumerate items held in an array in reverse order.
    Iterator over an array of nodes in reverse order
    A SequenceIterator is used to iterate over any XPath 2 sequence (of values or nodes).
    Interface that extends NodeInfo by providing a method to get the position of a node relative to its siblings.
    SingletonIterator: an iterator over a sequence of zero or one values
    SingletonIterator: an iterator over a sequence of zero or one values
    Well-known names used in XSLT processing.
    A StrippedDocument represents a view of a real Document in which selected whitespace text nodes are treated as having been stripped.
    A StrippedNode is a view of a node, in a virtual tree that has whitespace text nodes stripped from it.
    This class provides an economical representation of a QName triple (prefix, URI, and localname).
    A SequenceIterator is used to iterate over a sequence.
    This class contains constants and static methods to manipulate the validation property of a type.
    A ValueRepresentation is a representation of a Value.
    This class represents a node that is a virtual copy of another node: that is, it behaves as a node that's the same as another node, but has different identity.
    A virtual copy of a document node
    This interface is implemented by NodeInfo implementations that act as wrappers on some underlying tree.
    This class represents a virtual copy of a node with type annotations stripped