Class NodePointer
java.lang.Object
org.apache.commons.jxpath.ri.model.NodePointer
- All Implemented Interfaces:
- Serializable,- Cloneable,- Comparable,- Pointer
- Direct Known Subclasses:
- CollectionPointer,- ContainerPointer,- DOMAttributePointer,- DOMNodePointer,- JDOMAttributePointer,- JDOMNamespacePointer,- JDOMNodePointer,- LangAttributePointer,- NamespacePointer,- PropertyOwnerPointer,- PropertyPointer,- VariablePointer
Common superclass for Pointers of all kinds. A NodePointer maps to a deterministic XPath that represents the location of a node in an object graph. This
 XPath uses only simple axes: child, namespace and attribute and only simple, context-independent predicates.
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected intIndex for this NodePointer.protected LocaleLocaleprotected NodePointerParent pointerstatic final StringConstant to indicate unknown namespacestatic final intWhole collection index.
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedNodePointer(NodePointer parent) Constructs a new NodePointer.protectedNodePointer(NodePointer parent, Locale locale) Constructs a new NodePointer.
- 
Method SummaryModifier and TypeMethodDescriptionasPath()Returns an XPath that maps to this Pointer.attributeIterator(QName qname) Returns a NodeIterator that iterates over all attributes of the current node matching the supplied node name (could have a wildcard).childIterator(NodeTest test, boolean reverse, NodePointer startWith) Returns a NodeIterator that iterates over all children or all children that match the given NodeTest, starting with the specified one.clone()Clone this NodePointer.abstract intcompareChildNodePointers(NodePointer pointer1, NodePointer pointer2) Compares two child NodePointers and returns a positive number, zero or a positive number according to the order of the pointers.intcreateAttribute(JXPathContext context, QName qName) Called to create a non-existing attributecreateChild(JXPathContext context, QName qName, int index) Called by a child pointer when it needs to create a parent object for a non-existent collection element.createChild(JXPathContext context, QName qName, int index, Object value) Called by a child pointer if that child needs to assign the value supplied in the createPath(context, value) call to a non-existent node.createPath(JXPathContext context) Called by a child pointer when it needs to create a parent object.createPath(JXPathContext context, Object value) Called directly by JXPathContext.protected StringReturn a string escaping single and double quotes.protected AbstractFactorygetAbstractFactory(JXPathContext context) Gets the AbstractFactory associated with the specified JXPathContext.abstract ObjectGets the value represented by the pointer before indexing.protected StringGets the default ns uriabstract ObjectReturns the object the pointer points to; does not convert it to a "canonical" type.Gets the immediate parent pointer.Gets this instance by default, subclasses can return a pointer for the immediately contained value.intgetIndex()If the pointer represents a collection, the index identifies an element of that collection.abstract intIf the pointer represents a collection (or collection element), returns the length of the collection.If the Pointer has a parent, returns the parent's locale; otherwise returns the locale specified when this Pointer was created.abstract QNamegetName()Gets the name of this node.Gets the NamespaceResolver associated with this NodePointer.Returns the namespace URI associated with this Pointer.getNamespaceURI(String prefix) Decodes a namespace prefix to the corresponding URI.getNode()Returns the object the pointer points to; does not convert it to a "canonical" type.getNodeSetByKey(JXPathContext context, String key, Object value) Find a NodeSet by key/value.Deprecated.1.1 Please use getNode()Gets the parent pointer.getPointerByID(JXPathContext context, String id) Locates a node by ID.getPointerByKey(JXPathContext context, String key, String value) Locates a node by key and value.Gets the root node.getValue()By default, returnsgetNode(), can be overridden to return a "canonical" value, like for instance a DOM element should return its string value.If this pointer manages a transparent container, like a variable, this method returns the pointer to the contents.voidHandle a Throwable using an installed ExceptionHandler, if available.voidhandle(Throwable t, NodePointer originator) Handle a Throwable using an installed ExceptionHandler, if available.booleanisActual()An actual pointer points to an existing part of an object graph, even if it is null.booleanReturns true if the pointer represents the "attribute::" axis.abstract booleanReturnstrueif the value of the pointer is an array or a Collection.booleanIf true, this node is auxiliary and can only be used as an intermediate in the chain of pointers.protected booleanisDefaultNamespace(String prefix) Returns true if the supplied prefix represents the default namespace in the context of the current node.booleanisLanguage(String lang) Check whether our locale matches the specified language.abstract booleanisLeaf()If true, this node does not have childrenbooleanisNode()Deprecated.Please use !booleanisRoot()Returns true if this Pointer has no parent.Returns a NodeIterator that iterates over all namespaces of the value currently pointed at.namespacePointer(String namespace) Returns a NodePointer for the specified namespace.static NodePointernewChildNodePointer(NodePointer parent, QName qName, Object bean) Allocates an new child NodePointer by iterating through all installed NodePointerFactories until it finds one that can create a pointer.static NodePointernewNodePointer(QName qName, Object bean, Locale locale) Allocates an entirely new NodePointer by iterating through all installed NodePointerFactories until it finds one that can create a pointer.voidPrint internal structure of a pointer for debuggingvoidremove()Remove the node of the object graph this pointer points to.voidsetAttribute(boolean attribute) Sets to true if the pointer represents the "attribute::" axis.voidsetExceptionHandler(ExceptionHandler exceptionHandler) Sets the exceptionHandler of this NodePointer.voidsetIndex(int index) Sets the index of this NodePointer.voidsetNamespaceResolver(NamespaceResolver namespaceResolver) Sets the NamespaceResolver for this NodePointer.abstract voidConverts the value to the required type and changes the corresponding object to that value.booleanChecks if this Pointer matches the supplied NodeTest.toString()static NodePointerverify(NodePointer nodePointer) Verify the structure of a given NodePointer.
- 
Field Details- 
WHOLE_COLLECTIONWhole collection index.- See Also:
 
