All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.xmlpull.infoset.xpath.jaxen.XPath Maven / Gradle / Ivy

There is a newer version: 1.2.8
Show newest version
/*
 * $Header: /l/extreme/cvs/codes/xpp5/xis5/infoset_xpath_jaxen/org/xmlpull/infoset/xpath/jaxen/XPath.java,v 1.1 2005/05/16 23:59:18 aslom Exp $
 * $Revision: 1.1 $
 * $Date: 2005/05/16 23:59:18 $
 *
 * ====================================================================
 *
 * Copyright (C) 2000-2002 bob mcwhirter & James Strachan.
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions, and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions, and the disclaimer that follows 
 *    these conditions in the documentation and/or other materials 
 *    provided with the distribution.
 *
 * 3. The name "Jaxen" must not be used to endorse or promote products
 *    derived from this software without prior written permission.  For
 *    written permission, please contact [email protected].
 * 
 * 4. Products derived from this software may not be called "Jaxen", nor
 *    may "Jaxen" appear in their name, without prior written permission
 *    from the Jaxen Project Management ([email protected]).
 * 
 * In addition, we request (but do not require) that you include in the 
 * end-user documentation provided with the redistribution and/or in the 
 * software itself an acknowledgement equivalent to the following:
 *     "This product includes software developed by the
 *      Jaxen Project (http://www.jaxen.org/)."
 * Alternatively, the acknowledgment may be graphical using the logos 
 * available at http://www.jaxen.org/
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE Jaxen AUTHORS OR THE PROJECT
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 *
 * ====================================================================
 * This software consists of voluntary contributions made by many 
 * individuals on behalf of the Jaxen Project and was originally 
 * created by bob mcwhirter  and 
 * James Strachan .  For more information on the 
 * Jaxen Project, please see .
 * 
 * $Id: XPath.java,v 1.1 2005/05/16 23:59:18 aslom Exp $
 */


package org.xmlpull.infoset.xpath.jaxen;

import java.util.List;

