Package org.dom4j.xpath
Class DefaultXPath
- java.lang.Object
-
- org.dom4j.xpath.DefaultXPath
-
- All Implemented Interfaces:
java.io.Serializable
,NodeFilter
,XPath
public class DefaultXPath extends java.lang.Object implements XPath, NodeFilter, java.io.Serializable
- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description DefaultXPath(java.lang.String text)
Construct an XPath
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
booleanValueOf(java.lang.Object context)
Retrieve a boolean-value interpretation of this XPath expression when evaluated against a given context.java.lang.Object
evaluate(java.lang.Object context)
evaluate
evaluates an XPath expression and returns the result as anObject
.protected java.lang.Object
getCompareValue(Node node)
DOCUMENT ME!org.jaxen.FunctionContext
getFunctionContext()
DOCUMENT ME!org.jaxen.NamespaceContext
getNamespaceContext()
DOCUMENT ME!java.lang.String
getText()
Retrieve the textual XPath string used to initialize this Objectorg.jaxen.VariableContext
getVariableContext()
DOCUMENT ME!protected void
handleJaxenException(org.jaxen.JaxenException exception)
boolean
matches(Node node)
matches
returns true if the given node matches the XPath expression.java.lang.Number
numberValueOf(java.lang.Object context)
numberValueOf
evaluates an XPath expression and returns the numeric value of the XPath expression if the XPath expression results is a number, or null if the result is not a number.protected static org.jaxen.XPath
parse(java.lang.String text)
protected void
removeDuplicates(java.util.List<Node> list, java.util.Map<Node,java.lang.Object> sortValues)
Removes items from the list which have duplicate valuesjava.util.List<Node>
selectNodes(java.lang.Object context)
java.util.List<Node>
selectNodes(java.lang.Object context, XPath sortXPath)
java.util.List<Node>
selectNodes(java.lang.Object context, XPath sortXPath, boolean distinct)
java.lang.Object
selectObject(java.lang.Object context)
selectObject
evaluates an XPath expression and returns the result as anObject
.Node
selectSingleNode(java.lang.Object context)
void
setFunctionContext(org.jaxen.FunctionContext functionContext)
Sets the function context to be used when evaluating XPath expressionsvoid
setNamespaceContext(org.jaxen.NamespaceContext namespaceContext)
Sets the namespace context to be used when evaluating XPath expressionsvoid
setNamespaceURIs(java.util.Map<java.lang.String,java.lang.String> map)
Sets the current NamespaceContext from a Map where the keys are the String namespace prefixes and the values are the namespace URIs.protected void
setNSContext(java.lang.Object context)
void
setVariableContext(org.jaxen.VariableContext variableContext)
Sets the variable context to be used when evaluating XPath expressionsvoid
sort(java.util.List<Node> list)
sort
sorts the given List of Nodes using this XPath expression as aComparator
.void
sort(java.util.List<Node> list, boolean distinct)
sort
sorts the given List of Nodes using this XPath expression as aComparator
and optionally removing duplicates.protected void
sort(java.util.List<Node> list, java.util.Map<Node,java.lang.Object> sortValues)
Sorts the list based on the sortValues for each nodejava.lang.String
toString()
java.lang.String
valueOf(java.lang.Object context)
valueOf
evaluates this XPath expression and returns the textual representation of the results using the XPath string() function.
-
-
-
Constructor Detail
-
DefaultXPath
public DefaultXPath(java.lang.String text) throws InvalidXPathException
Construct an XPath- Parameters:
text
- DOCUMENT ME!- Throws:
InvalidXPathException
- DOCUMENT ME!
-
-
Method Detail
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
getText
public java.lang.String getText()
Retrieve the textual XPath string used to initialize this Object
-
getFunctionContext
public org.jaxen.FunctionContext getFunctionContext()
Description copied from interface:XPath
DOCUMENT ME!- Specified by:
getFunctionContext
in interfaceXPath
- Returns:
- the current function context
-
setFunctionContext
public void setFunctionContext(org.jaxen.FunctionContext functionContext)
Description copied from interface:XPath
Sets the function context to be used when evaluating XPath expressions- Specified by:
setFunctionContext
in interfaceXPath
- Parameters:
functionContext
- DOCUMENT ME!
-
getNamespaceContext
public org.jaxen.NamespaceContext getNamespaceContext()
Description copied from interface:XPath
DOCUMENT ME!- Specified by:
getNamespaceContext
in interfaceXPath
- Returns:
- the current namespace context
-
setNamespaceURIs
public void setNamespaceURIs(java.util.Map<java.lang.String,java.lang.String> map)
Description copied from interface:XPath
Sets the current NamespaceContext from a Map where the keys are the String namespace prefixes and the values are the namespace URIs. For example:Map uris = new HashMap(); uris.put("SOAP-ENV", "http://schemas.xmlsoap.org/soap/envelope/"); uris.put("m", "urn:xmethodsBabelFish"); XPath xpath = document .createXPath("SOAP-ENV:Envelope/SOAP-ENV:Body/m:BabelFish"); xpath.setNamespaceURIs(uris); Node babelfish = xpath.selectSingleNode(document);
- Specified by:
setNamespaceURIs
in interfaceXPath
- Parameters:
map
- the map containing the namespace mappings
-
setNamespaceContext
public void setNamespaceContext(org.jaxen.NamespaceContext namespaceContext)
Description copied from interface:XPath
Sets the namespace context to be used when evaluating XPath expressions- Specified by:
setNamespaceContext
in interfaceXPath
- Parameters:
namespaceContext
- DOCUMENT ME!
-
getVariableContext
public org.jaxen.VariableContext getVariableContext()
Description copied from interface:XPath
DOCUMENT ME!- Specified by:
getVariableContext
in interfaceXPath
- Returns:
- the current variable context
-
setVariableContext
public void setVariableContext(org.jaxen.VariableContext variableContext)
Description copied from interface:XPath
Sets the variable context to be used when evaluating XPath expressions- Specified by:
setVariableContext
in interfaceXPath
- Parameters:
variableContext
- DOCUMENT ME!
-
evaluate
public java.lang.Object evaluate(java.lang.Object context)
Description copied from interface:XPath
-
selectObject
public java.lang.Object selectObject(java.lang.Object context)
Description copied from interface:XPath
selectObject
evaluates an XPath expression and returns the result as anObject
. The object returned can either be aList
ofNode
instances, aNode
instance, aString
or aNumber
instance depending on the XPath expression.- Specified by:
selectObject
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPath- Returns:
- the value of the XPath expression as a
List
ofNode
instances, aNode
instance, aString
or aNumber
instance depending on the XPath expression.
-
selectNodes
public java.util.List<Node> selectNodes(java.lang.Object context)
Description copied from interface:XPath
selectNodes
performs this XPath expression on the givenNode
orList
ofNode
s instances appending all the results together into a single list.- Specified by:
selectNodes
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPath- Returns:
- the results of all the XPath evaluations as a single list
-
selectNodes
public java.util.List<Node> selectNodes(java.lang.Object context, XPath sortXPath)
Description copied from interface:XPath
selectNodes
evaluates the XPath expression on the givenNode
orList
ofNode
s and returns the result as aList
ofNode
s sorted by the sort XPath expression.- Specified by:
selectNodes
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPathsortXPath
- is the XPath expression to sort by- Returns:
- a list of
Node
instances
-
selectNodes
public java.util.List<Node> selectNodes(java.lang.Object context, XPath sortXPath, boolean distinct)
Description copied from interface:XPath
selectNodes
evaluates the XPath expression on the givenNode
orList
ofNode
s and returns the result as aList
ofNode
s sorted by the sort XPath expression.- Specified by:
selectNodes
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPathsortXPath
- is the XPath expression to sort bydistinct
- specifies whether or not duplicate values of the sort expression are allowed. If this parameter is true then only distinct sort expressions values are included in the result- Returns:
- a list of
Node
instances
-
selectSingleNode
public Node selectSingleNode(java.lang.Object context)
Description copied from interface:XPath
selectSingleNode
evaluates this XPath expression on the givenNode
orList
ofNode
s and returns the result as a singleNode
instance.- Specified by:
selectSingleNode
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPath- Returns:
- a single matching
Node
instance
-
valueOf
public java.lang.String valueOf(java.lang.Object context)
Description copied from interface:XPath
valueOf
evaluates this XPath expression and returns the textual representation of the results using the XPath string() function.
-
numberValueOf
public java.lang.Number numberValueOf(java.lang.Object context)
Description copied from interface:XPath
numberValueOf
evaluates an XPath expression and returns the numeric value of the XPath expression if the XPath expression results is a number, or null if the result is not a number.- Specified by:
numberValueOf
in interfaceXPath
- Parameters:
context
- is either a node or a list of nodes on which to evalute the XPath- Returns:
- the numeric result of the XPath expression or null if the result is not a number.
-
booleanValueOf
public boolean booleanValueOf(java.lang.Object context)
Description copied from interface:XPath
Retrieve a boolean-value interpretation of this XPath expression when evaluated against a given context. The boolean-value of the expression is determined per theboolean(..)
core function as defined in the XPath specification. This means that an expression that selects zero nodes will returnfalse
, while an expression that selects one-or-more nodes will returntrue
.- Specified by:
booleanValueOf
in interfaceXPath
- Parameters:
context
- The node, nodeset or Context object for evaluation. This value can be null- Returns:
- The boolean-value interpretation of this expression.
-
sort
public void sort(java.util.List<Node> list)
sort
sorts the given List of Nodes using this XPath expression as aComparator
.
-
sort
public void sort(java.util.List<Node> list, boolean distinct)
sort
sorts the given List of Nodes using this XPath expression as aComparator
and optionally removing duplicates.
-
matches
public boolean matches(Node node)
Description copied from interface:XPath
matches
returns true if the given node matches the XPath expression. To be more precise when evaluating this XPath expression on the given node the result set must include the node.- Specified by:
matches
in interfaceNodeFilter
- Specified by:
matches
in interfaceXPath
- Parameters:
node
- DOCUMENT ME!- Returns:
- true if the given node matches this XPath expression
-
sort
protected void sort(java.util.List<Node> list, java.util.Map<Node,java.lang.Object> sortValues)
Sorts the list based on the sortValues for each node- Parameters:
list
- DOCUMENT ME!sortValues
- DOCUMENT ME!
-
removeDuplicates
protected void removeDuplicates(java.util.List<Node> list, java.util.Map<Node,java.lang.Object> sortValues)
Removes items from the list which have duplicate values- Parameters:
list
- DOCUMENT ME!sortValues
- DOCUMENT ME!
-
getCompareValue
protected java.lang.Object getCompareValue(Node node)
DOCUMENT ME!- Parameters:
node
- DOCUMENT ME!- Returns:
- the node expression used for sorting comparisons
-
parse
protected static org.jaxen.XPath parse(java.lang.String text)
-
setNSContext
protected void setNSContext(java.lang.Object context)
-
handleJaxenException
protected void handleJaxenException(org.jaxen.JaxenException exception) throws XPathException
- Throws:
XPathException
-
-