org.apache.xpath.functions
Class FunctionMultiArgs
java.lang.Object
   org.apache.xpath.Expression
org.apache.xpath.Expression
       org.apache.xpath.functions.Function
org.apache.xpath.functions.Function
           org.apache.xpath.functions.FunctionOneArg
org.apache.xpath.functions.FunctionOneArg
               org.apache.xpath.functions.Function2Args
org.apache.xpath.functions.Function2Args
                   org.apache.xpath.functions.Function3Args
org.apache.xpath.functions.Function3Args
                       org.apache.xpath.functions.FunctionMultiArgs
org.apache.xpath.functions.FunctionMultiArgs
- All Implemented Interfaces: 
- java.io.Serializable, javax.xml.transform.SourceLocator, ExpressionNode, ExpressionOwner, XPathVisitable
- Direct Known Subclasses: 
- FuncConcat
- public class FunctionMultiArgs 
- extends Function3Args
Base class for functions that accept an undetermined number of multiple
 arguments.
- See Also:
- Serialized Form
 
 
 
 
 
 
 
 
| Method Summary | 
|  void | callArgVisitors(XPathVisitor visitor)Call the visitors for the function arguments.
 | 
|  boolean | canTraverseOutsideSubtree()Tell if this expression or it's subexpressions can traverse outside
 the current subtree.
 | 
|  void | checkNumberArgs(int argNum)Check that the number of arguments passed to this function is correct.
 | 
|  boolean | deepEquals(Expression expr)Compare this object with another object and see 
 if they are equal, include the sub heararchy.
 | 
|  void | fixupVariables(java.util.Vector vars,
                             int globalsSize)This function is used to fixup variables from QNames to stack frame 
 indexes at stylesheet build time.
 | 
|  Expression[] | getArgs()Return an expression array containing arguments at index 3 or greater.
 | 
| protected  void | reportWrongNumberArgs()Constructs and throws a WrongNumberArgException with the appropriate
 message for this function object.
 | 
|  void | setArg(Expression arg,
             int argNum)Set an argument expression for a function.
 | 
 
 
 
 
 
| Methods inherited from class org.apache.xpath.Expression | 
| asIterator, asIteratorRaw, asNode, assertion, bool, error, execute, execute, execute, executeCharsToContentHandler, exprAddChild, exprGetChild, exprGetNumChildren, exprGetParent, exprSetParent, getColumnNumber, getExpressionOwner, getLineNumber, getPublicId, getSystemId, isNodesetExpr, isSameClass, isStableNumber, num, warn, xstr | 
 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
 
serialVersionUID
static final long serialVersionUID
- See Also:
- Constant Field Values
m_args
Expression[] m_args
- Argument expressions that are at index 3 or greater.
 
 
FunctionMultiArgs
public FunctionMultiArgs()
getArgs
public Expression[] getArgs()
- Return an expression array containing arguments at index 3 or greater.
 
- 
- Returns:
- An array that contains the arguments at index 3 or greater.
 
setArg
public void setArg(Expression arg,
                   int argNum)
            throws WrongNumberArgsException
- Set an argument expression for a function.  This method is called by the
 XPath compiler.
 
- 
- Overrides:
- setArgin class- Function3Args
 
- 
- Parameters:
- arg- non-null expression that represents the argument.
- argNum- The argument number index.
- Throws:
- WrongNumberArgsException- If a derived class determines that the
 number of arguments is incorrect.
 
fixupVariables
public void fixupVariables(java.util.Vector vars,
                           int globalsSize)
- This function is used to fixup variables from QNames to stack frame 
 indexes at stylesheet build time.
 
- 
- Overrides:
- fixupVariablesin class- Function3Args
 
- 
- Parameters:
- vars- List of QNames that correspond to variables.  This list 
 should be searched backwards for the first qualified name that 
 corresponds to the variable reference qname.  The position of the 
 QName in the vector from the start of the vector will be its position 
 in the stack frame (but variables above the globalsTop value will need 
 to be offset to the current stack frame).
 
checkNumberArgs
public void checkNumberArgs(int argNum)
                     throws WrongNumberArgsException
- Check that the number of arguments passed to this function is correct.
 
- 
- Overrides:
- checkNumberArgsin class- Function3Args
 
- 
- Parameters:
- argNum- The number of arguments that is being passed to the function.
- Throws:
- WrongNumberArgsException
 
reportWrongNumberArgs
protected void reportWrongNumberArgs()
                              throws WrongNumberArgsException
- Constructs and throws a WrongNumberArgException with the appropriate
 message for this function object.  This class supports an arbitrary
 number of arguments, so this method must never be called.
 
- 
- Overrides:
- reportWrongNumberArgsin class- Function3Args
 
- 
- Throws:
- WrongNumberArgsException
 
canTraverseOutsideSubtree
public boolean canTraverseOutsideSubtree()
- Tell if this expression or it's subexpressions can traverse outside
 the current subtree.
 
- 
- Overrides:
- canTraverseOutsideSubtreein class- Function3Args
 
- 
- Returns:
- true if traversal outside the context node's subtree can occur.
 
callArgVisitors
public void callArgVisitors(XPathVisitor visitor)
- Description copied from class: Function
- Call the visitors for the function arguments.
 
- 
- Overrides:
- callArgVisitorsin class- Function3Args
 
- 
- See Also:
- XPathVisitable.callVisitors(ExpressionOwner, XPathVisitor)
 
deepEquals
public boolean deepEquals(Expression expr)
- Description copied from class: Expression
- Compare this object with another object and see 
 if they are equal, include the sub heararchy.
 
- 
- Overrides:
- deepEqualsin class- Function3Args
 
- 
- Parameters:
- expr- Another expression object.
- Returns:
- true if this objects class and the expr
 object's class are the same, and the data contained 
 within both objects are considered equal.
- See Also:
- Expression.deepEquals(Expression)