org.apache.velocity.runtime.directive
Class Directive

java.lang.Object
  extended by org.apache.velocity.runtime.directive.Directive
All Implemented Interfaces:
Cloneable, DirectiveConstants
Direct Known Subclasses:
Break, Define, Evaluate, Foreach, InputBase, Literal, Macro, RuntimeMacro, VelocimacroProxy

public abstract class Directive
extends Object
implements DirectiveConstants, Cloneable

Base class for all directives used in Velocity.

Version:
$Id: Directive.java 724825 2008-12-09 18:56:06Z nbubna $
Author:
Jason van Zyl

Field Summary
protected  RuntimeServices rsvc
           
 
Fields inherited from interface org.apache.velocity.runtime.directive.DirectiveConstants
BLOCK, LINE
 
Constructor Summary
Directive()
           
 
Method Summary
 int getColumn()
          for log msg purposes
 int getLine()
          for log msg purposes
abstract  String getName()
          Return the name of this directive.
 String getTemplateName()
           
abstract  int getType()
          Get the directive type BLOCK/LINE.
 void init(RuntimeServices rs, InternalContextAdapter context, Node node)
          How this directive is to be initialized.
abstract  boolean render(InternalContextAdapter context, Writer writer, Node node)
          How this directive is to be rendered
 void setLocation(int line, int column)
          Allows the template location to be set.
 void setLocation(int line, int column, String templateName)
          Allows the template location to be set.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

rsvc

protected RuntimeServices rsvc
Constructor Detail

Directive

public Directive()
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,
                        String templateName)
Allows the template location to be set.

Parameters:
line -
column -

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.

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

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:
IOException
ResourceNotFoundException
ParseErrorException
MethodInvocationException


Copyright © 2000-2009 The Apache Software Foundation. All Rights Reserved.