- 
UNKNOWN_NAMESPACEConstant to indicate unknown namespace- See Also:
 
- 
indexIndex for this NodePointer.
- 
parentParent pointer
- 
localeLocale
 
- 
- 
Constructor Details- 
NodePointerConstructs a new NodePointer.- Parameters:
- parent- Pointer
 
- 
NodePointerConstructs a new NodePointer.- Parameters:
- parent- Pointer
- locale- Locale
 
 
- 
- 
Method Details- 
newChildNodePointerAllocates an new child NodePointer by iterating through all installed NodePointerFactories until it finds one that can create a pointer.- Parameters:
- parent- pointer
- qName- QName
- bean- Object
- Returns:
- NodePointer
 
- 
newNodePointerAllocates an entirely new NodePointer by iterating through all installed NodePointerFactories until it finds one that can create a pointer.- Parameters:
- qName- QName
- bean- Object
- locale- Locale
- Returns:
- NodePointer
 
- 
verifyVerify the structure of a given NodePointer.- Parameters:
- nodePointer- to check
- Returns:
- nodePointer
- Throws:
- JXPathNotFoundException- Thrown when there is no value at the NodePointer.
 
- 
asPathReturns an XPath that maps to this Pointer.
- 
attributeIteratorReturns a NodeIterator that iterates over all attributes of the current node matching the supplied node name (could have a wildcard). May return null if the object does not support the attributes.- Parameters:
- qname- the attribute name to test
- Returns:
- NodeIterator
 
- 
childIteratorReturns a NodeIterator that iterates over all children or all children that match the given NodeTest, starting with the specified one.- Parameters:
- test- NodeTest to filter children
- reverse- specified iteration direction
- startWith- the NodePointer to start with
- Returns:
- NodeIterator
 
- 
cloneClone this NodePointer.
- 
compareChildNodePointersCompares two child NodePointers and returns a positive number, zero or a positive number according to the order of the pointers.- Parameters:
- pointer1- first pointer to be compared
- pointer2- second pointer to be compared
- Returns:
- int per Java comparison conventions
 
- 
compareTo- Specified by:
- compareToin interface- Comparable
 
- 
createAttributeCalled to create a non-existing attribute- Parameters:
- context- the owning JXPathCOntext
- qName- the QName at which an attribute should be created
- Returns:
- created NodePointer
 
