Package freemarker.ext.beans
Class OverloadedMethodsModel
- java.lang.Object
-
- freemarker.ext.beans.OverloadedMethodsModel
-
- All Implemented Interfaces:
TemplateMethodModel,TemplateMethodModelEx,TemplateModel,TemplateSequenceModel
public class OverloadedMethodsModel extends java.lang.Object implements TemplateMethodModelEx, TemplateSequenceModel
Wraps a set of same-name overloaded methods behindTemplateMethodModelinterface, like if it was a single method, chooses among them behind the scenes on call-time based on the argument values.
-
-
Field Summary
-
Fields inherited from interface freemarker.template.TemplateModel
NOTHING
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Objectexec(java.util.List arguments)Invokes the method, passing it the arguments from the list.TemplateModelget(int index)Retrieves the i-th template model in this sequence.intsize()
-
-
-
Method Detail
-
exec
public java.lang.Object exec(java.util.List arguments) throws TemplateModelExceptionInvokes the method, passing it the arguments from the list. The actual method to call from several overloaded methods will be chosen based on the classes of the arguments.- Specified by:
execin interfaceTemplateMethodModel- Specified by:
execin interfaceTemplateMethodModelEx- Parameters:
arguments- aListofTemplateModel-s, containing the arguments passed to the method. If the implementation absolutely wants to operate on POJOs, it can use the static utility methods in theDeepUnwrapclass to easily obtain them. However, unwrapping is not always possible (or not perfectly), and isn't always efficient, so it's recommended to use the originalTemplateModelvalue as much as possible.- Returns:
- the return value of the method, or
null. If the returned value does not implementTemplateModel, it will be automatically wrapped using theenvironment's object wrapper. - Throws:
TemplateModelException- if the method cannot be chosen unambiguously.
-
get
public TemplateModel get(int index) throws TemplateModelException
Description copied from interface:TemplateSequenceModelRetrieves the i-th template model in this sequence.- Specified by:
getin interfaceTemplateSequenceModel- Returns:
- the item at the specified index, or
nullif the index is out of bounds. Note that anullvalue is interpreted by FreeMarker as "variable does not exist", and accessing a missing variables is usually considered as an error in the FreeMarker Template Language, so the usage of a bad index will not remain hidden, unless the default value for that case was also specified in the template. - Throws:
TemplateModelException
-
size
public int size() throws TemplateModelException- Specified by:
sizein interfaceTemplateSequenceModel- Returns:
- the number of items in the list.
- Throws:
TemplateModelException
-
-