Class Directive
- java.lang.Object
-
- org.apache.velocity.runtime.directive.Directive
-
- All Implemented Interfaces:
Cloneable,DirectiveConstants
- Direct Known Subclasses:
Block,Break,Evaluate,Foreach,InputBase,Macro,RuntimeMacro,Stop,VelocimacroProxy
public abstract class Directive extends Object implements DirectiveConstants, Cloneable
Base class for all directives used in Velocity.- Version:
- $Id$
- Author:
- Jason van Zyl, Nathan Bubna
-
-
Field Summary
Fields Modifier and Type Field Description protected org.slf4j.Loggerlogprotected RuntimeServicesrsvc-
Fields inherited from interface org.apache.velocity.runtime.directive.DirectiveConstants
BLOCK, LINE
-
-
Constructor Summary
Constructors Constructor Description Directive()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidcheckArgs(ArrayList<Integer> argtypes, Token t, String templateName)The Parser calls this method during template parsing to check the arguments types.intgetColumn()for log msg purposesintgetLine()for log msg purposesabstract StringgetName()Return the name of this directive.StringgetScopeName()TemplategetTemplate()returns the template in which this directive appearsStringgetTemplateName()abstract intgetType()Get the directive type BLOCK/LINE.voidinit(RuntimeServices rs, InternalContextAdapter context, Node node)How this directive is to be initialized.booleanisScopeProvided()protected ScopemakeScope(Object prev)protected voidpostRender(InternalContextAdapter context)This cleans up any scope control for this directive after rendering, assuming the scope control was turned on.protected voidpreRender(InternalContextAdapter context)This creates and places the scope control for this directive into the context (if scope provision is turned on).abstract booleanrender(InternalContextAdapter context, Writer writer, Node node)How this directive is to be renderedvoidsetLocation(int line, int column)Allows the template location to be set.voidsetLocation(int line, int column, Template template)Allows the template location to be set.
-
-
-
Field Detail
-
log
protected org.slf4j.Logger log
-
rsvc
protected RuntimeServices rsvc
-
-
Method Detail
-
getName
public abstract String getName()
Return the name of this directive.- Returns:
- The name of this directive.
-
getType
public abstract int getType()
Get the directive type BLOCK/LINE.- Returns:
- The directive type BLOCK/LINE.
-
setLocation
public void setLocation(int line, int column)Allows the template location to be set.- Parameters:
line-column-
-
setLocation
public void setLocation(int line, int column, Template template)Allows the template location to be set.- Parameters:
line-column-template-
-
getTemplate
public Template getTemplate()
returns the template in which this directive appears- Returns:
- template
-
getLine
public int getLine()
for log msg purposes- Returns:
- The current line for log msg purposes.
-
getColumn
public int getColumn()
for log msg purposes- Returns:
- The current column for log msg purposes.
-
getTemplateName
public String getTemplateName()
- Returns:
- The template file name this directive was defined in, or null if not defined in a file.
-
getScopeName
public String getScopeName()
- Returns:
- the name to be used when a scope control is provided for this directive.
-
isScopeProvided
public boolean isScopeProvided()
- Returns:
- true if there will be a scope control injected into the context when rendering this directive.
-
init
public void init(RuntimeServices rs, InternalContextAdapter context, Node node) throws TemplateInitException
How this directive is to be initialized.- Parameters:
rs-context-node-- Throws:
TemplateInitException
-
checkArgs
public void checkArgs(ArrayList<Integer> argtypes, Token t, String templateName) throws ParseException
The Parser calls this method during template parsing to check the arguments types. Be aware that this method is called pre init, so not all data is available in this method. The default implementation does not peform any checking. We do this so that Custom directives do not trigger any parse errors in IDEs.- Parameters:
argtypes- type, Array of argument types of each argument to the directive for example StandardParserTreeConstants.JJTWORDt- token of directivetemplateName- the name of the template this directive is referenced in.- Throws:
ParseException
-
render
public abstract boolean render(InternalContextAdapter context, Writer writer, Node node) throws IOException, ResourceNotFoundException, ParseErrorException, MethodInvocationException
How this directive is to be rendered- Parameters:
context-writer-node-- Returns:
- True if the directive rendered successfully.
- Throws:
IOExceptionResourceNotFoundExceptionParseErrorExceptionMethodInvocationException
-
preRender
protected void preRender(InternalContextAdapter context)
This creates and places the scope control for this directive into the context (if scope provision is turned on).- Parameters:
context-
-
postRender
protected void postRender(InternalContextAdapter context)
This cleans up any scope control for this directive after rendering, assuming the scope control was turned on.- Parameters:
context-
-
-