Package org.camunda.bpm.impl.juel
Class Parser
java.lang.Object
org.camunda.bpm.impl.juel.Parser
Handcrafted top-down parser.
- Author:
- Christoph Beck
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classProvide limited support for syntax extensions.static enumstatic classParse exception type
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final Builderprotected Map<Scanner.ExtensionToken,Parser.ExtensionHandler> protected final Scanner
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected AstNodeadd(boolean required) add := add (<PLUS> mul | <MINUS> mul)*protected AstNodeand(boolean required) and := eq (<AND> eq)*protected AstNodecmp(boolean required) cmp := add (<LT> add | <LE> add | <GE> add | <GT> add)*protected final Scanner.Tokenconsume current token (get next token).protected final Scanner.TokenconsumeToken(Scanner.Symbol expected) consume current token (get next token); throw exception if the current token doesn't match the expected symbol.protected AstBinarycreateAstBinary(AstNode left, AstNode right, AstBinary.Operator operator) protected AstBracketcreateAstBracket(AstNode base, AstNode property, boolean lvalue, boolean strict) protected AstChoicecreateAstChoice(AstNode question, AstNode yes, AstNode no) protected AstCompositecreateAstComposite(List<AstNode> nodes) protected AstDotcreateAstDot(AstNode base, String property, boolean lvalue) protected AstFunctioncreateAstFunction(String name, int index, AstParameters params) protected AstIdentifiercreateAstIdentifier(String name, int index) protected AstMethodcreateAstMethod(AstProperty property, AstParameters params) protected AstUnarycreateAstUnary(AstNode child, AstUnary.Operator operator) protected ScannercreateScanner(String expression) protected AstNodeeq(boolean required) eq := cmp (<EQ> cmp | <NE> cmp)*protected AstEvaleval()eval := dynamic | deferredprotected AstEvaleval(boolean required, boolean deferred) dynmamic := <START_EVAL_DYNAMIC> expr <END_EVAL> deferred := <START_EVAL_DEFERRED> expr <END_EVAL>protected AstNodeexpr(boolean required) expr := or (<QUESTION> expr <COLON> expr)?protected voidthrow exceptionprotected voidfail(Scanner.Symbol expected) throw exceptionprotected final AstFunctionfunction(String name, AstParameters params) protected Parser.ExtensionHandlergetExtensionHandler(Scanner.Token token) protected final List<FunctionNode>protected final List<IdentifierNode>protected final Scanner.TokengetToken()protected final AstIdentifieridentifier(String name) protected AstNodeliteral()literal := <TRUE> | <FALSE> | <STRING> | <INTEGER> | <FLOAT> | <NULL>protected final Scanner.Tokenlookahead(int index) get lookahead symbol.protected AstNodemul(boolean required) mul := unary (<MUL> unary | <DIV> unary | <MOD> unary)*protected AstNodenonliteral := <IDENTIFIER> | function | <LPAREN> expr <RPAREN> function := (<IDENTIFIER> <COLON>)? <IDENTIFIER> <LPAREN> list? <RPAREN>protected AstNodeor(boolean required) or := and (<OR> and)*protected AstParametersparams()params := <LPAREN> (expr (<COMMA> expr)*)? <RPAREN>protected NumberparseFloat(String string) Parse a floating point literal.protected NumberparseInteger(String string) Parse an integer literal.voidputExtensionHandler(Scanner.ExtensionToken token, Parser.ExtensionHandler extension) protected AstNodetext()text := <TEXT>tree()tree := text? ((dynamic text?)+ | (deferred text?)+)?protected AstNodeunary(boolean required) unary := <NOT> unary | <MINUS> unary | <EMPTY> unary | valueprotected AstNodevalue()value := (nonliteral | literal) (<DOT> <IDENTIFIER> | <LBRACK> expr <RBRACK>)*
- 
Field Details- 
context
- 
scanner
- 
extensions
 
- 
- 
Constructor Details- 
Parser
 
- 
- 
Method Details- 
createScanner
- 
putExtensionHandler
- 
getExtensionHandler
- 
parseIntegerParse an integer literal.- Parameters:
- string- string to parse
- Returns:
- Long.valueOf(string)
- Throws:
- Parser.ParseException
 
- 
parseFloatParse a floating point literal.- Parameters:
- string- string to parse
- Returns:
- Double.valueOf(string)
- Throws:
- Parser.ParseException
 
- 
createAstBinary
- 
createAstBracketprotected AstBracket createAstBracket(AstNode base, AstNode property, boolean lvalue, boolean strict) 
- 
createAstChoice
- 
createAstComposite
- 
createAstDot
- 
createAstFunction
- 
createAstIdentifier
- 
createAstMethod
- 
createAstUnary
- 
getFunctions
- 
getIdentifiers
- 
getToken
- 
failthrow exception- Throws:
- Parser.ParseException
 
- 
failthrow exception- Throws:
- Parser.ParseException
 
- 
lookaheadprotected final Scanner.Token lookahead(int index) throws Scanner.ScanException, Parser.ParseException get lookahead symbol.
- 
consumeTokenconsume current token (get next token).- Returns:
- the consumed token (which was the current token when calling this method)
- Throws:
- Scanner.ScanException
- Parser.ParseException
 
- 
consumeTokenprotected final Scanner.Token consumeToken(Scanner.Symbol expected) throws Scanner.ScanException, Parser.ParseException consume current token (get next token); throw exception if the current token doesn't match the expected symbol.
- 
treetree := text? ((dynamic text?)+ | (deferred text?)+)?
- 
texttext := <TEXT>
- 
evaleval := dynamic | deferred
- 
evalprotected AstEval eval(boolean required, boolean deferred) throws Scanner.ScanException, Parser.ParseException dynmamic := <START_EVAL_DYNAMIC> expr <END_EVAL> deferred := <START_EVAL_DEFERRED> expr <END_EVAL>
- 
exprexpr := or (<QUESTION> expr <COLON> expr)?
- 
oror := and (<OR> and)*
- 
andand := eq (<AND> eq)*
- 
eqeq := cmp (<EQ> cmp | <NE> cmp)*
- 
cmpcmp := add (<LT> add | <LE> add | <GE> add | <GT> add)*
- 
addadd := add (<PLUS> mul | <MINUS> mul)*
- 
mulmul := unary (<MUL> unary | <DIV> unary | <MOD> unary)*
- 
unaryunary := <NOT> unary | <MINUS> unary | <EMPTY> unary | value
- 
valuevalue := (nonliteral | literal) (<DOT> <IDENTIFIER> | <LBRACK> expr <RBRACK>)*
- 
nonliteralnonliteral := <IDENTIFIER> | function | <LPAREN> expr <RPAREN> function := (<IDENTIFIER> <COLON>)? <IDENTIFIER> <LPAREN> list? <RPAREN>
- 
paramsparams := <LPAREN> (expr (<COMMA> expr)*)? <RPAREN>
- 
literalliteral := <TRUE> | <FALSE> | <STRING> | <INTEGER> | <FLOAT> | <NULL>
- 
function
- 
identifier
 
-