Package net.sf.saxon.tree.tiny
Class TinyElementImpl
java.lang.Object
net.sf.saxon.tree.tiny.TinyNodeImpl
net.sf.saxon.tree.tiny.TinyParentNodeImpl
net.sf.saxon.tree.tiny.TinyElementImpl
- All Implemented Interfaces:
- Source,- SourceLocator,- ActiveSource,- GroundedValue,- Item,- NodeInfo,- Sequence,- Location,- Locator
- Direct Known Subclasses:
- TinyTextualElement
A node in the XML parse tree representing an XML element.
 
This class is an implementation of NodeInfo. The object is a wrapper around one entry in the arrays maintained by the TinyTree. Note that the same node might be represented by different TinyElementImpl objects at different times.
- 
Field SummaryFields inherited from class net.sf.saxon.tree.tiny.TinyNodeImplNODE_LETTER, nodeNr, parent, tree
- 
Constructor SummaryConstructorsConstructorDescriptionTinyElementImpl(TinyTree tree, int nodeNr) Constructor - create a tiny element node
- 
Method SummaryModifier and TypeMethodDescriptionatomize()Get the typed value.protected voidcheckNotNamespaceSensitiveElement(SchemaType type, int nodeNr) Check whether the content of an element is namespace-sensitivevoidCopy this node to a given receiverGet all the namespace bindings that are in-scope for this element.getAttributeValue(int fp) Get the value of the attribute with a given fingerprint.getAttributeValue(NamespaceUri uri, String local) Get the string value of a given attribute of this nodeGet the base URI of this element node.getDeclaredNamespaces(NamespaceBinding[] buffer) Get all namespace undeclarations and undeclarations defined on this element.final intReturn the type of node.Get the type annotation of this node, if any.booleanAsk whether the element is the root of a subtree in which no descendant element has any local namespace declarations or undeclarations; that is, all elements in the subtree have the same in-scope namespace bindings.booleanisId()Determine whether this node has the is-id propertybooleanisIdref()Determine whether this node has the is-idref propertyMethods inherited from class net.sf.saxon.tree.tiny.TinyParentNodeImplgetStringValue, getUnicodeStringValue, hasChildNodesMethods inherited from class net.sf.saxon.tree.tiny.TinyNodeImplcompareOrder, equals, generateId, getColumnNumber, getConfiguration, getDisplayName, getFingerprint, getGenre, getLineNumber, getLocalPart, getNamePool, getNamespaceUri, getNodeNumber, getParent, getParentNodeNr, getPrefix, getRoot, getSequenceNumber, getSystemId, getTree, getTreeInfo, hasFingerprint, hashCode, hasURI, head, isAncestorOrSelf, isNilled, isSameNodeInfo, isStreamed, iterateAxis, iterateAxis, saveLocation, setParentNode, setSystemIdMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface net.sf.saxon.om.GroundedValueasIterable, concatenate, containsNode, effectiveBooleanValue, materializeMethods inherited from interface net.sf.saxon.om.ItemgetLength, getStringValue, itemAt, iterate, reduce, subsequenceMethods inherited from interface net.sf.saxon.om.NodeInfoasActiveSource, attributes, children, children, deliver, getAttributeValue, getPublicId, getURI, toShortStringMethods inherited from interface net.sf.saxon.om.SequencemakeRepeatable
- 
Constructor Details- 
TinyElementImplConstructor - create a tiny element node- Parameters:
- tree- the Tinytree containing the node
- nodeNr- the node number
 
 
- 
- 
Method Details- 
getNodeKindpublic final int getNodeKind()Return the type of node.- Returns:
- Type.ELEMENT
- See Also:
 
- 
getBaseURIGet the base URI of this element node. This will be the same as the System ID unless xml:base has been used.- Specified by:
- getBaseURIin interface- NodeInfo
- Overrides:
- getBaseURIin class- TinyNodeImpl
- Returns:
- the base URI of the node. This may be null if the base URI is unknown, including the case where the node has no parent.
 
