org.exist.xquery.update
Class Insert
java.lang.Object
org.exist.xquery.AbstractExpression
org.exist.xquery.update.Modification
org.exist.xquery.update.Insert
- All Implemented Interfaces:
- Expression
public class Insert
- extends Modification
- Author:
- wolf
Fields inherited from interface org.exist.xquery.Expression |
DOT_TEST, EXPRESSION_ID_INVALID, IGNORE_CONTEXT, IN_NODE_CONSTRUCTOR, IN_PREDICATE, IN_UPDATE, IN_WHERE_CLAUSE, NEED_INDEX_INFO, NO_CONTEXT_ID, POSITIONAL_PREDICATE, SINGLE_STEP_EXECUTION, USE_TREE_TRAVERSAL |
Methods inherited from class org.exist.xquery.AbstractExpression |
accept, eval, getColumn, getContext, getContextDocSet, getContextId, getDependencies, getExpressionId, getLine, getPrimaryAxis, getSource, setASTNode, setContextDocSet, setLocation, setPrimaryAxis |
INSERT_BEFORE
public static final int INSERT_BEFORE
- See Also:
- Constant Field Values
INSERT_AFTER
public static final int INSERT_AFTER
- See Also:
- Constant Field Values
INSERT_APPEND
public static final int INSERT_APPEND
- See Also:
- Constant Field Values
Insert
public Insert(XQueryContext context,
int mode)
Insert
public Insert(XQueryContext context,
Expression select,
Expression value,
int mode)
- Parameters:
context
- select
- value
-
eval
public Sequence eval(Sequence contextSequence,
Item contextItem)
throws XPathException
- Description copied from interface:
Expression
- Evaluate the expression represented by this object.
Depending on the context in which this expression is executed,
either the context sequence, the context item or both of them may
be set. An implementing class should know how to handle this.
The general contract is as follows: if the
Dependency.CONTEXT_ITEM
bit is set in the bit field returned by Expression.getDependencies()
, the eval method will
be called once for every item in the context sequence. The contextItem
parameter will be set to the current item. Otherwise, the eval method will only be called
once for the whole context sequence and contextItem will be null.
eXist tries to process the entire context set in one, single step whenever
possible. Thus, most classes only expect context to contain a list of
nodes which represents the current context of the expression.
The position() function in XPath is an example for an expression,
which requires both, context sequence and context item to be set.
The context sequence might be a node set, a sequence of atomic values or a single
node or atomic value.
- Specified by:
eval
in interface Expression
- Specified by:
eval
in class AbstractExpression
- Parameters:
contextSequence
- the current context sequence.contextItem
- a single item, taken from context. This defines the item,
the expression should work on.
- Throws:
XPathException
update
public void update(Sequence inSeq,
Sequence contentSeq)
throws XPathException
- Specified by:
update
in class Modification
- Throws:
XPathException
dump
public void dump(ExpressionDumper dumper)
- Description copied from interface:
Expression
- Write a diagnostic dump of the expression to the passed
ExpressionDumper
.
- Parameters:
dumper
- the expression dumper to write to
toString
public String toString()
- Overrides:
toString
in class Object
Copyright (C) Wolfgang Meier. All rights reserved.