Class CallMethodRule
- java.lang.Object
-
- org.apache.tomcat.util.digester.Rule
-
- org.apache.tomcat.util.digester.CallMethodRule
-
public class CallMethodRule extends Rule
Rule implementation that calls a method on an object on the stack (normally the top/parent object), passing arguments collected from subsequent
CallParamRulerules or from the body of this element.By using
CallMethodRule(String methodName)a method call can be made to a method which accepts no arguments.Incompatible method parameter types are converted using
org.apache.commons.beanutils.ConvertUtils.This rule now uses org.apache.commons.beanutils.MethodUtils#invokeMethod by default. This increases the kinds of methods successfully and allows primitives to be matched by passing in wrapper classes. There are rare cases when org.apache.commons.beanutils.MethodUtils#invokeExactMethod (the old default) is required. This method is much stricter in its reflection. Setting the
UseExactMatchto true reverts to the use of this method.Note that the target method is invoked when the end of the tag the CallMethodRule fired on is encountered, not when the last parameter becomes available. This implies that rules which fire on tags nested within the one associated with the CallMethodRule will fire before the CallMethodRule invokes the target method. This behaviour is not configurable.
Note also that if a CallMethodRule is expecting exactly one parameter and that parameter is not available (eg CallParamRule is used with an attribute name but the attribute does not exist) then the method will not be invoked. If a CallMethodRule is expecting more than one parameter, then it is always invoked, regardless of whether the parameters were available or not (missing parameters are passed as null values).
-
-
Field Summary
Fields Modifier and Type Field Description protected StringbodyTextThe body text collected from this element.protected StringmethodNameThe method name to call on the parent object.protected String[]paramClassNamesThe names of the classes of the parameters to be collected.protected intparamCountThe number of parameters to collect fromMethodParamrules.protected Class<?>[]paramTypesThe parameter types of the parameters to be collected.protected inttargetOffsetlocation of the target object for the call, relative to the top of the digester object stack.protected booleanuseExactMatchShouldMethodUtils.invokeExactMethodbe used for reflection.-
Fields inherited from class org.apache.tomcat.util.digester.Rule
digester, namespaceURI
-
-
Constructor Summary
Constructors Constructor Description CallMethodRule(int targetOffset, String methodName)Construct a "call method" rule with the specified method name.CallMethodRule(int targetOffset, String methodName, int paramCount)Construct a "call method" rule with the specified method name.CallMethodRule(int targetOffset, String methodName, int paramCount, Class<?>[] paramTypes)Construct a "call method" rule with the specified method name and parameter types.CallMethodRule(int targetOffset, String methodName, int paramCount, String[] paramTypes)Construct a "call method" rule with the specified method name and parameter types.CallMethodRule(String methodName)Construct a "call method" rule with the specified method name.CallMethodRule(String methodName, int paramCount)Construct a "call method" rule with the specified method name.CallMethodRule(String methodName, int paramCount, Class<?>[] paramTypes)Construct a "call method" rule with the specified method name and parameter types.CallMethodRule(String methodName, int paramCount, String[] paramTypes)Construct a "call method" rule with the specified method name and parameter types.CallMethodRule(Digester digester, String methodName, int paramCount)Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method.CallMethodRule(Digester digester, String methodName, int paramCount, Class[] paramTypes)Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method.CallMethodRule(Digester digester, String methodName, int paramCount, String[] paramTypes)Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidbegin(Attributes attributes)Process the start of this element.voidbody(String bodyText)Process the body text of this element.voidend()Process the end of this element.voidfinish()Clean up after parsing is complete.booleangetUseExactMatch()ShouldMethodUtils.invokeExactMethodbe used for the reflection.protected voidprocessMethodCallResult(Object result)Subclasses may override this method to perform additional processing of the invoked method's result.voidsetDigester(Digester digester)Set the associated digester.voidsetUseExactMatch(boolean useExactMatch)Set whetherMethodUtils.invokeExactMethodshould be used for the reflection.StringtoString()Render a printable version of this Rule.-
Methods inherited from class org.apache.tomcat.util.digester.Rule
begin, body, end, getDigester, getNamespaceURI, setNamespaceURI
-
-
-
-
Field Detail
-
bodyText
protected String bodyText
The body text collected from this element.
-
targetOffset
protected int targetOffset
location of the target object for the call, relative to the top of the digester object stack. The default value of zero means the target object is the one on top of the stack.
-
methodName
protected String methodName
The method name to call on the parent object.
-
paramCount
protected int paramCount
The number of parameters to collect fromMethodParamrules. If this value is zero, a single parameter will be collected from the body of this element.
-
paramTypes
protected Class<?>[] paramTypes
The parameter types of the parameters to be collected.
-
paramClassNames
protected String[] paramClassNames
The names of the classes of the parameters to be collected. This attribute allows creation of the classes to be postponed until the digester is set.
-
useExactMatch
protected boolean useExactMatch
ShouldMethodUtils.invokeExactMethodbe used for reflection.
-
-
Constructor Detail
-
CallMethodRule
public CallMethodRule(Digester digester, String methodName, int paramCount)
Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method. UseCallMethodRule(String methodName,int paramCount)instead.Construct a "call method" rule with the specified method name. The parameter types (if any) default to java.lang.String.- Parameters:
digester- The associated DigestermethodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of this element.
-
CallMethodRule
public CallMethodRule(Digester digester, String methodName, int paramCount, String[] paramTypes)
Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method. UseCallMethodRule(String methodName,int paramCount, String [] paramTypes)instead.Construct a "call method" rule with the specified method name.- Parameters:
digester- The associated DigestermethodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java class names of the arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Booleanfor abooleanparameter)
-
CallMethodRule
public CallMethodRule(Digester digester, String methodName, int paramCount, Class[] paramTypes)
Deprecated.The digester instance is now set in theDigester.addRule(java.lang.String, org.apache.tomcat.util.digester.Rule)method. UseCallMethodRule(String methodName,int paramCount, Class [] paramTypes)instead.Construct a "call method" rule with the specified method name.- Parameters:
digester- The associated DigestermethodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java classes that represent the parameter types of the method arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Boolean.TYPEfor abooleanparameter)
-
CallMethodRule
public CallMethodRule(String methodName, int paramCount)
Construct a "call method" rule with the specified method name. The parameter types (if any) default to java.lang.String.- Parameters:
methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of this element.
-
CallMethodRule
public CallMethodRule(int targetOffset, String methodName, int paramCount)Construct a "call method" rule with the specified method name. The parameter types (if any) default to java.lang.String.- Parameters:
targetOffset- location of the target object. Positive numbers are relative to the top of the digester object stack. Negative numbers are relative to the bottom of the stack. Zero implies the top object on the stack.methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of this element.
-
CallMethodRule
public CallMethodRule(String methodName)
Construct a "call method" rule with the specified method name. The method should accept no parameters.- Parameters:
methodName- Method name of the parent method to call
-
CallMethodRule
public CallMethodRule(int targetOffset, String methodName)Construct a "call method" rule with the specified method name. The method should accept no parameters.- Parameters:
targetOffset- location of the target object. Positive numbers are relative to the top of the digester object stack. Negative numbers are relative to the bottom of the stack. Zero implies the top object on the stack.methodName- Method name of the parent method to call
-
CallMethodRule
public CallMethodRule(String methodName, int paramCount, String[] paramTypes)
Construct a "call method" rule with the specified method name and parameter types. IfparamCountis set to zero the rule will use the body of this element as the single argument of the method, unlessparamTypesis null or empty, in this case the rule will call the specified method with no arguments.- Parameters:
methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java class names of the arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Booleanfor abooleanparameter)
-
CallMethodRule
public CallMethodRule(int targetOffset, String methodName, int paramCount, String[] paramTypes)Construct a "call method" rule with the specified method name and parameter types. IfparamCountis set to zero the rule will use the body of this element as the single argument of the method, unlessparamTypesis null or empty, in this case the rule will call the specified method with no arguments.- Parameters:
targetOffset- location of the target object. Positive numbers are relative to the top of the digester object stack. Negative numbers are relative to the bottom of the stack. Zero implies the top object on the stack.methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java class names of the arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Booleanfor abooleanparameter)
-
CallMethodRule
public CallMethodRule(String methodName, int paramCount, Class<?>[] paramTypes)
Construct a "call method" rule with the specified method name and parameter types. IfparamCountis set to zero the rule will use the body of this element as the single argument of the method, unlessparamTypesis null or empty, in this case the rule will call the specified method with no arguments.- Parameters:
methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java classes that represent the parameter types of the method arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Boolean.TYPEfor abooleanparameter)
-
CallMethodRule
public CallMethodRule(int targetOffset, String methodName, int paramCount, Class<?>[] paramTypes)Construct a "call method" rule with the specified method name and parameter types. IfparamCountis set to zero the rule will use the body of this element as the single argument of the method, unlessparamTypesis null or empty, in this case the rule will call the specified method with no arguments.- Parameters:
targetOffset- location of the target object. Positive numbers are relative to the top of the digester object stack. Negative numbers are relative to the bottom of the stack. Zero implies the top object on the stack.methodName- Method name of the parent method to callparamCount- The number of parameters to collect, or zero for a single argument from the body of ths elementparamTypes- The Java classes that represent the parameter types of the method arguments (if you wish to use a primitive type, specify the corresonding Java wrapper class instead, such asjava.lang.Boolean.TYPEfor abooleanparameter)
-
-
Method Detail
-
getUseExactMatch
public boolean getUseExactMatch()
ShouldMethodUtils.invokeExactMethodbe used for the reflection.
-
setUseExactMatch
public void setUseExactMatch(boolean useExactMatch)
Set whetherMethodUtils.invokeExactMethodshould be used for the reflection.
-
setDigester
public void setDigester(Digester digester)
Set the associated digester. If needed, this class loads the parameter classes from their names.- Overrides:
setDigesterin classRule
-
begin
public void begin(Attributes attributes) throws Exception
Process the start of this element.
-
end
public void end() throws ExceptionProcess the end of this element.
-
finish
public void finish() throws ExceptionClean up after parsing is complete.
-
processMethodCallResult
protected void processMethodCallResult(Object result)
Subclasses may override this method to perform additional processing of the invoked method's result.- Parameters:
result- the Object returned by the method invoked, possibly null
-
-