org.exist.xmldb
Class LocalXPathQueryService

java.lang.Object
  extended by org.exist.xmldb.LocalXPathQueryService
All Implemented Interfaces:
XPathQueryServiceImpl, org.xmldb.api.base.Configurable, org.xmldb.api.base.Service, org.xmldb.api.modules.XPathQueryService, org.xmldb.api.modules.XQueryService

public class LocalXPathQueryService
extends Object
implements XPathQueryServiceImpl, XQueryService


Constructor Summary
LocalXPathQueryService(User user, BrokerPool pool, LocalCollection collection, AccessContext accessCtx)
           
 
Method Summary
 void beginProtected()
          Execute all following queries in a protected environment.
 void clearNamespaces()
           
 org.xmldb.api.base.CompiledExpression compile(String query)
          Compiles the specified XQuery and returns a handle to the compiled code, which can then be passed to XQueryService.execute(CompiledExpression).
 org.xmldb.api.base.CompiledExpression compileAndCheck(String query)
          Tries to compile the specified XQuery and returns a handle to the compiled code, which can then be passed to XQueryService.execute(CompiledExpression).
 void declareVariable(String qname, Object initialValue)
          Declare an external XPath variable and assign a value to it.
 void dump(org.xmldb.api.base.CompiledExpression expression, Writer writer)
          Return a diagnostic dump of the query.
 void endProtected()
          Close the protected environment.
 org.xmldb.api.base.ResourceSet execute(org.xmldb.api.base.CompiledExpression expression)
          Execute a compiled XQuery.
 org.xmldb.api.base.ResourceSet execute(Source source)
           
 org.xmldb.api.base.ResourceSet execute(org.xmldb.api.modules.XMLResource res, org.xmldb.api.base.CompiledExpression expression)
           
 String getName()
           
 String getNamespace(String prefix)
          Returns the URI string associated with prefix from the internal namespace map.
 String getProperty(String property)
           
 String getVersion()
           
 org.xmldb.api.base.ResourceSet query(String query)
          Execute the specified query and return the results as a ResourceSet.
 org.xmldb.api.base.ResourceSet query(String query, String sortBy)
          Process an XPath query and sort the results by applying a second XPath expression to each of the search results.
 org.xmldb.api.base.ResourceSet query(org.xmldb.api.modules.XMLResource res, String query)
          Process an XPath query based on the result of a previous query.
 org.xmldb.api.base.ResourceSet query(org.xmldb.api.modules.XMLResource res, String query, String sortBy)
          Process an XPath query based on the result of a previous query and sort the results using the second XPath expression.
 org.xmldb.api.base.ResourceSet queryResource(String resource, String query)
           
 void removeNamespace(String ns)
          Removes the namespace mapping associated with prefix from the internal namespace map.
 void setCollection(org.xmldb.api.base.Collection col)
           
 void setModuleLoadPath(String path)
           
 void setNamespace(String prefix, String namespace)
          Sets a namespace mapping in the internal namespace map used to evaluate queries.
 void setProperty(String property, String value)
           
 void setXPathCompatibility(boolean backwardsCompatible)
          Enable or disable XPath 1.0 compatibility mode.
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

LocalXPathQueryService

public LocalXPathQueryService(User user,
                              BrokerPool pool,
                              LocalCollection collection,
                              AccessContext accessCtx)
Method Detail

clearNamespaces

public void clearNamespaces()
                     throws org.xmldb.api.base.XMLDBException
Specified by:
clearNamespaces in interface org.xmldb.api.modules.XPathQueryService
Specified by:
clearNamespaces in interface org.xmldb.api.modules.XQueryService
Throws:
org.xmldb.api.base.XMLDBException

getName

public String getName()
               throws org.xmldb.api.base.XMLDBException
Specified by:
getName in interface org.xmldb.api.base.Service
Throws:
org.xmldb.api.base.XMLDBException

getNamespace

public String getNamespace(String prefix)
                    throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Returns the URI string associated with prefix from the internal namespace map. If prefix is null or empty the URI for the default namespace will be returned. If a mapping for the prefix can not be found null is returned.

Specified by:
getNamespace in interface org.xmldb.api.modules.XPathQueryService
Specified by:
getNamespace in interface org.xmldb.api.modules.XQueryService
Parameters:
prefix - The prefix to retrieve from the namespace map.
Returns:
The URI associated with prefix
Throws:
org.xmldb.api.base.XMLDBException - with expected error codes.
ErrorCodes.VENDOR_ERROR for any vendor specific errors that occur.

getProperty

public String getProperty(String property)
                   throws org.xmldb.api.base.XMLDBException
Specified by:
getProperty in interface org.xmldb.api.base.Configurable
Throws:
org.xmldb.api.base.XMLDBException

getVersion

public String getVersion()
                  throws org.xmldb.api.base.XMLDBException
Specified by:
getVersion in interface org.xmldb.api.base.Service
Throws:
org.xmldb.api.base.XMLDBException

query

public org.xmldb.api.base.ResourceSet query(String query)
                                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Execute the specified query and return the results as a ResourceSet.

Specified by:
query in interface org.xmldb.api.modules.XPathQueryService
Specified by:
query in interface org.xmldb.api.modules.XQueryService
Throws:
org.xmldb.api.base.XMLDBException

query

public org.xmldb.api.base.ResourceSet query(org.xmldb.api.modules.XMLResource res,
                                            String query)
                                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XPathQueryServiceImpl
Process an XPath query based on the result of a previous query. The XMLResource contains the result received from a previous query.

Specified by:
query in interface XPathQueryServiceImpl
Parameters:
res - an XMLResource as obtained from a previous query.
query - the XPath query
Throws:
org.xmldb.api.base.XMLDBException

query

public org.xmldb.api.base.ResourceSet query(String query,
                                            String sortBy)
                                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XPathQueryServiceImpl
Process an XPath query and sort the results by applying a second XPath expression to each of the search results. The result of applying the sort expression is converted into a string, which is then used to sort the set of results.

Specified by:
query in interface XPathQueryServiceImpl
Parameters:
query - the XPath query
sortBy - another XPath expression, which is executed relative to the results of the primary expression.
Throws:
org.xmldb.api.base.XMLDBException

query

public org.xmldb.api.base.ResourceSet query(org.xmldb.api.modules.XMLResource res,
                                            String query,
                                            String sortBy)
                                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XPathQueryServiceImpl
Process an XPath query based on the result of a previous query and sort the results using the second XPath expression. The XMLResource contains the result received from a previous query.

Specified by:
query in interface XPathQueryServiceImpl
Parameters:
res - an XMLResource as obtained from a previous query
query - the XPath query
sortBy - another XPath expression, which is executed relative to the results of the primary expression. The result of applying sortExpr is converted to a string value, which is then used to sort the results.
Throws:
org.xmldb.api.base.XMLDBException

execute

public org.xmldb.api.base.ResourceSet execute(org.xmldb.api.base.CompiledExpression expression)
                                       throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Execute a compiled XQuery. The implementation should pass all namespaces and variables declared through XQueryService to the compiled XQuery code. Note: CompiledExpression is not thread safe. Please make sure you don't call the same compiled expression from two threads at the same time.

Specified by:
execute in interface org.xmldb.api.modules.XQueryService
Throws:
org.xmldb.api.base.XMLDBException

execute

public org.xmldb.api.base.ResourceSet execute(org.xmldb.api.modules.XMLResource res,
                                              org.xmldb.api.base.CompiledExpression expression)
                                       throws org.xmldb.api.base.XMLDBException
Throws:
org.xmldb.api.base.XMLDBException

execute

public org.xmldb.api.base.ResourceSet execute(Source source)
                                       throws org.xmldb.api.base.XMLDBException
Throws:
org.xmldb.api.base.XMLDBException

compile

public org.xmldb.api.base.CompiledExpression compile(String query)
                                              throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Compiles the specified XQuery and returns a handle to the compiled code, which can then be passed to XQueryService.execute(CompiledExpression). Note: CompiledExpression is not thread safe. Please make sure you don't call the same compiled expression from two threads at the same time.

Specified by:
compile in interface org.xmldb.api.modules.XQueryService
Throws:
org.xmldb.api.base.XMLDBException

compileAndCheck

public org.xmldb.api.base.CompiledExpression compileAndCheck(String query)
                                                      throws org.xmldb.api.base.XMLDBException,
                                                             XPathException
Description copied from interface: XQueryService
Tries to compile the specified XQuery and returns a handle to the compiled code, which can then be passed to XQueryService.execute(CompiledExpression). If a static error is detected, an XPathException will be thrown.

Throws:
org.xmldb.api.base.XMLDBException
XPathException

queryResource

public org.xmldb.api.base.ResourceSet queryResource(String resource,
                                                    String query)
                                             throws org.xmldb.api.base.XMLDBException
Specified by:
queryResource in interface org.xmldb.api.modules.XPathQueryService
Specified by:
queryResource in interface org.xmldb.api.modules.XQueryService
Throws:
org.xmldb.api.base.XMLDBException

beginProtected

public void beginProtected()
                    throws org.xmldb.api.base.XMLDBException
Execute all following queries in a protected environment. Protected means: it is guaranteed that documents referenced by the query or the result set are not modified by other threads until endProtected() is called.

Specified by:
beginProtected in interface XPathQueryServiceImpl
Throws:
org.xmldb.api.base.XMLDBException

endProtected

public void endProtected()
Close the protected environment. All locks held by the current thread are released. The result set is no longer guaranteed to be stable.

Specified by:
endProtected in interface XPathQueryServiceImpl

removeNamespace

public void removeNamespace(String ns)
                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Removes the namespace mapping associated with prefix from the internal namespace map. If prefix is null or empty the mapping for the default namespace will be removed.

Specified by:
removeNamespace in interface org.xmldb.api.modules.XPathQueryService
Specified by:
removeNamespace in interface org.xmldb.api.modules.XQueryService
Parameters:
ns - The prefix to remove from the namespace map. If prefix is null or empty the mapping for the default namespace will be removed.
Throws:
org.xmldb.api.base.XMLDBException - with expected error codes.
ErrorCodes.VENDOR_ERROR for any vendor specific errors that occur.

setCollection

public void setCollection(org.xmldb.api.base.Collection col)
                   throws org.xmldb.api.base.XMLDBException
Specified by:
setCollection in interface org.xmldb.api.base.Service
Throws:
org.xmldb.api.base.XMLDBException

setNamespace

public void setNamespace(String prefix,
                         String namespace)
                  throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Sets a namespace mapping in the internal namespace map used to evaluate queries. If prefix is null or empty the default namespace is associated with the provided URI. A null or empty uri results in an exception being thrown.

Specified by:
setNamespace in interface org.xmldb.api.modules.XPathQueryService
Specified by:
setNamespace in interface org.xmldb.api.modules.XQueryService
Parameters:
prefix - The prefix to set in the map. If prefix is empty or null the default namespace will be associated with the provided URI.
namespace - The URI for the namespace to be associated with prefix.
Throws:
org.xmldb.api.base.XMLDBException - with expected error codes.
ErrorCodes.VENDOR_ERROR for any vendor specific errors that occur.
TODO: probably need some special error here.

setProperty

public void setProperty(String property,
                        String value)
                 throws org.xmldb.api.base.XMLDBException
Specified by:
setProperty in interface org.xmldb.api.base.Configurable
Throws:
org.xmldb.api.base.XMLDBException

declareVariable

public void declareVariable(String qname,
                            Object initialValue)
                     throws org.xmldb.api.base.XMLDBException
Description copied from interface: XPathQueryServiceImpl
Declare an external XPath variable and assign a value to it. A variable can be referenced inside an XPath expression as $variable. For example, if you declare a variable with
        declareVariable("name", "HAMLET");
 
you may use the variable in an XPath expression as follows:
        //SPEECH[SPEAKER=$name]
 
Any Java object may be passed as initial value. The query engine will try to map this into a corresponding XPath value. You may also pass an XMLResource as obtained from another XPath expression. This will be converted into a node.

Specified by:
declareVariable in interface XPathQueryServiceImpl
Specified by:
declareVariable in interface org.xmldb.api.modules.XQueryService
Parameters:
qname - a valid QName by which the variable is identified. Any prefix should have been mapped to a namespace, i.e. if a variable is called x:name, there should be a prefix/namespace mapping for the prefix x
initialValue - the initial value, which is assigned to the variable
Throws:
org.xmldb.api.base.XMLDBException

setXPathCompatibility

public void setXPathCompatibility(boolean backwardsCompatible)
Description copied from interface: XQueryService
Enable or disable XPath 1.0 compatibility mode. In XPath 1.0 compatibility mode, some XQuery expressions will behave different. In particular, additional automatic type conversions will be applied to the operands of numeric operators.

Specified by:
setXPathCompatibility in interface org.xmldb.api.modules.XQueryService

setModuleLoadPath

public void setModuleLoadPath(String path)
Specified by:
setModuleLoadPath in interface org.xmldb.api.modules.XQueryService

dump

public void dump(org.xmldb.api.base.CompiledExpression expression,
                 Writer writer)
          throws org.xmldb.api.base.XMLDBException
Description copied from interface: XQueryService
Return a diagnostic dump of the query. The query should have been executed before calling this function.

Throws:
org.xmldb.api.base.XMLDBException


Copyright (C) Wolfgang Meier. All rights reserved.