Class XQueryParser
- java.lang.Object
- 
- net.sf.saxon.expr.parser.XPathParser
- 
- net.sf.saxon.query.XQueryParser
 
 
- 
 public class XQueryParser extends XPathParser This class defines extensions to the XPath parser to handle the additional syntax supported in XQuery
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classXQueryParser.Unescaper- 
Nested classes/interfaces inherited from class net.sf.saxon.expr.parser.XPathParserXPathParser.Accelerator, XPathParser.NestedLocation, XPathParser.ParsedLanguage
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected Executableexecutablejava.util.Set<java.lang.String>importedModulesstatic StructuredQNameSAXON_MEMO_FUNCTIONstatic java.lang.StringXQUERY10static java.lang.StringXQUERY30static java.lang.StringXQUERY31- 
Fields inherited from class net.sf.saxon.expr.parser.XPathParserallowSaxonExtensions, allowXPath30Syntax, allowXPath30XSLTExtensions, allowXPath31Syntax, catchDepth, charChecker, codeInjector, env, language, languageVersion, parserExtension, qNameParser, rangeVariables, scanOnly, t
 
- 
 - 
Constructor SummaryConstructors Constructor Description XQueryParser()Constructor for internal use: this class should be instantiated via the QueryModule
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidapplyModuleImport(net.sf.saxon.query.XQueryParser.Import mImport)protected booleanatStartOfRelativePath()Test whether the current token is one that can start a RelativePathExpressionprotected static booleancontainsLoopingClause(java.util.List<Clause> clauseList)protected voidcustomizeTokenizer(Tokenizer t)Callback to tailor the tokenizerprotected voidensureSchemaAware(java.lang.String featureName)ExecutablegetExecutable()Get the executable containing this expression.protected java.lang.StringgetLanguage()Get the current language (XPath or XQuery)booleanisStreaming()Ask whether the streaming option has been set, that is, whether subsequent calls on parseQuery() will compile queries to be capable of executing in streaming mode.protected voidlookAhead()Lookahead one token, catching any exception thrown by the tokenizer.protected LetExpressionmakeLetExpression()Make a LetExpression.protected voidmakeSimpleContent(Expression content, SimpleNodeConstructor inst, int offset)Make the instructions for the children of a node with simple content (attribute, text, PI, etc)static ExpressionmakeStringJoin(Expression exp, StaticContext env)Make a string-join expression that concatenates the string-values of items in a sequence with intervening spaces.protected LiteralmakeStringLiteral(java.lang.String token, boolean doUnescaping)Method to make a string literal from a token identified as a string literal.XQueryExpressionmakeXQueryExpression(java.lang.String query, QueryModule mainModule, Configuration config)Create an XQueryExpressionprotected AnnotationListparseAnnotationsList()Parse the annotations that can appear in a variable or function declarationprotected ExpressionparseConstructor()Parse a node constructor.protected ExpressionparseExtensionExpression()Parse an Extension Expression.protected ExpressionparseFLWORExpression()Parse a FLWOR expression.voidparseFunctionDeclaration(AnnotationList annotations)Parse a function declaration.voidparseLibraryModule(java.lang.String queryString, QueryModule env)Parse a library module.protected voidparseOutputDeclaration(StructuredQName varName, java.lang.String value)protected voidparseRevalidationDeclaration()Parse the "declare revalidation" declaration.ExpressionparseStringConstructor()Parse a string constructor: introduced in XQuery 3.1protected ExpressionparseSwitchExpression()Parse a Switch Expression.protected ExpressionparseTryCatchExpression()Parse a Try/Catch Expression.protected voidparseTypeAliasDeclaration()Parse a type alias declaration.protected ExpressionparseTypeswitchExpression()Parse a Typeswitch Expression.protected ExpressionparseValidateExpression()Parse a Validate Expression.protected java.lang.StringreadCollationName()voidsetExecutable(Executable exec)Set the executable used for this query expressionvoidsetStreaming(boolean option)Say whether the query should be compiled and evaluated to use streaming.static Expressionstringify(Expression exp, boolean noNodeIfEmpty, StaticContext env)Convert an expression so it generates a space-separated sequence of stringsprotected voidtestPermittedAxis(int axis, java.lang.String errorCode)protected java.lang.CharSequenceunescape(java.lang.String token)Unescape character references and built-in entity references in a stringjava.lang.StringuriLiteral(java.lang.String in)Handle a URI literal.- 
Methods inherited from class net.sf.saxon.expr.parser.XPathParsercheckLanguageVersion30, checkLanguageVersion31, checkMapExtensions, checkSyntaxExtensions, currentTokenDisplay, declareRangeVariable, disallowedAtStartOfRelativePath, expect, findRangeVariable, generateApplyCall, getCodeInjector, getMissingFunctionExplanation, getPlainType, getQNameParser, getRangeVariables, getStaticContext, getTokenizer, grumble, grumble, grumble, grumble, isAllowAbsentExpression, isAllowXPath31Syntax, isKeyword, isNamespaceTestAllowed, isReservedFunctionName30, isReservedFunctionName31, isReservedInQuery, makeCurriedFunction, makeFingerprint, makeLocalNameTest, makeLocation, makeLocation, makeNamespaceTest, makeNameTest, makeNestedLocation, makeNodeName, makeQNameTest, makeStructuredQName, makeStructuredQNameSilently, makeTracer, nextToken, operatorPrecedence, parse, parseArrayCurlyConstructor, parseArrayItemType, parseArraySquareConstructor, parseArrowPostfix, parseBackTickedStringLiteral, parseBasicStep, parseBinaryExpression, parseDynamicFunctionCall, parseExpression, parseExprSingle, parseExtendedItemType, parseExtendedSequenceType, parseFunctionArgument, parseFunctionCall, parseFunctionItemType, parseInlineFunction, parseItemType, parseLookup, parseMapExpression, parseMapItemType, parseNamedFunctionReference, parseNodeTest, parseNumericLiteral, parseParenthesizedExpression, parsePathExpression, parsePredicate, parsePredicate, parseRelativePath, parseRemainingPath, parseSequenceType, parseSequenceType, parseSimpleMappingExpression, parseStepExpression, parseStringLiteral, parseVariableReference, reportMissingFunction, resolveFunctionName, setAccelerator, setAllowAbsentExpression, setCatchDepth, setCodeInjector, setLanguage, setLocation, setLocation, setLocation, setParserExtension, setQNameParser, setRangeVariables, setRangeVariableStack, setScanOnly, undeclareRangeVariable, warning, whyDisallowedType
 
- 
 
- 
- 
- 
Field Detail- 
XQUERY10public static final java.lang.String XQUERY10 - See Also:
- Constant Field Values
 
 - 
XQUERY30public static final java.lang.String XQUERY30 - See Also:
- Constant Field Values
 
 - 
XQUERY31public static final java.lang.String XQUERY31 - See Also:
- Constant Field Values
 
 - 
executableprotected Executable executable 
 - 
importedModulespublic final java.util.Set<java.lang.String> importedModules 
 - 
SAXON_MEMO_FUNCTIONpublic static final StructuredQName SAXON_MEMO_FUNCTION 
 
- 
 - 
Method Detail- 
makeXQueryExpressionpublic XQueryExpression makeXQueryExpression(java.lang.String query, QueryModule mainModule, Configuration config) throws XPathException Create an XQueryExpression- Parameters:
- query- the source text of the query
- mainModule- the static context of the query
- config- the Saxon configuration
- Returns:
- the compiled XQuery expression
- Throws:
- XPathException- if the expression contains static errors
 
 - 
getExecutablepublic Executable getExecutable() Get the executable containing this expression.- Returns:
- the executable
 
 - 
setExecutablepublic void setExecutable(Executable exec) Set the executable used for this query expression- Parameters:
- exec- the executable
 
 - 
customizeTokenizerprotected void customizeTokenizer(Tokenizer t) Callback to tailor the tokenizer- Overrides:
- customizeTokenizerin class- XPathParser
- Parameters:
- t- the Tokenizer to be customized
 
 - 
setStreamingpublic void setStreaming(boolean option) Say whether the query should be compiled and evaluated to use streaming. This affects subsequent calls on the parseQuery() method. This option requires Saxon-EE.- Parameters:
- option- if true, the compiler will attempt to compile a query to be capable of executing in streaming mode. If the query cannot be streamed, a compile-time exception is reported. In streaming mode, the source document is supplied as a stream, and no tree is built in memory. The default is false.
- Since:
- 9.6
 
 - 
isStreamingpublic boolean isStreaming() Ask whether the streaming option has been set, that is, whether subsequent calls on parseQuery() will compile queries to be capable of executing in streaming mode.- Returns:
- true if the streaming option has been set.
- Since:
- 9.6
 
 - 
parseLibraryModulepublic final void parseLibraryModule(java.lang.String queryString, QueryModule env) throws XPathExceptionParse a library module. Prolog? Expression- Parameters:
- queryString- The text of the library module.
- env- The static context. The result of parsing a library module is that the static context is populated with a set of function declarations and variable declarations. Each library module must have its own static context objext.
- Throws:
- XPathException- if the expression contains a syntax error
 
 - 
parseAnnotationsListprotected AnnotationList parseAnnotationsList() throws XPathException Parse the annotations that can appear in a variable or function declaration- Overrides:
- parseAnnotationsListin class- XPathParser
- Returns:
- the annotations as a list
- Throws:
- XPathException- in the event of a syntax error
 
 - 
parseRevalidationDeclarationprotected void parseRevalidationDeclaration() throws XPathExceptionParse the "declare revalidation" declaration. Syntax: not allowed unless XQuery update is in use- Throws:
- XPathException- if the syntax is incorrect, or is not allowed in this XQuery processor
 
 - 
ensureSchemaAwareprotected void ensureSchemaAware(java.lang.String featureName) throws XPathException- Throws:
- XPathException
 
 - 
applyModuleImportpublic void applyModuleImport(net.sf.saxon.query.XQueryParser.Import mImport) throws XPathException- Throws:
- XPathException
 
 - 
parseFunctionDeclarationpublic void parseFunctionDeclaration(AnnotationList annotations) throws XPathException Parse a function declaration.Syntax: 
 <"declare" "function"> QName "(" ParamList? ")" ("as" SequenceType)? (EnclosedExpr | "external")On entry, the "declare function" has already been recognized - Parameters:
- annotations- the list of annotations that have been encountered for this function declaration
- Throws:
- XPathException- if a syntax error is found
 
 - 
parseTypeAliasDeclarationprotected void parseTypeAliasDeclaration() throws XPathExceptionParse a type alias declaration. Allowed only in Saxon-PE and higher- Throws:
- XPathException- if parsing fails
 
 - 
parseOutputDeclarationprotected void parseOutputDeclaration(StructuredQName varName, java.lang.String value) throws XPathException - Throws:
- XPathException
 
 - 
parseFLWORExpressionprotected Expression parseFLWORExpression() throws XPathException Parse a FLWOR expression. This replaces the XPath "for" expression. Full syntax:[41] FLWORExpr ::= (ForClause | LetClause)+ WhereClause? OrderByClause? "return" ExprSingle 
 [42] ForClause ::= <"for" "$"> VarName TypeDeclaration? PositionalVar? "in" ExprSingle ("," "$" VarName TypeDeclaration? PositionalVar? "in" ExprSingle)*
 [43] PositionalVar ::= "at" "$" VarName
 [44] LetClause ::= <"let" "$"> VarName TypeDeclaration? ":=" ExprSingle ("," "$" VarName TypeDeclaration? ":=" ExprSingle)*
 [45] WhereClause ::= "where" Expr
 [46] OrderByClause ::= (<"order" "by"> | <"stable" "order" "by">) OrderSpecList
 [47] OrderSpecList ::= OrderSpec ("," OrderSpec)*
 [48] OrderSpec ::= ExprSingle OrderModifier
 [49] OrderModifier ::= ("ascending" | "descending")? (<"empty" "greatest"> | <"empty" "least">)? ("collation" StringLiteral)?- Overrides:
- parseFLWORExpressionin class- XPathParser
- Returns:
- the resulting subexpression
- Throws:
- XPathException- if any error is encountered
 
 - 
makeLetExpressionprotected LetExpression makeLetExpression() Make a LetExpression. This returns an ordinary LetExpression if tracing is off, and an EagerLetExpression if tracing is on. This is so that trace events occur in an order that the user can follow.- Returns:
- the constructed "let" expression
 
 - 
containsLoopingClauseprotected static boolean containsLoopingClause(java.util.List<Clause> clauseList) 
 - 
makeStringJoinpublic static Expression makeStringJoin(Expression exp, StaticContext env) Make a string-join expression that concatenates the string-values of items in a sequence with intervening spaces. This may be simplified later as a result of type-checking.- Parameters:
- exp- the base expression, evaluating to a sequence
- env- the static context
- Returns:
- a call on string-join to create a string containing the representations of the items in the sequence separated by spaces.
 
 - 
readCollationNameprotected java.lang.String readCollationName() throws XPathException- Throws:
- XPathException
 
 - 
parseTypeswitchExpressionprotected Expression parseTypeswitchExpression() throws XPathException Parse a Typeswitch Expression. This construct is XQuery-only. TypeswitchExpr ::= "typeswitch" "(" Expr ")" CaseClause+ "default" ("$" VarName)? "return" ExprSingle CaseClause ::= "case" ("$" VarName "as")? SequenceType "return" ExprSingle- Overrides:
- parseTypeswitchExpressionin class- XPathParser
- Returns:
- the expression that results from the parsing
- Throws:
- XPathException- if parsing fails
 
 - 
parseSwitchExpressionprotected Expression parseSwitchExpression() throws XPathException Parse a Switch Expression. This construct is XQuery-3.0-only. SwitchExpr ::= "switch" "(" Expr ")" SwitchCaseClause+ "default" "return" ExprSingle SwitchCaseClause ::= ("case" ExprSingle)+ "return" ExprSingle- Overrides:
- parseSwitchExpressionin class- XPathParser
- Returns:
- the parsed expression
- Throws:
- XPathException- in the event of a syntax error
 
 - 
parseValidateExpressionprotected Expression parseValidateExpression() throws XPathException Parse a Validate Expression. This construct is XQuery-only. The syntax allows: validate mode? { Expr } mode ::= "strict" | "lax"- Overrides:
- parseValidateExpressionin class- XPathParser
- Returns:
- the parsed expression; except that this version of the method always throws an exception
- Throws:
- XPathException- if parsing fails
 
 - 
parseExtensionExpressionprotected Expression parseExtensionExpression() throws XPathException Parse an Extension Expression. Syntax: "(#" QName arbitrary-text "#)")+ "{" expr? "}"- Overrides:
- parseExtensionExpressionin class- XPathParser
- Returns:
- the parsed expression; except that this version of the method always throws an exception
- Throws:
- XPathException- if parsing fails
 
 - 
parseConstructorprotected Expression parseConstructor() throws XPathException Parse a node constructor. This is allowed only in XQuery. This method handles both the XML-like "direct" constructors, and the XQuery-based "computed" constructors.- Overrides:
- parseConstructorin class- XPathParser
- Returns:
- an Expression for evaluating the parsed constructor
- Throws:
- XPathException- in the event of a syntax error.
 
 - 
parseTryCatchExpressionprotected Expression parseTryCatchExpression() throws XPathException Parse a Try/Catch Expression. This construct is XQuery-3.0 only. The syntax allows: try { Expr } catch NameTest ('|' NameTest)* { Expr } We don't currently implement the CatchVars- Overrides:
- parseTryCatchExpressionin class- XPathParser
- Returns:
- the parsed expression; except that this version of the method always throws an exception
- Throws:
- XPathException- if a static error is found
 
 - 
makeSimpleContentprotected void makeSimpleContent(Expression content, SimpleNodeConstructor inst, int offset) Make the instructions for the children of a node with simple content (attribute, text, PI, etc)- Parameters:
- content- the expression making up the simple content
- inst- the skeletal instruction for creating the node
- offset- the character position of this construct within the source query
 
 - 
stringifypublic static Expression stringify(Expression exp, boolean noNodeIfEmpty, StaticContext env) Convert an expression so it generates a space-separated sequence of strings- Parameters:
- exp- the expression that calculates the content
- noNodeIfEmpty- if true, no node is produced when the value of the content expression is an empty sequence. If false, the effect of supplying an empty sequence is that a node is created whose string-value is a zero-length string. Set to true for text node constructors, false for other kinds of node.
- env- the static context
- Returns:
- an expression that computes the content and converts the result to a character string
 
 - 
makeStringLiteralprotected Literal makeStringLiteral(java.lang.String token, boolean doUnescaping) throws XPathException Method to make a string literal from a token identified as a string literal. This is trivial in XPath, but in XQuery the method is overridden to identify pseudo-XML character and entity references- Overrides:
- makeStringLiteralin class- XPathParser
- Parameters:
- token- the string as written (or as returned by the tokenizer)
- Returns:
- The string value of the string literal, after dereferencing entity and character references
- Throws:
- XPathException- if parsing fails
 
 - 
unescapeprotected java.lang.CharSequence unescape(java.lang.String token) throws XPathExceptionUnescape character references and built-in entity references in a string- Overrides:
- unescapein class- XPathParser
- Parameters:
- token- the input string, which may include XML-style character references or built-in entity references
- Returns:
- the string with character references and built-in entity references replaced by their expansion
- Throws:
- XPathException- if a malformed character or entity reference is found
 
 - 
parseStringConstructorpublic Expression parseStringConstructor() throws XPathException Parse a string constructor: introduced in XQuery 3.1- Overrides:
- parseStringConstructorin class- XPathParser
- Throws:
- XPathException
 
 - 
uriLiteralpublic java.lang.String uriLiteral(java.lang.String in) throws XPathExceptionHandle a URI literal. This is whitespace-normalized as well as being unescaped- Parameters:
- in- the string as written
- Returns:
- the URI after unescaping of entity and character references followed by whitespace normalization
- Throws:
- XPathException- if an error is found while unescaping the URI
 
 - 
lookAheadprotected void lookAhead() throws XPathExceptionLookahead one token, catching any exception thrown by the tokenizer. This method is only called from the query parser when switching from character-at-a-time mode to tokenizing mode- Throws:
- XPathException- if parsing fails
 
 - 
atStartOfRelativePathprotected boolean atStartOfRelativePath() Description copied from class:XPathParserTest whether the current token is one that can start a RelativePathExpression- Overrides:
- atStartOfRelativePathin class- XPathParser
- Returns:
- the resulting subexpression
 
 - 
testPermittedAxisprotected void testPermittedAxis(int axis, java.lang.String errorCode) throws XPathException- Overrides:
- testPermittedAxisin class- XPathParser
- Throws:
- XPathException
 
 - 
getLanguageprotected java.lang.String getLanguage() Get the current language (XPath or XQuery)- Overrides:
- getLanguagein class- XPathParser
- Returns:
- a string representation of the language being parsed, for use in error messages
 
 
- 
 
-