<VAR> VariableDeclarator() ( <COMMA> VariableDeclarator() )* <SEMICOLON>
}
-void VariableDeclarator() :
-{}
+String VariableDeclarator() :
+{
+ String expr;
+ StringBuffer buff = new StringBuffer();
+}
{
- VariableDeclaratorId() [ <ASSIGN> VariableInitializer() ]
+ expr = VariableDeclaratorId()
+ {buff.append(expr);}
+ [ <ASSIGN> expr = VariableInitializer()
+ {buff.append("=").append(expr);}
+ ]
+ {return buff.toString();}
}
-void VariableDeclaratorId() :
-{}
+String VariableDeclaratorId() :
+{
+ String expr;
+ StringBuffer buff = new StringBuffer();
+}
{
- Variable() ( LOOKAHEAD(2) VariableSuffix() )*
+ expr = Variable()
+ {buff.append(expr);}
+ ( LOOKAHEAD(2) expr = VariableSuffix()
+ {buff.append(expr);}
+ )*
+ {return buff.toString();}
}
-void Variable():
-{}
+String Variable():
+{
+ String expr = null;
+ Token token;
+}
{
- <DOLLAR_ID> (<LBRACE> Expression() <RBRACE>) *
+ token = <DOLLAR_ID> [<LBRACE> expr = Expression() <RBRACE>]
+ {
+ if (expr == null) {
+ return token.image;
+ }
+ return token + "{" + expr + "}";
+ }
|
- <DOLLAR> VariableName()
+ <DOLLAR> expr = VariableName()
+ {return "$" + expr;}
}
String VariableName():
-{}
{
- <LBRACE> Expression() <RBRACE>
-|
- <IDENTIFIER> (<LBRACE> Expression() <RBRACE>) *
+String expr = null;
+Token token;
+}
+{
+ <LBRACE> expr = Expression() <RBRACE>
+ {return "{"+expr+"}";}
|
- <DOLLAR> VariableName()
+ token = <IDENTIFIER> [<LBRACE> expr = Expression() <RBRACE>]
+ {
+ if (expr == null) {
+ return token.image;
+ }
+ return token + "{" + expr + "}";
+ }|
+ <DOLLAR> expr = VariableName()
+ {return "$" + expr;}
}
-void VariableInitializer() :
-{}
+String VariableInitializer() :
{
- Expression()
+ String expr;
+}
+{
+ expr = Expression()
+ {return expr;}
}
-void ArrayVariable() :
-{}
+String ArrayVariable() :
{
- Expression() (<ARRAYASSIGN> Expression())*
+String expr;
+StringBuffer buff = new StringBuffer();
+}
+{
+ expr = Expression()
+ {buff.append(expr);}
+ [<ARRAYASSIGN> expr = Expression()
+ {buff.append("=>").append(expr);}]
+ {return buff.toString();}
}
-void ArrayInitializer() :
-{}
+String ArrayInitializer() :
+{
+String expr = null;
+StringBuffer buff = new StringBuffer("(");
+}
{
- <LPAREN> [ ArrayVariable() ( LOOKAHEAD(2) <COMMA> ArrayVariable() )* ]<RPAREN>
+ <LPAREN> [ expr = ArrayVariable()
+ {buff.append(expr);}
+ ( LOOKAHEAD(2) <COMMA> expr = ArrayVariable()
+ {buff.append(",").append(expr);}
+ )* ]
+ <RPAREN>
+ {
+ buff.append(")");
+ return buff.toString();
+ }
}
void MethodDeclaration() :
PHPFunctionDeclaration MethodDeclarator() :
{
- Token bit_and = null;
Token identifier;
StringBuffer methodDeclaration = new StringBuffer();
String formalParameters;
int pos = jj_input_stream.bufpos;
}
{
- [ bit_and = <BIT_AND>]
- identifier = <IDENTIFIER> FormalParameters()
+ [ <BIT_AND> {methodDeclaration.append("&");}]
+ identifier = <IDENTIFIER> formalParameters = FormalParameters()
{
- if (bit_and != null) {
- methodDeclaration.append("&");
- }
- methodDeclaration.append(identifier);
+ methodDeclaration.append(identifier).append(formalParameters);
return new PHPFunctionDeclaration(currentSegment,methodDeclaration.toString(),pos);
}
}
-void FormalParameters() :
-{}
+String FormalParameters() :
+{
+ String expr;
+ StringBuffer buff = new StringBuffer("(");
+}
{
- <LPAREN> [ FormalParameter() ( <COMMA> FormalParameter() )* ] <RPAREN>
+ <LPAREN> [ expr = FormalParameter() {buff.append(expr);}
+ ( <COMMA> expr = FormalParameter()
+ {buff.append(",").append(expr);}
+ )* ] <RPAREN>
+ {
+ buff.append(")");
+ return buff.toString();
+ }
}
-void FormalParameter() :
-{}
+String FormalParameter() :
+{
+ String expr;
+ StringBuffer buff = new StringBuffer();
+}
{
- [<BIT_AND>] VariableDeclarator()
+ [<BIT_AND> {buff.append("&");}] expr = VariableDeclarator()
+ {
+ buff.append(expr);
+ return buff.toString();
+ }
}
-void Type() :
+String Type() :
{}
{
<STRING>
+ {return "string";}
|
<BOOL>
+ {return "bool";}
|
<BOOLEAN>
+ {return "boolean";}
|
<REAL>
+ {return "real";}
|
<DOUBLE>
+ {return "double";}
|
<FLOAT>
+ {return "float";}
|
<INT>
+ {return "int";}
|
<INTEGER>
+ {return "integer";}
}
-void Expression() :
-{}
+String Expression() :
+{
+ String expr;
+ String assignOperator = null;
+ String expr2 = null;
+}
{
- PrintExpression()
+ expr = PrintExpression()
+ {return expr;}
|
- ConditionalExpression()
+ expr = ConditionalExpression()
[
- AssignmentOperator() Expression()
+ assignOperator = AssignmentOperator()
+ expr2 = Expression()
]
+ {
+ if (expr2 == null) {
+ return expr;
+ } else {
+ return expr + assignOperator + expr2;
+ }
+ }
}
-void AssignmentOperator() :
-{}
-{
- <ASSIGN> | <STARASSIGN> | <SLASHASSIGN> | <REMASSIGN> | <PLUSASSIGN> | <MINUSASSIGN> | <LSHIFTASSIGN> | <RSIGNEDSHIFTASSIGN> | <RUNSIGNEDSHIFTASSIGN> | <ANDASSIGN> | <XORASSIGN> | <ORASSIGN> | <DOTASSIGN>
+String AssignmentOperator() :
+{
+ Token assignOperator;
+}
+{
+ <ASSIGN>
+{return "=";}
+| <STARASSIGN>
+{return "*=";}
+| <SLASHASSIGN>
+{return "/=";}
+| <REMASSIGN>
+{return "%=";}
+| <PLUSASSIGN>
+{return "+=";}
+| <MINUSASSIGN>
+{return "-=";}
+| <LSHIFTASSIGN>
+{return "<<=";}
+| <RSIGNEDSHIFTASSIGN>
+{return ">>=";}
+| <RUNSIGNEDSHIFTASSIGN>
+{return ">>>=";}
+| <ANDASSIGN>
+{return "&=";}
+| <XORASSIGN>
+{return "|=";}
+| <ORASSIGN>
+{return "|=";}
+| <DOTASSIGN>
+{return ".=";}
+}
+
+String ConditionalExpression() :
+{
+ String expr;
+ String expr2 = null;
+ String expr3 = null;
+}
+{
+ expr = ConditionalOrExpression() [ <HOOK> expr2 = Expression() <COLON> expr3 = ConditionalExpression() ]
+{
+ if (expr3 == null) {
+ return expr;
+ } else {
+ return expr + "?" + expr2 + ":" + expr3;
+ }
+}
}
-void ConditionalExpression() :
-{}
+String ConditionalOrExpression() :
{
- ConditionalOrExpression() [ <HOOK> Expression() <COLON> ConditionalExpression() ]
+ String expr;
+ Token operator;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
}
-
-void ConditionalOrExpression() :
-{}
{
- ConditionalAndExpression() ( (<SC_OR> | <_ORL>) ConditionalAndExpression() )*
+ expr = ConditionalAndExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ (operator = <SC_OR> | operator = <_ORL>) expr2 = ConditionalAndExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void ConditionalAndExpression() :
-{}
+String ConditionalAndExpression() :
+{
+ String expr;
+ Token operator;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
+}
{
- ConcatExpression() ( (<SC_AND> | <_ANDL>) ConcatExpression() )*
+ expr = ConcatExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ (operator = <SC_AND> | operator = <_ANDL>) expr2 = ConcatExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void ConcatExpression() :
-{}
+String ConcatExpression() :
+{
+ String expr;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
+}
{
- InclusiveOrExpression() ( <DOT> InclusiveOrExpression() )*
+ expr = InclusiveOrExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ <DOT> expr2 = InclusiveOrExpression()
+ {
+ buff.append(".");
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void InclusiveOrExpression() :
-{}
+String InclusiveOrExpression() :
+{
+ String expr;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
+}
{
- ExclusiveOrExpression() ( <BIT_OR> ExclusiveOrExpression() )*
+ expr = ExclusiveOrExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ <BIT_OR> expr2 = ExclusiveOrExpression()
+ {
+ buff.append("|");
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void ExclusiveOrExpression() :
-{}
+String ExclusiveOrExpression() :
+{
+ String expr;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
+}
{
- AndExpression() ( <XOR> AndExpression() )*
+ expr = AndExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ <XOR> expr2 = AndExpression()
+ {
+ buff.append("^");
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void AndExpression() :
-{}
+String AndExpression() :
+{
+ String expr;
+ String expr2 = null;
+ StringBuffer buff = new StringBuffer();
+}
{
- EqualityExpression() ( <BIT_AND> EqualityExpression() )*
+ expr = EqualityExpression()
+ {
+ buff.append(expr);
+ }
+ (
+ <BIT_AND> expr2 = EqualityExpression()
+ {
+ buff.append("&");
+ buff.append(expr2);
+ }
+ )*
+ {
+ return buff.toString();
+ }
}
-void EqualityExpression() :
-{}
+String EqualityExpression() :
{
- RelationalExpression() ( ( <EQ> | <NE> ) RelationalExpression() )*
+ String expr;
+ Token operator;
+ String expr2;
+ StringBuffer buff = new StringBuffer();
+}
+{
+ expr = RelationalExpression()
+ {buff.append(expr);}
+ (
+ ( operator = <EQ> | operator = <NE> ) expr2 = RelationalExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {return buff.toString();}
}
-void RelationalExpression() :
-{}
+String RelationalExpression() :
{
- ShiftExpression() ( ( <LT> | <GT> | <LE> | <GE> ) ShiftExpression() )*
+ String expr;
+ Token operator;
+ String expr2;
+ StringBuffer buff = new StringBuffer();
+}
+{
+ expr = ShiftExpression()
+ {buff.append(expr);}
+ (
+ ( operator = <LT> | operator = <GT> | operator = <LE> | operator = <GE> ) expr2 = ShiftExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {return buff.toString();}
}
-void ShiftExpression() :
-{}
+String ShiftExpression() :
+{
+ String expr;
+ Token operator;
+ String expr2;
+ StringBuffer buff = new StringBuffer();
+}
{
- AdditiveExpression() ( ( <LSHIFT> | <RSIGNEDSHIFT> | <RUNSIGNEDSHIFT> ) AdditiveExpression() )*
+ expr = AdditiveExpression()
+ {buff.append(expr);}
+ (
+ (operator = <LSHIFT> | operator = <RSIGNEDSHIFT> | operator = <RUNSIGNEDSHIFT> ) expr2 = AdditiveExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {return buff.toString();}
}
-void AdditiveExpression() :
-{}
+String AdditiveExpression() :
{
- MultiplicativeExpression() ( ( <PLUS> | <MINUS> ) MultiplicativeExpression() )*
+ String expr;
+ Token operator;
+ String expr2;
+ StringBuffer buff = new StringBuffer();
+}
+{
+ expr = MultiplicativeExpression()
+ {buff.append(expr);}
+ (
+ ( operator = <PLUS> | operator = <MINUS> ) expr2 = MultiplicativeExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {return buff.toString();}
}
-void MultiplicativeExpression() :
-{}
+String MultiplicativeExpression() :
{
- UnaryExpression() ( ( <STAR> | <SLASH> | <REM> ) UnaryExpression() )*
+ String expr;
+ Token operator;
+ String expr2;
+ StringBuffer buff = new StringBuffer();}
+{
+ expr = UnaryExpression()
+ {buff.append(expr);}
+ (
+ ( operator = <STAR> | operator = <SLASH> | operator = <REM> ) expr2 = UnaryExpression()
+ {
+ buff.append(operator.image);
+ buff.append(expr2);
+ }
+ )*
+ {return buff.toString();}
}
-void UnaryExpression() :
-{}
+String UnaryExpression() :
+{
+ String expr;
+ StringBuffer buff = new StringBuffer();
+}
{
- <AT> UnaryExpression()
+ <AT> expr = UnaryExpression()
+ {return "@" + expr;}
|
- ( <PLUS> | <MINUS> ) UnaryExpression()
+ ( <PLUS> {buff.append("+");}| <MINUS> {buff.append("-");}) expr = UnaryExpression()
+ {
+ buff.append(expr);
+ return buff.toString();
+ }
|
- PreIncrementExpression()
+ expr = PreIncrementExpression()
+ {return expr;}
|
- PreDecrementExpression()
+ expr = PreDecrementExpression()
+ {return expr;}
|
- UnaryExpressionNotPlusMinus()
+ expr = UnaryExpressionNotPlusMinus()
+ {return buff.toString();}
}
-void PreIncrementExpression() :
-{}
+String PreIncrementExpression() :
+{
+String expr;
+}
{
- <INCR> PrimaryExpression()
+ <INCR> expr = PrimaryExpression()
+ {return "++"+expr;}
}
-void PreDecrementExpression() :
-{}
+String PreDecrementExpression() :
+{
+String expr;
+}
{
- <DECR> PrimaryExpression()
+ <DECR> expr = PrimaryExpression()
+ {return "--"+expr;}
}
-void UnaryExpressionNotPlusMinus() :
-{}
+String UnaryExpressionNotPlusMinus() :
+{
+ String expr;
+}
{
- <BANG> UnaryExpression()
+ <BANG> expr = UnaryExpression()
+ {return "!" + expr;}
|
LOOKAHEAD( <LPAREN> Type() <RPAREN> )
- CastExpression()
+ expr = CastExpression()
+ {return expr;}
|
- PostfixExpression()
+ expr = PostfixExpression()
+ {return expr;}
|
- Literal()
+ expr = Literal()
+ {return expr;}
|
- <LPAREN>Expression()<RPAREN>
+ <LPAREN> expr = Expression()<RPAREN>
+ {return "("+expr+")";}
}
-void CastExpression() :
-{}
+String CastExpression() :
{
- <LPAREN> Type() <RPAREN> UnaryExpression()
+String type;
+String expr;
+}
+{
+ <LPAREN> type = Type() <RPAREN> expr = UnaryExpression()
+ {return "(" + type + ")" + expr;}
}
-void PostfixExpression() :
-{}
+String PostfixExpression() :
+{
+ String expr;
+ Token operator = null;
+}
{
- PrimaryExpression() [ <INCR> | <DECR> ]
+ expr = PrimaryExpression() [ operator = <INCR> | operator = <DECR> ]
+ {
+ if (operator == null) {
+ return expr;
+ }
+ return expr + operator.image;
+ }
}
-void PrimaryExpression() :
-{}
+String PrimaryExpression() :
+{
+ Token identifier;
+ String expr;
+ StringBuffer buff = new StringBuffer();
+}
{
LOOKAHEAD(2)
- <IDENTIFIER> <STATICCLASSACCESS> ClassIdentifier() (PrimarySuffix())*
+ identifier = <IDENTIFIER> <STATICCLASSACCESS> expr = ClassIdentifier()
+ {buff.append(identifier.image).append("::").append(expr);}
+ (
+ expr = PrimarySuffix()
+ {buff.append(expr);}
+ )*
+ {return buff.toString();}
|
- PrimaryPrefix() ( PrimarySuffix() )*
+ expr = PrimaryPrefix()
+ {buff.append(expr);}
+ (
+ expr = PrimarySuffix()
+ {buff.append(expr);}
+ )*
+ {return buff.toString();}
|
- <ARRAY> ArrayInitializer()
+ <ARRAY> expr = ArrayInitializer()
+ {return "array" + expr;}
}
-void PrimaryPrefix() :
-{}
+String PrimaryPrefix() :
{
- <IDENTIFIER>
+ String expr;
+ Token token = null;
+}
+{
+ token = <IDENTIFIER>
+ {return token.image;}
|
- [<BIT_AND>] <NEW> ClassIdentifier()
+ [token = <BIT_AND>] <NEW> expr = ClassIdentifier()
+ {
+ if (token == null) {
+ return "new " + expr;
+ }
+ return "new " + expr;
+ }
|
- VariableDeclaratorId()
+ expr = VariableDeclaratorId()
+ {return expr;}
}
-void ClassIdentifier():
-{}
+String ClassIdentifier():
{
- <IDENTIFIER>
+ String expr;
+ Token token;
+}
+{
+ token = <IDENTIFIER>
+ {return token.image;}
|
- VariableDeclaratorId()
+ expr = VariableDeclaratorId()
+ {return expr;}
}
-void PrimarySuffix() :
-{}
+String PrimarySuffix() :
{
- Arguments()
+ String expr;
+}
+{
+ expr = Arguments()
+ {return expr;}
|
- VariableSuffix()
+ expr = VariableSuffix()
+ {return expr;}
}
-void VariableSuffix() :
-{}
+String VariableSuffix() :
{
- <CLASSACCESS> VariableName()
+ String expr = null;
+}
+{
+ <CLASSACCESS> expr = VariableName()
+ {return "->" + expr;}
|
- <LBRACKET> [ Expression() ] <RBRACKET>
+ <LBRACKET> [ expr = Expression() ] <RBRACKET>
+ {
+ if(expr == null) {
+ return "[]";
+ }
+ return "[" + expr + "]";
+ }
}
-void Literal() :
-{}
+String Literal() :
{
- <INTEGER_LITERAL>
+ String expr;
+ Token token;
+}
+{
+ token = <INTEGER_LITERAL>
+ {return token.image;}
|
- <FLOATING_POINT_LITERAL>
+ token = <FLOATING_POINT_LITERAL>
+ {return token.image;}
|
try {
- <STRING_LITERAL>
+ token = <STRING_LITERAL>
+ {return token.image;}
} catch (TokenMgrError e) {
errorMessage = "unterminated string";
errorLevel = ERROR;
throw generateParseException();
}
|
- BooleanLiteral()
+ expr = BooleanLiteral()
+ {return expr;}
|
- NullLiteral()
+ expr = NullLiteral()
+ {return expr;}
}
-void BooleanLiteral() :
+String BooleanLiteral() :
{}
{
<TRUE>
+ {return "true";}
|
<FALSE>
+ {return "false";}
}
-void NullLiteral() :
+String NullLiteral() :
{}
{
<NULL>
+ {return "null";}
}
-void Arguments() :
-{}
+String Arguments() :
{
- <LPAREN> [ ArgumentList() ]
+String expr = null;
+}
+{
+ <LPAREN> [ expr = ArgumentList() ]
try {
<RPAREN>
} catch (ParseException e) {
errorLevel = ERROR;
throw e;
}
+ {
+ if (expr == null) {
+ return "()";
+ }
+ return "(" + expr + ")";
+ }
}
-void ArgumentList() :
-{}
+String ArgumentList() :
{
- Expression()
+String expr;
+StringBuffer buff = new StringBuffer();
+}
+{
+ expr = Expression()
+ {buff.append(expr);}
( <COMMA>
try {
- Expression()
+ expr = Expression()
} catch (ParseException e) {
errorMessage = "expression expected after a comma in argument list";
errorLevel = ERROR;
throw e;
}
+ {
+ buff.append(",").append("expr");
+ }
)*
+ {return buff.toString();}
}
/*
<INCLUDE_ONCE> Expression() (<SEMICOLON> | "?>")
}
-void PrintExpression() :
-{}
+String PrintExpression() :
+{
+ StringBuffer buff = new StringBuffer("print ");
+ String expr;
+}
{
- <PRINT> Expression()
+ <PRINT> expr = Expression()
+ {
+ buff.append(expr);
+ return buff.toString();
+ }
}
void EchoStatement() :