/** 
 * Defines the interface to an object which represents an XPath 1.0 expression which
 * can be evaluated against a variety of different XML object models.
 *
 * 

* Most of the evaluation methods take a context object. This is typically a * node or node set object (which is typically a List of node objects) or * a Jaxen Context object. * A null context is allowed, meaning that * there is no XML nodes on which to evaluate. *

* * @see org.jaxen.dom4j.Dom4jXPath XPath for dom4j * @see org.jaxen.jdom.JDOMXPath XPath for JDOM * @see org.jaxen.dom.DOMXPath XPath for W3C DOM * @see org.jaxen.exml.ElectricXPath XPath for Electric XML * * @author bob mcwhirter * @author James Strachan */ public interface XPath { /** Evaluate this XPath against a given context. * *

* The context of evaluation my be a document, * an element, or a set of elements. *

* *

* If the expression evaluates to a single primitive * (String, Number or Boolean) type, it is returned * directly. Otherwise, the returned value is a * List (a node-set, in the terms of the * specification) of values. *

* *

* When using this method, one must be careful to * test the class of the returned objects, and of * each of the composite members if a List * is returned. If the returned members are XML entities, * they will be the actual Document, * Element or Attribute objects * as defined by the concrete XML object-model implementation, * directly from the context document. This does not * return copies of anything, but merely returns * references to entities within the source document. *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The result of evaluating the XPath expression * against the supplied context. */ public Object evaluate(Object context) throws JaxenException; /** Select all nodes that are selectable by this XPath * expression. If multiple nodes match, multiple nodes * will be returned. * *

* NOTE: In most cases, nodes will be returned * in document-order, as defined by the XML Canonicalization * specification. The exception occurs when using XPath * expressions involving the union operator * (denoted with the pipe '|' character). *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The node-set of all items selected * by this XPath expression. * * @see #selectSingleNode */ public List selectNodes(Object context) throws JaxenException; /** Select only the first node that is selectable by this XPath * expression. If multiple nodes match, only one node will be * returned. * * NOTE: In most cases, the selected node will be the first * selectable node in document-order, as defined by the XML Canonicalization * specification. The exception occurs when using XPath * expressions involving the union operator * (denoted with the pipe '|' character). *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The node-set of all items selected * by this XPath expression. * * @see #selectNodes */ public Object selectSingleNode(Object context) throws JaxenException; /** Retrieve a string-value interpretation of this XPath * expression when evaluated against a given context. * *

* The string-value of the expression is determined per * the string(..) core function as defined * in the XPath specification. This means that an expression * that selects more than one nodes will return the string value * of the first node in the node set.. *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The string-value interpretation of this expression. * * @deprecated As of Jaxen 1.0 RC1 please use * {@link #stringValueOf(Object) instead} */ public String valueOf(Object context) throws JaxenException; /** Retrieve a string-value interpretation of this XPath * expression when evaluated against a given context. * *

* The string-value of the expression is determined per * the string(..) core function as defined * in the XPath specification. This means that an expression * that selects more than one nodes will return the string value * of the first node in the node set.. *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The string-value interpretation of this expression. */ public String stringValueOf(Object context) throws JaxenException; /** Retrieve a boolean-value interpretation of this XPath * expression when evaluated against a given context. * *

* The boolean-value of the expression is determined per * the boolean(..) core function as defined * in the XPath specification. This means that an expression * that selects zero nodes will return false, * while an expression that selects one-or-more nodes will * return true. *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The boolean-value interpretation of this expression. */ public boolean booleanValueOf(Object context) throws JaxenException; /** Retrieve a number-value interpretation of this XPath * expression when evaluated against a given context. * *

* The number-value of the expression is determined per * the number(..) core function as defined * in the XPath specification. This means that if this * expression selects multiple nodes, the number-value * of the first node is returned. *

* * @param The node, nodeset or Context object for evaluation. This value can be null * * @return The number-value interpretation of this expression. */ public Number numberValueOf(Object context) throws JaxenException; // Helpers /** Add a namespace prefix-to-URI mapping for this XPath * expression. * *

* Namespace prefix-to-URI mappings in an XPath are independant * of those used within any document. Only the mapping explicitly * added to this XPath will be available for resolving the * XPath expression. *

* *

* This is a convenience method for adding mappings to the * default {@link NamespaceContext} in place for this XPath. * If you have installed a specific custom NamespaceContext, * then this method will throw a JaxenException. *

* * @param prefix The namespace prefix. * @param uri The namespace URI. * * @throws JaxenException If a NamespaceContext * used by this XPath has been explicitly installed. */ public void addNamespace(String prefix, String uri) throws JaxenException; // ------------------------------------------------------------ // ------------------------------------------------------------ // Properties // ------------------------------------------------------------ // ------------------------------------------------------------ /** Set a NamespaceContext for use with this * XPath expression. * *

* A NamespaceContext is responsible for translating * namespace prefixes within the expression into namespace URIs. *

* * @param namespaceContext The NamespaceContext to * install for this expression. * * @see NamespaceContext * @see NamespaceContext#translateNamespacePrefixToUri */ public void setNamespaceContext(NamespaceContext namespaceContext); /** Set a FunctionContext for use with this XPath * expression. * *

* A FunctionContext is responsible for resolving * all function calls used within the expression. *

* * @param functionContext The FunctionContext to * install for this expression. * * @see FunctionContext * @see FunctionContext#getFunction */ public void setFunctionContext(FunctionContext functionContext); /** Set a VariableContext for use with this XPath * expression. * *

* A VariableContext is responsible for resolving * all variables referenced within the expression. *

* * @param variableContext The VariableContext to * install for this expression. * * @see VariableContext * @see VariableContext#getVariableValue */ public void setVariableContext(VariableContext variableContext); /** Retrieve the NamespaceContext used by this XPath * expression. * *

* A FunctionContext is responsible for resolving * all function calls used within the expression. *

* *

* If this XPath expression has not previously had a NamespaceContext * installed, a new default NamespaceContext will be created, * installed and returned. *

* * @return The NamespaceContext used by this expression. * * @see NamespaceContext */ public NamespaceContext getNamespaceContext(); /** Retrieve the FunctionContext used by this XPath * expression. * *

* A FunctionContext is responsible for resolving * all function calls used within the expression. *

* *

* If this XPath expression has not previously had a FunctionContext * installed, a new default FunctionContext will be created, * installed and returned. *

* * @return The FunctionContext used by this expression. * * @see FunctionContext */ public FunctionContext getFunctionContext(); /** Retrieve the VariableContext used by this XPath * expression. * *

* A VariableContext is responsible for resolving * all variables referenced within the expression. *

* *

* If this XPath expression has not previously had a VariableContext * installed, a new default VariableContext will be created, * installed and returned. *

* * @return The VariableContext used by this expression. * * @see VariableContext */ public VariableContext getVariableContext(); /** Retrieve the XML object-model-specific {@link Navigator} * for us in evaluating this XPath expression. * * @return The implementation-specific Navigator. */ public Navigator getNavigator(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy