|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--net.sf.saxon.instruct.Instruction | +--net.sf.saxon.instruct.ExprInstruction | +--net.sf.saxon.instruct.ElementCreator | +--net.sf.saxon.instruct.Element
An instruction representing xsl:element element in the stylesheet.
Field Summary |
Fields inherited from class net.sf.saxon.instruct.ElementCreator |
schemaType, useAttributeSets, validation, validationContext |
Fields inherited from class net.sf.saxon.instruct.Instruction |
children |
Constructor Summary | |
Element(Expression elementName,
Expression namespace,
NamespaceResolver nsContext,
AttributeSet[] useAttributeSets,
SchemaType schemaType,
int validation)
Create an instruction that creates a new element node |
Method Summary | |
Expression |
analyze(StaticContext env)
Perform static analysis of an expression and its subexpressions. |
void |
display(int level,
NamePool pool)
Display this instruction as an expression, for diagnostics |
java.lang.String |
getInstructionName()
Get the name of this instruction for diagnostic and tracing purposes |
protected int |
getNameCode(XPathContext context)
Callback from the superclass ElementCreator to get the nameCode for the element name |
void |
getXPathExpressions(java.util.List list)
Get all the XPath expressions associated with this instruction (in XSLT terms, the expression present on attributes of the instruction, as distinct from the child instructions in a sequence construction) |
protected void |
outputNamespaceNodes(XPathContext context,
Receiver out)
Callback to output namespace nodes for the new element. |
void |
promoteInst(PromotionOffer offer)
Offer promotion for subexpressions. |
Expression |
simplify()
Simplify an expression. |
Methods inherited from class net.sf.saxon.instruct.ElementCreator |
evaluateItem, getCardinality, getItemType, getValidationContext, getValidationMode, processLeavingTail, setValidationContext, setValidationMode |
Methods inherited from class net.sf.saxon.instruct.ExprInstruction |
effectiveBooleanValue, evaluateAsString, getDependencies, getSpecialProperties, getSubExpressions, iterate, promote |
Methods inherited from class net.sf.saxon.instruct.Instruction |
assembleParams, assembleTunnelParams, displayChildren, dynamicError, dynamicError, getChildren, getColumnNumber, getExecutable, getInstructionNamespace, getLineNumber, getPublicId, getSourceLocator, getSystemId, process, processChildren, processChildrenLeavingTail, recoverableError, setChildren, setExecutable, setSourceLocation |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
public Element(Expression elementName, Expression namespace, NamespaceResolver nsContext, AttributeSet[] useAttributeSets, SchemaType schemaType, int validation)
elementName
- Expression that evaluates to produce the name of the
element node as a lexical QNamenamespace
- Expression that evaluates to produce the namespace URI of
the element node. Set to null if the namespace is to be deduced from the prefix
of the elementName.nsContext
- Saved copy of the static namespace context for the instruction.
Can be set to null if namespace is supplied.useAttributeSets
- Array of attribute sets to be expandedschemaType
- The required schema type for the contentMethod Detail |
public Expression simplify() throws XPathException
ExprInstruction
simplify
in interface Expression
simplify
in class ExprInstruction
XPathException
- if an error is discovered during expression
rewritingpublic Expression analyze(StaticContext env) throws XPathException
ExprInstruction
This checks statically that the operands of the expression have the correct type; if necessary it generates code to do run-time type checking or type conversion. A static type error is reported only if execution cannot possibly succeed, that is, if a run-time type error is inevitable. The call may return a modified form of the expression.
This method is called after all references to functions and variables have been resolved to the declaration of the function or variable. However, the types of such functions and variables will only be accurately known if they have been explicitly declared.
analyze
in interface Expression
analyze
in class ElementCreator
env
- the static context of the expression
XPathException
- if an error is discovered during this phase
(typically a type error)public void getXPathExpressions(java.util.List list)
ExprInstruction
getXPathExpressions
in class ExprInstruction
list
- A list to be populated with the list of XPath expressionspublic void promoteInst(PromotionOffer offer) throws XPathException
promoteInst
in class ElementCreator
offer
- details of the offer, for example the offer to move
expressions that don't depend on the context to an outer level in
the containing expression
XPathException
- if any error is detectedprotected int getNameCode(XPathContext context) throws XPathException, javax.xml.transform.TransformerException
getNameCode
in class ElementCreator
context
- The evaluation context (not used)
XPathException
javax.xml.transform.TransformerException
protected void outputNamespaceNodes(XPathContext context, Receiver out) throws javax.xml.transform.TransformerException
outputNamespaceNodes
in class ElementCreator
context
- The execution contextout
- the Receiver where the namespace nodes are to be written
javax.xml.transform.TransformerException
public java.lang.String getInstructionName()
getInstructionName
in class Instruction
public void display(int level, NamePool pool)
level
- indentation level for this expression
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |