Class Parser
java.lang.Object
org.apache.velocity.runtime.parser.Parser
- All Implemented Interfaces:
ParserConstants
,ParserTreeConstants
This class is responsible for parsing a Velocity
template. This class was generated by JavaCC using
the JJTree extension to produce an Abstract
Syntax Tree (AST) of the template.
Please look at the Parser.jjt file which is
what controls the generation of this class.
- Version:
- $Id: Parser.java 928463 2010-03-28 18:11:34Z nbubna $
- Author:
- Jason van Zyl, Geir Magnusson Jr., Henning P. Schmiedehausen
-
Field Summary
FieldsModifier and TypeFieldDescriptionName of current template we are parsing.Next token.protected JJTParserState
boolean
Set to true if the property RuntimeConstants.RUNTIME_REFERENCES_STRICT_ESCAPE is set to trueCurrent token.Generated Token Manager.Fields inherited from interface org.apache.velocity.runtime.parser.ParserConstants
ALPHA_CHAR, ALPHANUM_CHAR, BRACKETED_WORD, COLON, COMMA, DEFAULT, DIGIT, DIRECTIVE, DIRECTIVE_CHAR, DIRECTIVE_TERMINATOR, DIVIDE, DOLLAR, DOLLARBANG, DOT, DOUBLE_ESCAPE, DOUBLEDOT, ELSE_DIRECTIVE, ELSEIF_DIRECTIVE, EMPTY_INDEX, END, EOF, EQUALS, ESCAPE, ESCAPE_DIRECTIVE, EXPONENT, FALSE, FLOATING_POINT_LITERAL, FORMAL_COMMENT, HASH, IDENTIFIER, IDENTIFIER_CHAR, IF_DIRECTIVE, IN_FORMAL_COMMENT, IN_MULTI_LINE_COMMENT, IN_SINGLE_LINE_COMMENT, IN_TEXTBLOCK, INDEX_LBRACKET, INDEX_RBRACKET, INTEGER_LITERAL, LBRACKET, LCURLY, LEFT_CURLEY, LETTER, LOGICAL_AND, LOGICAL_EQUALS, LOGICAL_GE, LOGICAL_GT, LOGICAL_LE, LOGICAL_LT, LOGICAL_NOT, LOGICAL_NOT_EQUALS, LOGICAL_OR, LPAREN, MINUS, MODULUS, MULTI_LINE_COMMENT, MULTIPLY, NEWLINE, PLUS, PRE_DIRECTIVE, RBRACKET, RCURLY, REFERENCE, REFERENCE_TERMINATOR, REFINDEX, REFMOD, REFMOD2, REFMOD2_RPAREN, REFMODIFIER, RIGHT_CURLEY, RPAREN, SET_DIRECTIVE, SINGLE_LINE_COMMENT, SINGLE_LINE_COMMENT_START, STRING_LITERAL, TEXT, TEXTBLOCK, tokenImage, TRUE, WHITESPACE, WORD
Fields inherited from interface org.apache.velocity.runtime.parser.ParserTreeConstants
JJTADDNODE, JJTANDNODE, JJTASSIGNMENT, JJTBLOCK, JJTCOMMENT, JJTDIRECTIVE, JJTDIVNODE, JJTELSEIFSTATEMENT, JJTELSESTATEMENT, JJTEQNODE, JJTESCAPE, JJTESCAPEDDIRECTIVE, JJTEXPRESSION, JJTFALSE, JJTFLOATINGPOINTLITERAL, JJTGENODE, JJTGTNODE, JJTIDENTIFIER, JJTIFSTATEMENT, JJTINDEX, JJTINTEGERLITERAL, JJTINTEGERRANGE, JJTLENODE, JJTLTNODE, JJTMAP, JJTMETHOD, JJTMODNODE, JJTMULNODE, JJTNENODE, jjtNodeName, JJTNOTNODE, JJTOBJECTARRAY, JJTORNODE, JJTPROCESS, JJTREFERENCE, JJTSETDIRECTIVE, JJTSTRINGLITERAL, JJTSUBTRACTNODE, JJTTEXT, JJTTEXTBLOCK, JJTTRUE, JJTVOID, JJTWORD
-
Constructor Summary
ConstructorsConstructorDescriptionParser
(CharStream stream) Constructor with user supplied CharStream.Constructor with generated Token Manager.This constructor was added to allow the re-use of parsers. -
Method Summary
Modifier and TypeMethodDescriptionfinal void
final void
final void
Comment()
final void
final void
final SimpleNode
Supports the Pluggable Directives #foo( arg+ )final int
Supports the arguments for the Pluggable Directivesfinal void
Disable tracing.final void
final void
final void
Enable tracing.final void
final void
Escape()
Used to catch and process escape sequences in grammatical constructs as escapes outside of VTL are just characters.final void
used to separate the notion of a valid directive that has been escaped, versus something that looks like a directive and is just schmoo.final void
final void
False()
final void
Generate ParseException.getDirective
(String directive) This method gets a Directive from the directives Hashtablefinal Token
Get the next Token.final Token
getToken
(int index) Get the specific Token.final void
This method corresponds to variable references in Velocity templates.final void
final void
Index()
final void
A Simplified parameter more suitable for an index position: $foo[$index]final void
final void
supports the [n..m] vector generator for use in the #foreach() to generate measured ranges w/o needing explicit support from the app/servletboolean
isDirective
(String directive) This method finds out of the directive exists in the directives Map.final void
Map()
for creating a map in a #set #set($foo = {$foo : $bar, $blargh : $thingy})final void
Method()
This method has yet to be fully implemented but will allow arbitrarily nested method callsfinal void
final void
final void
This method has yet to be fully implemented but will allow arbitrarily nested method callsThis was also added to allow parsers to be re-usable.final void
final SimpleNode
process()
This method is what starts the whole parsing process.final void
void
ReInit
(CharStream stream) Reinitialise.void
Reinitialise.final void
final void
Currently support both types of set : #set( expr ) #set exprfinal void
These are the types of statements that are acceptable in Velocity templates.final void
final void
Text()
This method is responsible for allowing all non-grammar text to pass through unscathed.final void
final void
True()
final void
final void
Word()
-
Field Details
-
jjtree
-
currentTemplateName
Name of current template we are parsing. Passed to us in parse() -
strictEscape
public boolean strictEscapeSet to true if the property RuntimeConstants.RUNTIME_REFERENCES_STRICT_ESCAPE is set to true -
token_source
Generated Token Manager. -
token
Current token. -
jj_nt
Next token.
-
-
Constructor Details
-
Parser
This constructor was added to allow the re-use of parsers. The normal constructor takes a single argument which an InputStream. This simply creates a re-usable parser object, we satisfy the requirement of an InputStream by using a newline character as an input stream. -
Parser
Constructor with user supplied CharStream. -
Parser
Constructor with generated Token Manager.
-
-
Method Details
-
parse
This was also added to allow parsers to be re-usable. Normal JavaCC use entails passing an input stream to the constructor and the parsing process is carried out once. We want to be able to re-use parsers: we do this by adding this method and re-initializing the lexer with the new stream that we want parsed.- Throws:
ParseException
-
getDirective
This method gets a Directive from the directives Hashtable -
isDirective
This method finds out of the directive exists in the directives Map. -
process
This method is what starts the whole parsing process. After the parsing is complete and the template has been turned into an AST, this method returns the root of AST which can subsequently be traversed by a visitor which implements the ParserVisitor interface which is generated automatically by JavaCC- Throws:
ParseException
-
Statement
These are the types of statements that are acceptable in Velocity templates.- Throws:
ParseException
-
EscapedDirective
used to separate the notion of a valid directive that has been escaped, versus something that looks like a directive and is just schmoo. This is important to do as a separate production that creates a node, because we want this, in either case, to stop the further parsing of the Directive() tree.- Throws:
ParseException
-
Escape
Used to catch and process escape sequences in grammatical constructs as escapes outside of VTL are just characters. Right now we have both this and the EscapeDirective() construction because in the EscapeDirective() case, we want to suck in the #and here we don't. We just want the escapes to render correctly - Throws:
ParseException
-
Comment
- Throws:
ParseException
-
Textblock
- Throws:
ParseException
-
FloatingPointLiteral
- Throws:
ParseException
-
IntegerLiteral
- Throws:
ParseException
-
StringLiteral
- Throws:
ParseException
-
Identifier
This method corresponds to variable references in Velocity templates. The following are examples of variable references that may be found in a template: $foo $bar- Throws:
ParseException
-
Word
- Throws:
ParseException
-
DirectiveArg
Supports the arguments for the Pluggable Directives- Throws:
ParseException
-
Directive
Supports the Pluggable Directives #foo( arg+ )- Throws:
ParseException
-
Map
for creating a map in a #set #set($foo = {$foo : $bar, $blargh : $thingy})- Throws:
ParseException
-
ObjectArray
- Throws:
ParseException
-
IntegerRange
supports the [n..m] vector generator for use in the #foreach() to generate measured ranges w/o needing explicit support from the app/servlet- Throws:
ParseException
-
IndexParameter
A Simplified parameter more suitable for an index position: $foo[$index]- Throws:
ParseException
-
Parameter
This method has yet to be fully implemented but will allow arbitrarily nested method calls- Throws:
ParseException
-
Method
This method has yet to be fully implemented but will allow arbitrarily nested method calls- Throws:
ParseException
-
Index
- Throws:
ParseException
-
Reference
- Throws:
ParseException
-
True
- Throws:
ParseException
-
False
- Throws:
ParseException
-
Text
This method is responsible for allowing all non-grammar text to pass through unscathed.- Throws:
ParseException
-
IfStatement
- Throws:
ParseException
-
ElseStatement
- Throws:
ParseException
-
ElseIfStatement
- Throws:
ParseException
-
SetDirective
Currently support both types of set : #set( expr ) #set expr- Throws:
ParseException
-
Expression
- Throws:
ParseException
-
Assignment
- Throws:
ParseException
-
ConditionalOrExpression
- Throws:
ParseException
-
ConditionalAndExpression
- Throws:
ParseException
-
EqualityExpression
- Throws:
ParseException
-
RelationalExpression
- Throws:
ParseException
-
AdditiveExpression
- Throws:
ParseException
-
MultiplicativeExpression
- Throws:
ParseException
-
UnaryExpression
- Throws:
ParseException
-
PrimaryExpression
- Throws:
ParseException
-
ReInit
Reinitialise. -
ReInit
Reinitialise. -
getNextToken
Get the next Token. -
getToken
Get the specific Token. -
generateParseException
Generate ParseException. -
enable_tracing
public final void enable_tracing()Enable tracing. -
disable_tracing
public final void disable_tracing()Disable tracing.
-