- 
createChildCalled by a child pointer when it needs to create a parent object for a non-existent collection element. It may have to expand the collection, then create an element object and return a new pointer describing the newly created element.- Parameters:
- context- the owning JXPathCOntext
- qName- the QName at which a child should be created
- index- child index.
- Returns:
- created NodePointer
 
- 
createChildCalled by a child pointer if that child needs to assign the value supplied in the createPath(context, value) call to a non-existent node. This method may have to expand the collection in order to assign the element.- Parameters:
- context- the owning JXPathCOntext
- qName- the QName at which a child should be created
- index- child index.
- value- node value to set
- Returns:
- created NodePointer
 
- 
createPathCalled by a child pointer when it needs to create a parent object. Must create an object described by this pointer and return a new pointer that properly describes the new object.- Parameters:
- context- the owning JXPathContext
- Returns:
- created NodePointer
 
- 
createPathCalled directly by JXPathContext. Must create path and set value.- Parameters:
- context- the owning JXPathContext
- value- the new value to set
- Returns:
- created NodePointer
 
- 
escapeReturn a string escaping single and double quotes.- Parameters:
- string- string to treat
- Returns:
- string with any necessary changes made.
 
- 
getAbstractFactoryGets the AbstractFactory associated with the specified JXPathContext.- Parameters:
- context- JXPathContext
- Returns:
- AbstractFactory
 
- 
getBaseValueGets the value represented by the pointer before indexing. So, if the node represents an element of a collection, this method returns the collection itself.- Returns:
- Object value
 
- 
getDefaultNamespaceURIGets the default ns uri- Returns:
- String uri
 
- 
getImmediateNodeReturns the object the pointer points to; does not convert it to a "canonical" type.- Returns:
- Object node
 
- 
getImmediateParentPointerGets the immediate parent pointer.- Returns:
- NodePointer
 
- 
getImmediateValuePointerGets this instance by default, subclasses can return a pointer for the immediately contained value.- Returns:
- NodePointer is either thisor a pointer for the immediately contained value.
- See Also:
 
- 
getIndexIf the pointer represents a collection, the index identifies an element of that collection. The default value ofindexisWHOLE_COLLECTION, which just means that the pointer is not indexed at all. Note: the index on NodePointer starts with 0, not 1.- Returns:
- the index.
 
- 
getLengthIf the pointer represents a collection (or collection element), returns the length of the collection. Otherwise returns 1 (even if the value is null).- Returns:
- the length.
 
- 
getLocaleIf the Pointer has a parent, returns the parent's locale; otherwise returns the locale specified when this Pointer was created.- Returns:
- Locale for this NodePointer
 
- 
getNameGets the name of this node. Can be null.- Returns:
- QName The name of this node. Can be null.
 
- 
getNamespaceResolverGets the NamespaceResolver associated with this NodePointer.- Returns:
- NamespaceResolver
 
- 
getNamespaceURIReturns the namespace URI associated with this Pointer.- Returns:
- String uri
 
- 
getNamespaceURIDecodes a namespace prefix to the corresponding URI.- Parameters:
- prefix- prefix to decode
- Returns:
- String uri
 
- 
getNodeReturns the object the pointer points to; does not convert it to a "canonical" type. Opens containers, properties etc and returns the ultimate contents.
- 
getNodeSetByKeyFind a NodeSet by key/value.- Parameters:
- context- owning JXPathContext
- key- key to search for
- value- value to match
- Returns:
- NodeSet found
 
- 
getNodeValueDeprecated.1.1 Please use getNode()Returns the object the pointer points to; does not convert it to a "canonical" type.- Returns:
- Object node value
 
- 
getParentGets the parent pointer.- Returns:
- NodePointer
 
- 
getPointerByIDLocates a node by ID.- Parameters:
- context- JXPathContext owning context
- id- String id
- Returns:
- Pointer found
 
- 
getPointerByKeyLocates a node by key and value.- Parameters:
- context- owning JXPathContext
- key- key to search for
- value- value to match
- Returns:
- Pointer found
 
- 
getRootNodeGets the root node.- Specified by:
- getRootNodein interface- Pointer
- Returns:
- Object value of this pointer's root (top parent).
 
- 
getValueBy default, returnsgetNode(), can be overridden to return a "canonical" value, like for instance a DOM element should return its string value.
- 
getValuePointerIf this pointer manages a transparent container, like a variable, this method returns the pointer to the contents. Only an auxiliary (non-node) pointer can (and should) return a value pointer other than itself. Note that you probably don't want to overridegetValuePointer()directly. Override thegetImmediateValuePointer()method instead. ThegetValuePointer()method is callsgetImmediateValuePointer()and, if the result is notthis, invokesgetValuePointer()recursively. The idea here is to open all nested containers. Let's say we have a container within a container within a container. ThegetValuePointer()method should then open all those containers and return the pointer to the ultimate contents. It does so with the above recursion.- Returns:
- NodePointer
 
- 
handleHandle a Throwable using an installed ExceptionHandler, if available. Public to facilitate calling for RI support; not truly intended for public consumption.- Parameters:
- t- to handle
 
- 
handleHandle a Throwable using an installed ExceptionHandler, if available. Public to facilitate calling for RI support; not truly intended for public consumption.- Parameters:
- t- to handle
- originator- context
 
- 
isActualAn actual pointer points to an existing part of an object graph, even if it is null. A non-actual pointer represents a part that does not exist at all. For instance consider the pointer "/address/street". If both address and street are not null, the pointer is actual. If address is not null, but street is null, the pointer is still actual. If address is null, the pointer is not actual. (In JavaBeans) if address is not a property of the root bean, a Pointer for this path cannot be obtained at all - actual or otherwise.- Returns:
- boolean
 
- 
isAttributeReturns true if the pointer represents the "attribute::" axis.- Returns:
- boolean
 
- 
isCollectionReturnstrueif the value of the pointer is an array or a Collection.- Returns:
- boolean
 
- 
isContainerIf true, this node is auxiliary and can only be used as an intermediate in the chain of pointers.- Returns:
- boolean
 
- 
isDefaultNamespaceReturns true if the supplied prefix represents the default namespace in the context of the current node.- Parameters:
- prefix- the prefix to check
- Returns:
- trueif prefix is default
 
- 
isLanguageCheck whether our locale matches the specified language.- Parameters:
- lang- String language to check
- Returns:
- true if the selected locale name starts with the specified prefix lang, case-insensitive.
 
- 
isLeafIf true, this node does not have children- Returns:
- boolean
 
- 
isNodeDeprecated.Please use !isContainer()Tests whether this pointer is considered to be a node.- Returns:
- boolean
 
- 
isRootReturns true if this Pointer has no parent.- Returns:
- boolean
 
- 
namespaceIteratorReturns a NodeIterator that iterates over all namespaces of the value currently pointed at. May return null if the object does not support the namespaces.- Returns:
- NodeIterator
 
- 
namespacePointerReturns a NodePointer for the specified namespace. Will return null if namespaces are not supported. Will return UNKNOWN_NAMESPACE if there is no such namespace.- Parameters:
- namespace- incoming namespace
- Returns:
- NodePointer for namespace
 
- 
printPointerChainPrint internal structure of a pointer for debugging
- 
removeRemove the node of the object graph this pointer points to.
- 
setAttributeSets to true if the pointer represents the "attribute::" axis.- Parameters:
- attribute- boolean
 
- 
setExceptionHandlerSets the exceptionHandler of this NodePointer.- Parameters:
- exceptionHandler- the ExceptionHandler to set
 
- 
setIndexSets the index of this NodePointer.- Parameters:
- index- int
 
- 
setNamespaceResolverSets the NamespaceResolver for this NodePointer.- Parameters:
- namespaceResolver- NamespaceResolver
 
- 
setValueConverts the value to the required type and changes the corresponding object to that value.
- 
testNodeChecks if this Pointer matches the supplied NodeTest.- Parameters:
- test- the NodeTest to execute
- Returns:
- true if a match
 
- 
toString
 
-