- 
getSchemaTypeGet the type annotation of this node, if any. The type annotation is represented as SchemaType object.Types derived from a DTD are not reflected in the result of this method. - Specified by:
- getSchemaTypein interface- NodeInfo
- Overrides:
- getSchemaTypein class- TinyNodeImpl
- Returns:
- For element and attribute nodes: the type annotation derived from schema validation (defaulting to xs:untyped and xs:untypedAtomic in the absence of schema validation). For comments, text nodes, processing instructions, and namespaces: null. For document nodes, either xs:untyped if the document has not been validated, or xs:anyType if it has.
- Since:
- 9.4
 
- 
atomizeGet the typed value.- Returns:
- the typed value. It will be a Value representing a sequence whose items are atomic values.
- Throws:
- XPathException- if the node has no typed value, for example if it is an element node with element-only content
 
- 
getDeclaredNamespacesGet all namespace undeclarations and undeclarations defined on this element.- Specified by:
- getDeclaredNamespacesin interface- NodeInfo
- Overrides:
- getDeclaredNamespacesin class- TinyNodeImpl
- Parameters:
- buffer- If this is non-null, and the result array fits in this buffer, then the result may overwrite the contents of this array, to avoid the cost of allocating a new array on the heap.
- Returns:
- An array of objects representing the namespace declarations and undeclarations present on this element. For a node other than an element, return null. Otherwise, the returned array is a sequence of namespace binding objects (essentially prefix/uri pairs) If the URI is null, then this is a namespace undeclaration rather than a declaration. The XML namespace is never included in the list. If the supplied array is larger than required, then the first unused entry will be set to null.
 
- 
getAllNamespacesDescription copied from class:TinyNodeImplGet all the namespace bindings that are in-scope for this element.For an element return all the prefix-to-uri bindings that are in scope. This may include a binding to the default namespace (represented by a prefix of ""). It will never include "undeclarations" - that is, the namespace URI will never be empty; the effect of an undeclaration is to remove a binding from the in-scope namespaces, not to add anything. For a node other than an element, returns null. - Specified by:
- getAllNamespacesin interface- NodeInfo
- Overrides:
- getAllNamespacesin class- TinyNodeImpl
- Returns:
- the in-scope namespaces for an element, or null for any other kind of node.
 
- 
hasUniformNamespacespublic boolean hasUniformNamespaces()Ask whether the element is the root of a subtree in which no descendant element has any local namespace declarations or undeclarations; that is, all elements in the subtree have the same in-scope namespace bindings.- Returns:
- true if it is known that no descendant elements have in-scope namespaces different from those of this element.
 
- 
getAttributeValueGet the string value of a given attribute of this node- Specified by:
- getAttributeValuein interface- NodeInfo
- Overrides:
- getAttributeValuein class- TinyNodeImpl
- Parameters:
- uri- the namespace URI of the attribute name. Supply the empty string for an attribute that is in no namespace
- local- the local part of the attribute name.
- Returns:
- the attribute value if it exists, or null if it does not exist. Always returns null if this node is not an element.
- Since:
- 9.4
 
- 
getAttributeValueGet the value of the attribute with a given fingerprint.- Parameters:
- fp- the fingerprint of the required attribute
- Returns:
- the string value of the attribute if present, or null if absent
 
- 
copyCopy this node to a given receiver- Parameters:
- receiver- the destination of the copy
- copyOptions- determines handling of namespaces, etc
- location- location information associated with the event
- Throws:
- XPathException- if any downstream error occurs
 
- 
checkNotNamespaceSensitiveElementCheck whether the content of an element is namespace-sensitive- Parameters:
- type- the type annotation of the node
- nodeNr- the node number of the element
- Throws:
- XPathException- if an error occurs
 
- 
isIdpublic boolean isId()Determine whether this node has the is-id property- Specified by:
- isIdin interface- NodeInfo
- Overrides:
- isIdin class- TinyNodeImpl
- Returns:
- true if the node is an ID
 
- 
isIdrefpublic boolean isIdref()Determine whether this node has the is-idref property- Specified by:
- isIdrefin interface- NodeInfo
- Overrides:
- isIdrefin class- TinyNodeImpl
- Returns:
- true if the node is an IDREF or IDREFS element or attribute
 
 
-