* You can test the parser with the PHPParserTestCase2.java
* @author Matthieu Casanova
*/
-public class PHPParser extends PHPParserSuperclass {
+public final class PHPParser extends PHPParserSuperclass {
+ /** The file that is parsed. */
private static IFile fileToParse;
/** The current segment */
private static final String PARSE_ERROR_STRING = "Parse error"; //$NON-NLS-1$
private static final String PARSE_WARNING_STRING = "Warning"; //$NON-NLS-1$
PHPOutlineInfo outlineInfo;
+
+ /** The error level of the current ParseException. */
private static int errorLevel = ERROR;
+ /** The message of the current ParseException. If it's null it's because the parse exception wasn't handled */
private static String errorMessage;
+ private static int errorStart = -1;
+ private static int errorEnd = -1;
+
public PHPParser() {
}
- public void setFileToParse(IFile fileToParse) {
+ public final void setFileToParse(final IFile fileToParse) {
this.fileToParse = fileToParse;
}
- public PHPParser(IFile fileToParse) {
+ public PHPParser(final IFile fileToParse) {
this(new StringReader(""));
this.fileToParse = fileToParse;
}
- public void phpParserTester(String strEval) throws CoreException, ParseException {
+ public static final void phpParserTester(final String strEval) throws CoreException, ParseException {
PHPParserTokenManager.SwitchTo(PHPParserTokenManager.PHPPARSING);
- StringReader stream = new StringReader(strEval);
+ final StringReader stream = new StringReader(strEval);
if (jj_input_stream == null) {
jj_input_stream = new SimpleCharStream(stream, 1, 1);
}
phpTest();
}
- public void htmlParserTester(String strEval) throws CoreException, ParseException {
- StringReader stream = new StringReader(strEval);
+ public static final void htmlParserTester(final String strEval) throws CoreException, ParseException {
+ final StringReader stream = new StringReader(strEval);
if (jj_input_stream == null) {
jj_input_stream = new SimpleCharStream(stream, 1, 1);
}
phpFile();
}
- public PHPOutlineInfo parseInfo(Object parent, String s) {
+ public final PHPOutlineInfo parseInfo(final Object parent, final String s) {
outlineInfo = new PHPOutlineInfo(parent);
currentSegment = outlineInfo.getDeclarations();
- StringReader stream = new StringReader(s);
+ final StringReader stream = new StringReader(s);
if (jj_input_stream == null) {
jj_input_stream = new SimpleCharStream(stream, 1, 1);
}
/**
* Create marker for the parse error
+ * @param e the ParseException
*/
- private static void setMarker(ParseException e) {
+ private static void setMarker(final ParseException e) {
try {
- setMarker(fileToParse,
- errorMessage,
- jj_input_stream.tokenBegin,
- jj_input_stream.tokenBegin + e.currentToken.image.length(),
- errorLevel,
- "Line " + e.currentToken.beginLine);
+ if (errorStart == -1) {
+ setMarker(fileToParse,
+ errorMessage,
+ jj_input_stream.tokenBegin,
+ jj_input_stream.tokenBegin + e.currentToken.image.length(),
+ errorLevel,
+ "Line " + e.currentToken.beginLine);
+ } else {
+ setMarker(fileToParse,
+ errorMessage,
+ errorStart,
+ errorEnd,
+ errorLevel,
+ "Line " + e.currentToken.beginLine);
+ errorStart = -1;
+ errorEnd = -1;
+ }
} catch (CoreException e2) {
PHPeclipsePlugin.log(e2);
}
/**
* Create markers according to the external parser output
*/
- private static void createMarkers(String output, IFile file) throws CoreException {
+ private static void createMarkers(final String output, final IFile file) throws CoreException {
// delete all markers
file.deleteMarkers(IMarker.PROBLEM, false, 0);
int indx = 0;
- int brIndx = 0;
+ int brIndx;
boolean flag = true;
while ((brIndx = output.indexOf("<br />", indx)) != -1) {
// newer php error output (tested with 4.2.3)
}
}
- private static void scanLine(String output, IFile file, int indx, int brIndx) throws CoreException {
+ private static void scanLine(final String output,
+ final IFile file,
+ final int indx,
+ final int brIndx) throws CoreException {
String current;
StringBuffer lineNumberBuffer = new StringBuffer(10);
char ch;
}
}
- public void parse(String s) throws CoreException {
- ReInit(new StringReader(s));
+ public final void parse(final String s) throws CoreException {
+ final StringReader stream = new StringReader(s);
+ if (jj_input_stream == null) {
+ jj_input_stream = new SimpleCharStream(stream, 1, 1);
+ }
+ ReInit(stream);
try {
parse();
} catch (ParseException e) {
* Call the php parse command ( php -l -f <filename> )
* and create markers according to the external parser output
*/
- public static void phpExternalParse(IFile file) {
- IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
- String filename = file.getLocation().toString();
+ public static void phpExternalParse(final IFile file) {
+ final IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore();
+ final String filename = file.getLocation().toString();
- String[] arguments = { filename };
- MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_PARSER_PREF));
- String command = form.format(arguments);
+ final String[] arguments = { filename };
+ final MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_PARSER_PREF));
+ final String command = form.format(arguments);
- String parserResult = PHPStartApacheAction.getParserOutput(command, "External parser: ");
+ final String parserResult = PHPStartApacheAction.getParserOutput(command, "External parser: ");
try {
// parse the buffer to find the errors and warnings
}
}
- public void parse() throws ParseException {
+ public static final void parse() throws ParseException {
phpFile();
}
}
<DEFAULT> TOKEN :
{
- <PHPSTART : "<?php" | "<?"> : PHPPARSING
+ <PHPSTARTSHORT : "<?"> : PHPPARSING
+| <PHPSTARTLONG : "<?php"> : PHPPARSING
+| <PHPECHOSTART : "<?="> : PHPPARSING
}
<PHPPARSING> TOKEN :
/* COMMENTS */
-<PHPPARSING> MORE :
+<PHPPARSING> SPECIAL_TOKEN :
{
"//" : IN_SINGLE_LINE_COMMENT
|
+ "#" : IN_SINGLE_LINE_COMMENT
+|
<"/**" ~["/"]> { input_stream.backup(1); } : IN_FORMAL_COMMENT
|
"/*" : IN_MULTI_LINE_COMMENT
}
-<IN_SINGLE_LINE_COMMENT>
-SPECIAL_TOKEN :
+<IN_SINGLE_LINE_COMMENT> SPECIAL_TOKEN :
+{
+ <SINGLE_LINE_COMMENT: "\n" | "\r" | "\r\n" > : PHPPARSING
+}
+
+<IN_SINGLE_LINE_COMMENT> SPECIAL_TOKEN :
{
- <SINGLE_LINE_COMMENT: "\n" | "\r" | "\r\n" | "?>" > : PHPPARSING
+ <SINGLE_LINE_COMMENT_PHPEND : "?>" > : DEFAULT
}
<IN_FORMAL_COMMENT>
| <ELSEIF : "elseif">
| <ELSE : "else">
| <ARRAY : "array">
+| <BREAK : "break">
}
/* LANGUAGE CONSTRUCT */
<PHPPARSING> TOKEN :
{
- <PRINT : "print">
-| <ECHO : "echo">
-| <INCLUDE : "include">
-| <REQUIRE : "require">
-| <INCLUDE_ONCE : "include_once">
-| <REQUIRE_ONCE : "require_once">
-| <GLOBAL : "global">
-| <STATIC : "static">
-| <CLASSACCESS: "->">
-| <STATICCLASSACCESS: "::">
-| <ARRAYASSIGN: "=>">
+ <PRINT : "print">
+| <ECHO : "echo">
+| <INCLUDE : "include">
+| <REQUIRE : "require">
+| <INCLUDE_ONCE : "include_once">
+| <REQUIRE_ONCE : "require_once">
+| <GLOBAL : "global">
+| <STATIC : "static">
+| <CLASSACCESS : "->">
+| <STATICCLASSACCESS : "::">
+| <ARRAYASSIGN : "=>">
}
+<PHPPARSING> TOKEN :
+{
+ <LIST : "list">
+}
/* RESERVED WORDS AND LITERALS */
<PHPPARSING> TOKEN :
{
- < BREAK: "break" >
-| < CASE: "case" >
-| < CONST: "const" >
-| < CONTINUE: "continue" >
-| < _DEFAULT: "default" >
-| < DO: "do" >
-| < EXTENDS: "extends" >
-| < FALSE: "false" >
-| < FOR: "for" >
-| < GOTO: "goto" >
-| < NEW: "new" >
-| < NULL: "null" >
-| < RETURN: "return" >
-| < SUPER: "super" >
-| < SWITCH: "switch" >
-| < THIS: "this" >
-| < TRUE: "true" >
-| < WHILE: "while" >
-| < ENDWHILE : "endwhile" >
+ <CASE : "case">
+| <CONST : "const">
+| <CONTINUE : "continue">
+| <_DEFAULT : "default">
+| <DO : "do">
+| <EXTENDS : "extends">
+| <FOR : "for">
+| <GOTO : "goto">
+| <NEW : "new">
+| <NULL : "null">
+| <RETURN : "return">
+| <SUPER : "super">
+| <SWITCH : "switch">
+| <THIS : "this">
+| <TRUE : "true">
+| <FALSE : "false">
+| <WHILE : "while">
+| <ENDWHILE : "endwhile">
+| <ENDIF : "endif">
+| <ENDFOR : "endfor">
+| <FOREACH : "foreach">
+| <AS : "as" >
}
/* TYPES */
<PHPPARSING> TOKEN :
{
- <STRING : "string">
-| <OBJECT : "object">
-| <BOOL : "bool">
+ <STRING : "string">
+| <OBJECT : "object">
+| <BOOL : "bool">
| <BOOLEAN : "boolean">
-| <REAL : "real">
-| <DOUBLE : "double">
-| <FLOAT : "float">
-| <INT : "int">
+| <REAL : "real">
+| <DOUBLE : "double">
+| <FLOAT : "float">
+| <INT : "int">
| <INTEGER : "integer">
}
<PHPPARSING> TOKEN :
{
- < _ORL : "OR" >
-| < _ANDL: "AND">
+ <_ORL : "OR">
+| <_ANDL : "AND">
}
/* LITERALS */
<PHPPARSING> TOKEN :
{
- < LPAREN: "(" >
-| < RPAREN: ")" >
-| < LBRACE: "{" >
-| < RBRACE: "}" >
-| < LBRACKET: "[" >
-| < RBRACKET: "]" >
-| < SEMICOLON: ";" >
-| < COMMA: "," >
-| < DOT: "." >
+ <LPAREN : "(">
+| <RPAREN : ")">
+| <LBRACE : "{">
+| <RBRACE : "}">
+| <LBRACKET : "[">
+| <RBRACKET : "]">
+| <SEMICOLON : ";">
+| <COMMA : ",">
+| <DOT : ".">
}
-/* OPERATORS */
+/* COMPARATOR */
<PHPPARSING> TOKEN :
{
- <AT : "@">
-| <DOLLAR : "$">
-| <ASSIGN: "=" >
-| <GT: ">" >
-| <LT: "<" >
-| <BANG: "!" >
-| <HOOK: "?" >
-| <COLON: ":" >
-| <EQ: "==" >
-| <LE: "<=" >
-| <GE: ">=" >
-| <NE: "!=" >
-| <SC_OR: "||" >
-| <SC_AND: "&&" >
-| <INCR: "++" >
-| <DECR: "--" >
-| <PLUS: "+" >
-| <MINUS: "-" >
-| <STAR: "*" >
-| <SLASH: "/" >
-| <BIT_AND: "&" >
-| <BIT_OR: "|" >
-| <XOR: "^" >
-| <REM: "%" >
-| <LSHIFT: "<<" >
-| <RSIGNEDSHIFT: ">>" >
-| <RUNSIGNEDSHIFT: ">>>" >
-| <PLUSASSIGN: "+=" >
-| <MINUSASSIGN: "-=" >
-| <STARASSIGN: "*=" >
-| <SLASHASSIGN: "/=" >
-| <ANDASSIGN: "&=" >
-| <ORASSIGN: "|=" >
-| <XORASSIGN: "^=" >
-| <DOTASSIGN: ".=" >
-| <REMASSIGN: "%=" >
-| <LSHIFTASSIGN: "<<=" >
-| <RSIGNEDSHIFTASSIGN: ">>=" >
-| <BANGDOUBLEEQUAL: "!==" >
-| <TRIPLEEQUAL: "===" >
-| <TILDEEQUAL: "~=" >
+ <GT : ">">
+| <LT : "<">
+| <EQ : "==">
+| <LE : "<=">
+| <GE : ">=">
+| <NE : "!=">
+| <DIF : "<>">
+| <BANGDOUBLEEQUAL : "!==">
+| <TRIPLEEQUAL : "===">
}
+/* ASSIGNATION */
<PHPPARSING> TOKEN :
{
- < DOLLAR_ID: <DOLLAR> <IDENTIFIER> >
+ <ASSIGN : "=">
+| <PLUSASSIGN : "+=">
+| <MINUSASSIGN : "-=">
+| <STARASSIGN : "*=">
+| <SLASHASSIGN : "/=">
+| <ANDASSIGN : "&=">
+| <ORASSIGN : "|=">
+| <XORASSIGN : "^=">
+| <DOTASSIGN : ".=">
+| <REMASSIGN : "%=">
+| <TILDEEQUAL : "~=">
}
-/*****************************************
- * THE JAVA LANGUAGE GRAMMAR STARTS HERE *
- *****************************************/
+/* OPERATORS */
+<PHPPARSING> TOKEN :
+{
+ <AT : "@">
+| <DOLLAR : "$">
+| <BANG : "!">
+| <HOOK : "?">
+| <COLON : ":">
+| <SC_OR : "||">
+| <SC_AND : "&&">
+| <INCR : "++">
+| <DECR : "--">
+| <PLUS : "+">
+| <MINUS : "-">
+| <STAR : "*">
+| <SLASH : "/">
+| <BIT_AND : "&">
+| <BIT_OR : "|">
+| <XOR : "^">
+| <REM : "%">
+| <LSHIFT : "<<">
+| <RSIGNEDSHIFT : ">>">
+| <RUNSIGNEDSHIFT : ">>>">
+| <LSHIFTASSIGN : "<<=">
+| <RSIGNEDSHIFTASSIGN : ">>=">
+}
-/*
- * Program structuring syntax follows.
- */
+<PHPPARSING> TOKEN :
+{
+ < DOLLAR_ID: <DOLLAR> <IDENTIFIER> >
+}
void phpTest() :
{}
{}
{
try {
- (<PHPSTART> Php() <PHPEND>)*
- <EOF>
+ (PhpBlock())*
+ <EOF>
} catch (TokenMgrError e) {
errorMessage = e.getMessage();
errorLevel = ERROR;
}
}
+void PhpBlock() :
+{
+ final int start = jj_input_stream.bufpos;
+}
+{
+ <PHPECHOSTART> Expression() [ <SEMICOLON> ] <PHPEND>
+|
+ [ <PHPSTARTLONG>
+ | <PHPSTARTSHORT>
+ {try {
+ setMarker(fileToParse,
+ "You should use '<?php' instead of '<?' it will avoid some problems with XML",
+ start,
+ jj_input_stream.bufpos,
+ INFO,
+ "Line " + token.beginLine);
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }}
+ ]
+ Php()
+ try {
+ <PHPEND>
+ } catch (ParseException e) {
+ errorMessage = "'?>' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+}
+
void Php() :
{}
{
void ClassDeclaration() :
{
- PHPClassDeclaration classDeclaration;
- Token className;
- int pos = jj_input_stream.bufpos;
+ final PHPClassDeclaration classDeclaration;
+ final Token className;
+ final int pos;
}
{
- <CLASS> className = <IDENTIFIER> [ <EXTENDS> <IDENTIFIER> ]
+ <CLASS>
+ try {
+ {pos = jj_input_stream.bufpos;}
+ className = <IDENTIFIER>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', identifier expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [
+ <EXTENDS>
+ try {
+ <IDENTIFIER>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', identifier expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ ]
{
- classDeclaration = new PHPClassDeclaration(currentSegment,className.image,pos);
- currentSegment.add(classDeclaration);
- currentSegment = classDeclaration;
+ if (currentSegment != null) {
+ classDeclaration = new PHPClassDeclaration(currentSegment,className.image,pos);
+ currentSegment.add(classDeclaration);
+ currentSegment = classDeclaration;
+ }
}
ClassBody()
{
- currentSegment = (PHPSegmentWithChildren) currentSegment.getParent();
+ if (currentSegment != null) {
+ currentSegment = (PHPSegmentWithChildren) currentSegment.getParent();
+ }
}
}
}
{
<VAR> variableDeclaration = VariableDeclarator()
- {currentSegment.add(variableDeclaration);}
+ {
+ if (currentSegment != null) {
+ currentSegment.add(variableDeclaration);
+ }
+ }
( <COMMA>
- variableDeclaration = VariableDeclarator()
- {currentSegment.add(variableDeclaration);}
+ variableDeclaration = VariableDeclarator()
+ {
+ if (currentSegment != null) {
+ currentSegment.add(variableDeclaration);
+ }
+ }
)*
try {
<SEMICOLON>
PHPVarDeclaration VariableDeclarator() :
{
- String varName;
- String varValue = null;
- int pos = jj_input_stream.bufpos;
+ final String varName;
+ String varValue;
+ final int pos = jj_input_stream.bufpos;
}
{
varName = VariableDeclaratorId()
<ASSIGN>
try {
varValue = VariableInitializer()
+ {return new PHPVarDeclaration(currentSegment,varName,pos,varValue);}
} catch (ParseException e) {
errorMessage = "Literal expression expected in variable initializer";
errorLevel = ERROR;
throw e;
}
]
- {
- if (varValue == null) {
- return new PHPVarDeclaration(currentSegment,varName,pos);
- }
- return new PHPVarDeclaration(currentSegment,varName,pos,varValue);
- }
+ {return new PHPVarDeclaration(currentSegment,varName,pos);}
}
String VariableDeclaratorId() :
{
String expr;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
try {
String Variable():
{
String expr = null;
- Token token;
+ final Token token;
}
{
token = <DOLLAR_ID> [<LBRACE> expr = Expression() <RBRACE>]
String VariableName():
{
String expr = null;
-Token token;
+final Token token;
}
{
<LBRACE> expr = Expression() <RBRACE>
String VariableInitializer() :
{
- String expr;
- Token token;
+ final String expr;
+ final Token token;
}
{
expr = Literal()
String ArrayVariable() :
{
String expr;
-StringBuffer buff = new StringBuffer();
+final StringBuffer buff = new StringBuffer();
}
{
expr = Expression()
String ArrayInitializer() :
{
-String expr = null;
-StringBuffer buff = new StringBuffer("(");
+String expr;
+final StringBuffer buff = new StringBuffer("(");
}
{
<LPAREN> [ expr = ArrayVariable()
void MethodDeclaration() :
{
- PHPFunctionDeclaration functionDeclaration;
+ final PHPFunctionDeclaration functionDeclaration;
}
{
- <FUNCTION> functionDeclaration = MethodDeclarator()
+ <FUNCTION>
+ try {
+ functionDeclaration = MethodDeclarator()
+ } catch (ParseException e) {
+ if (errorMessage != null) {
+ throw e;
+ }
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', function identifier expected";
+ errorLevel = ERROR;
+ throw e;
+ }
{
- currentSegment.add(functionDeclaration);
- currentSegment = functionDeclaration;
+ if (currentSegment != null) {
+ currentSegment.add(functionDeclaration);
+ currentSegment = functionDeclaration;
+ }
}
Block()
{
- currentSegment = (PHPSegmentWithChildren) currentSegment.getParent();
+ if (currentSegment != null) {
+ currentSegment = (PHPSegmentWithChildren) currentSegment.getParent();
+ }
}
}
PHPFunctionDeclaration MethodDeclarator() :
{
- Token identifier;
- StringBuffer methodDeclaration = new StringBuffer();
- String formalParameters;
- int pos = jj_input_stream.bufpos;
+ final Token identifier;
+ final StringBuffer methodDeclaration = new StringBuffer();
+ final String formalParameters;
+ final int pos = jj_input_stream.bufpos;
}
{
[ <BIT_AND> {methodDeclaration.append("&");} ]
String FormalParameter() :
{
- PHPVarDeclaration variableDeclaration;
- StringBuffer buff = new StringBuffer();
+ final PHPVarDeclaration variableDeclaration;
+ final StringBuffer buff = new StringBuffer();
}
{
[<BIT_AND> {buff.append("&");}] variableDeclaration = VariableDeclarator()
|
<INTEGER>
{return "integer";}
+|
+ <OBJECT>
+ {return "object";}
}
String Expression() :
{
- String expr;
- String assignOperator = null;
- String expr2 = null;
+ final String expr;
+ final String assignOperator;
+ final String expr2;
}
{
expr = PrintExpression()
{return expr;}
|
+ expr = ListExpression()
+ {return expr;}
+|
expr = ConditionalExpression()
[
assignOperator = AssignmentOperator()
try {
expr2 = Expression()
+ {return expr + assignOperator + expr2;}
} catch (ParseException e) {
errorMessage = "expression expected";
errorLevel = ERROR;
throw e;
}
]
- {
- if (expr2 == null) {
- return expr;
- } else {
- return expr + assignOperator + expr2;
- }
- }
+ {return expr;}
}
String AssignmentOperator() :
String ConditionalExpression() :
{
- String expr;
+ final String expr;
String expr2 = null;
String expr3 = null;
}
{
String expr;
Token operator;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = ConditionalAndExpression()
- {
- buff.append(expr);
- }
+ {buff.append(expr);}
(
- (operator = <SC_OR> | operator = <_ORL>) expr2 = ConditionalAndExpression()
+ (operator = <SC_OR> | operator = <_ORL>) expr = ConditionalAndExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
{
{
String expr;
Token operator;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = ConcatExpression()
- {
- buff.append(expr);
- }
+ {buff.append(expr);}
(
- (operator = <SC_AND> | operator = <_ANDL>) expr2 = ConcatExpression()
+ (operator = <SC_AND> | operator = <_ANDL>) expr = ConcatExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
- {
- return buff.toString();
- }
+ {return buff.toString();}
}
String ConcatExpression() :
{
String expr;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = InclusiveOrExpression()
- {
- buff.append(expr);
- }
+ {buff.append(expr);}
(
- <DOT> expr2 = InclusiveOrExpression()
- {
- buff.append(".");
- buff.append(expr2);
- }
+ <DOT> expr = InclusiveOrExpression()
+ {buff.append(".").append(expr);}
)*
- {
- return buff.toString();
- }
+ {return buff.toString();}
}
String InclusiveOrExpression() :
{
String expr;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = ExclusiveOrExpression()
- {
- buff.append(expr);
- }
+ {buff.append(expr);}
(
- <BIT_OR> expr2 = ExclusiveOrExpression()
- {
- buff.append("|");
- buff.append(expr2);
- }
+ <BIT_OR> expr = ExclusiveOrExpression()
+ {buff.append("|").append(expr);}
)*
- {
- return buff.toString();
- }
+ {return buff.toString();}
}
String ExclusiveOrExpression() :
{
String expr;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = AndExpression()
buff.append(expr);
}
(
- <XOR> expr2 = AndExpression()
+ <XOR> expr = AndExpression()
{
buff.append("^");
- buff.append(expr2);
+ buff.append(expr);
}
)*
{
String AndExpression() :
{
String expr;
- String expr2 = null;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = EqualityExpression()
buff.append(expr);
}
(
- <BIT_AND> expr2 = EqualityExpression()
+ <BIT_AND> expr = EqualityExpression()
{
- buff.append("&");
- buff.append(expr2);
+ buff.append("&").append(expr);
}
)*
- {
- return buff.toString();
- }
+ {return buff.toString();}
}
String EqualityExpression() :
{
String expr;
Token operator;
- String expr2;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = RelationalExpression()
{buff.append(expr);}
(
( operator = <EQ>
+ | operator = <DIF>
| operator = <NE>
| operator = <BANGDOUBLEEQUAL>
| operator = <TRIPLEEQUAL>
)
- expr2 = RelationalExpression()
+ expr = RelationalExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
{return buff.toString();}
{
String expr;
Token operator;
- String expr2;
- StringBuffer buff = new StringBuffer();
+ final 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);
- }
+ ( operator = <LT> | operator = <GT> | operator = <LE> | operator = <GE> ) expr = ShiftExpression()
+ {buff.append(operator.image).append(expr);}
)*
{return buff.toString();}
}
{
String expr;
Token operator;
- String expr2;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = AdditiveExpression()
{buff.append(expr);}
(
- (operator = <LSHIFT> | operator = <RSIGNEDSHIFT> | operator = <RUNSIGNEDSHIFT> ) expr2 = AdditiveExpression()
+ (operator = <LSHIFT> | operator = <RSIGNEDSHIFT> | operator = <RUNSIGNEDSHIFT> ) expr = AdditiveExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
{return buff.toString();}
{
String expr;
Token operator;
- String expr2;
- StringBuffer buff = new StringBuffer();
+ final StringBuffer buff = new StringBuffer();
}
{
expr = MultiplicativeExpression()
{buff.append(expr);}
(
- ( operator = <PLUS> | operator = <MINUS> ) expr2 = MultiplicativeExpression()
+ ( operator = <PLUS> | operator = <MINUS> ) expr = MultiplicativeExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
{return buff.toString();}
String MultiplicativeExpression() :
{
- String expr, expr2;
+ String expr;
Token operator;
final StringBuffer buff = new StringBuffer();}
{
expr = UnaryExpression()
{buff.append(expr);}
(
- ( operator = <STAR> | operator = <SLASH> | operator = <REM> ) expr2 = UnaryExpression()
+ ( operator = <STAR> | operator = <SLASH> | operator = <REM> ) expr = UnaryExpression()
{
buff.append(operator.image);
- buff.append(expr2);
+ buff.append(expr);
}
)*
{return buff.toString();}
*/
String UnaryExpression() :
{
- String expr;
- Token token;
+ final String expr;
+ final Token token;
final StringBuffer buff = new StringBuffer();
}
{
String UnaryExpressionNoPrefix() :
{
- String expr;
- Token token;
+ final String expr;
+ final Token token;
}
{
( token = <PLUS> | token = <MINUS> ) expr = UnaryExpression()
String PreIncrementExpression() :
{
-String expr;
+final String expr;
}
{
<INCR> expr = PrimaryExpression()
String PreDecrementExpression() :
{
-String expr;
+final String expr;
}
{
<DECR> expr = PrimaryExpression()
String UnaryExpressionNotPlusMinus() :
{
- String expr;
+ final String expr;
}
{
<BANG> expr = UnaryExpression()
expr = Literal()
{return expr;}
|
- <LPAREN> expr = Expression()<RPAREN>
+ <LPAREN> expr = Expression()
+ try {
+ <RPAREN>
+ } catch (ParseException e) {
+ errorMessage = "')' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
{return "("+expr+")";}
}
String CastExpression() :
{
-String type;
-String expr;
+final String type, expr;
}
{
<LPAREN> type = Type() <RPAREN> expr = UnaryExpression()
String PostfixExpression() :
{
- String expr;
+ final String expr;
Token operator = null;
}
{
String PrimaryExpression() :
{
- Token identifier;
+ final Token identifier;
String expr;
final StringBuffer buff = new StringBuffer();
}
String ArrayDeclarator() :
{
- String expr;
+ final String expr;
}
{
<ARRAY> expr = ArrayInitializer()
String PrimaryPrefix() :
{
- String expr;
- Token token = null;
+ final String expr;
+ final Token token;
}
{
token = <IDENTIFIER>
String ClassIdentifier():
{
- String expr;
- Token token;
+ final String expr;
+ final Token token;
}
{
token = <IDENTIFIER>
String PrimarySuffix() :
{
- String expr;
+ final String expr;
}
{
expr = Arguments()
String expr = null;
}
{
- <CLASSACCESS> expr = VariableName()
+ <CLASSACCESS>
+ try {
+ expr = VariableName()
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', function call or field access expected";
+ errorLevel = ERROR;
+ throw e;
+ }
{return "->" + expr;}
|
<LBRACKET> [ expr = Expression() ]
String Literal() :
{
- String expr;
- Token token;
+ final String expr;
+ final Token token;
}
{
token = <INTEGER_LITERAL>
try {
<RPAREN>
} catch (ParseException e) {
- errorMessage = "')' expected to close the argument list";
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', ')' expected to close the argument list";
errorLevel = ERROR;
throw e;
}
String ArgumentList() :
{
String expr;
-StringBuffer buff = new StringBuffer();
+final StringBuffer buff = new StringBuffer();
}
{
expr = Expression()
throw e;
}
{
- buff.append(",").append("expr");
+ buff.append(",").append(expr);
}
)*
{return buff.toString();}
}
-/*
- * Statement syntax follows.
+/**
+ * A Statement without break
*/
-
-void Statement() :
+void StatementNoBreak() :
{}
{
LOOKAHEAD(2)
Expression()
try {
- (<SEMICOLON> | "?>")
+ (<SEMICOLON> | <PHPEND>)
} catch (ParseException e) {
errorMessage = "';' expected";
errorLevel = ERROR;
|
ForStatement()
|
- BreakStatement()
+ ForeachStatement()
|
ContinueStatement()
|
GlobalStatement()
}
+/**
+ * A Normal statement
+ */
+void Statement() :
+{}
+{
+ StatementNoBreak()
+|
+ BreakStatement()
+}
+
void IncludeStatement() :
{
- String expr;
- int pos = jj_input_stream.bufpos;
+ final String expr;
+ final int pos = jj_input_stream.bufpos;
}
{
<REQUIRE>
expr = Expression()
- {currentSegment.add(new PHPReqIncDeclaration(currentSegment, "require",pos,expr));}
+ {
+ if (currentSegment != null) {
+ currentSegment.add(new PHPReqIncDeclaration(currentSegment, "require",pos,expr));
+ }
+ }
try {
(<SEMICOLON> | "?>")
} catch (ParseException e) {
|
<REQUIRE_ONCE>
expr = Expression()
- {currentSegment.add(new PHPReqIncDeclaration(currentSegment, "require_once",pos,expr));}
+ {
+ if (currentSegment != null) {
+ currentSegment.add(new PHPReqIncDeclaration(currentSegment, "require_once",pos,expr));
+ }
+ }
try {
(<SEMICOLON> | "?>")
} catch (ParseException e) {
|
<INCLUDE>
expr = Expression()
- {currentSegment.add(new PHPReqIncDeclaration(currentSegment, "include",pos,expr));}
+ {
+ if (currentSegment != null) {
+ currentSegment.add(new PHPReqIncDeclaration(currentSegment, "include",pos,expr));
+ }
+ }
try {
(<SEMICOLON> | "?>")
} catch (ParseException e) {
|
<INCLUDE_ONCE>
expr = Expression()
- {currentSegment.add(new PHPReqIncDeclaration(currentSegment, "include_once",pos,expr));}
+ {
+ if (currentSegment != null) {
+ currentSegment.add(new PHPReqIncDeclaration(currentSegment, "include_once",pos,expr));
+ }
+ }
try {
(<SEMICOLON> | "?>")
} catch (ParseException e) {
String PrintExpression() :
{
- StringBuffer buff = new StringBuffer("print ");
- String expr;
+ final StringBuffer buff = new StringBuffer("print ");
+ final String expr;
}
{
<PRINT> expr = Expression()
}
}
+String ListExpression() :
+{
+ final StringBuffer buff = new StringBuffer("list(");
+ String expr;
+}
+{
+ <LIST>
+ try {
+ <LPAREN>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', '(' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [
+ expr = VariableDeclaratorId()
+ {buff.append(expr);}
+ ]
+ [
+ try {
+ <COMMA>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', ',' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ expr = VariableDeclaratorId()
+ {buff.append(",").append(expr);}
+ ]
+ {buff.append(")");}
+ try {
+ <RPAREN>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.next.image +"', ')' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [ <ASSIGN> expr = Expression() {buff.append("(").append(expr);}]
+ {return buff.toString();}
+}
+
void EchoStatement() :
{}
{
throw e;
}
( BlockStatement() )*
- <RBRACE>
+ try {
+ <RBRACE>
+ } catch (ParseException e) {
+ errorMessage = "unexpected token : '"+ e.currentToken.image +"', '}' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
}
void BlockStatement() :
MethodDeclaration()
}
+/**
+ * A Block statement that will not contain any 'break'
+ */
+void BlockStatementNoBreak() :
+{}
+{
+ StatementNoBreak()
+|
+ ClassDeclaration()
+|
+ MethodDeclaration()
+}
+
void LocalVariableDeclaration() :
{}
{
- VariableDeclarator() ( <COMMA> VariableDeclarator() )*
+ LocalVariableDeclarator() ( <COMMA> LocalVariableDeclarator() )*
+}
+
+void LocalVariableDeclarator() :
+{}
+{
+ VariableDeclaratorId() [ <ASSIGN> Expression() ]
}
void EmptyStatement() :
}
void SwitchStatement() :
-{}
{
- <SWITCH> <LPAREN> Expression() <RPAREN> <LBRACE>
- ( SwitchLabel() ( BlockStatement() )* )*
- <RBRACE>
+ Token breakToken = null;
+ int line;
+}
+{
+ <SWITCH>
+ try {
+ <LPAREN>
+ } catch (ParseException e) {
+ errorMessage = "'(' expected after 'switch'";
+ errorLevel = ERROR;
+ throw e;
+ }
+ Expression()
+ try {
+ <RPAREN>
+ } catch (ParseException e) {
+ errorMessage = "')' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ <LBRACE>
+ } catch (ParseException e) {
+ errorMessage = "'{' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ (
+ line = SwitchLabel()
+ ( BlockStatementNoBreak() )*
+ [ breakToken = <BREAK>
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'break' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ ]
+ {
+ try {
+ if (breakToken == null) {
+ setMarker(fileToParse,
+ "You should use put a 'break' at the end of your statement",
+ line,
+ INFO,
+ "Line " + line);
+ }
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }
+ }
+ )*
+ try {
+ <RBRACE>
+ } catch (ParseException e) {
+ errorMessage = "'}' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
}
-void SwitchLabel() :
-{}
+int SwitchLabel() :
+{
+ final Token token;
+}
{
- <CASE> Expression() <COLON>
+ token = <CASE>
+ try {
+ Expression()
+ } catch (ParseException e) {
+ if (errorMessage != null) throw e;
+ errorMessage = "expression expected after 'case' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ <COLON>
+ } catch (ParseException e) {
+ errorMessage = "':' expected after case expression";
+ errorLevel = ERROR;
+ throw e;
+ }
+ {return token.beginLine;}
|
- <_DEFAULT> <COLON>
+ token = <_DEFAULT>
+ try {
+ <COLON>
+ } catch (ParseException e) {
+ errorMessage = "':' expected after 'default' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ {return token.beginLine;}
}
void IfStatement() :
-/*
- * The disambiguating algorithm of JavaCC automatically binds dangling
- * else's to the innermost if statement. The LOOKAHEAD specification
- * is to tell JavaCC that we know what we are doing.
- */
-{}
{
- <IF> Condition("if") Statement() ( LOOKAHEAD(1) ElseIfStatement() )* [ LOOKAHEAD(1) <ELSE> Statement() ]
+ final Token token;
+ final int pos = jj_input_stream.bufpos;
+}
+{
+ token = <IF> Condition("if") IfStatement0(pos,pos+token.image.length())
}
-void Condition(String keyword) :
+void Condition(final String keyword) :
{}
{
try {
}
}
+void IfStatement0(final int start,final int end) :
+{}
+{
+ <COLON> (Statement())* (ElseIfStatementColon())* [ElseStatementColon()]
+
+ {try {
+ setMarker(fileToParse,
+ "Ugly syntax detected, you should if () {...} instead of if (): ... endif;",
+ start,
+ end,
+ INFO,
+ "Line " + token.beginLine);
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }}
+ try {
+ <ENDIF>
+ } catch (ParseException e) {
+ errorMessage = "'endif' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'endif' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+|
+ Statement() ( LOOKAHEAD(1) ElseIfStatement() )* [ LOOKAHEAD(1) <ELSE> Statement() ]
+}
+
+void ElseIfStatementColon() :
+{}
+{
+ <ELSEIF> Condition("elseif") <COLON> (Statement())*
+}
+
+void ElseStatementColon() :
+{}
+{
+ <ELSE> <COLON> (Statement())*
+}
+
void ElseIfStatement() :
{}
{
}
void WhileStatement() :
-{}
{
- <WHILE> Condition("while") WhileStatement0()
+ final Token token;
+ final int pos = jj_input_stream.bufpos;
+}
+{
+ token = <WHILE> Condition("while") WhileStatement0(pos,pos + token.image.length())
}
-void WhileStatement0() :
+void WhileStatement0(final int start, final int end) :
{}
{
- <COLON> (Statement())* <ENDWHILE>
+ <COLON> (Statement())*
+ {try {
+ setMarker(fileToParse,
+ "Ugly syntax detected, you should while () {...} instead of while (): ... endwhile;",
+ start,
+ end,
+ INFO,
+ "Line " + token.beginLine);
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }}
+ try {
+ <ENDWHILE>
+ } catch (ParseException e) {
+ errorMessage = "'endwhile' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
try {
(<SEMICOLON> | "?>")
} catch (ParseException e) {
- errorMessage = "';' expected";
+ errorMessage = "';' expected after 'endwhile' keyword";
errorLevel = ERROR;
throw e;
}
}
}
-void ForStatement() :
+void ForeachStatement() :
{}
{
- <FOR> <LPAREN> [ ForInit() ] <SEMICOLON> [ Expression() ] <SEMICOLON> [ ForUpdate() ] <RPAREN> Statement()
+ <FOREACH>
+ try {
+ <LPAREN>
+ } catch (ParseException e) {
+ errorMessage = "'(' expected after 'foreach' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ Variable()
+ } catch (ParseException e) {
+ errorMessage = "variable expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [ VariableSuffix() ]
+ try {
+ <AS>
+ } catch (ParseException e) {
+ errorMessage = "'as' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ Variable()
+ } catch (ParseException e) {
+ errorMessage = "variable expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [ <ARRAYASSIGN> Expression() ]
+ try {
+ <RPAREN>
+ } catch (ParseException e) {
+ errorMessage = "')' expected after 'foreach' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ Statement()
+ } catch (ParseException e) {
+ if (errorMessage != null) throw e;
+ errorMessage = "statement expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+}
+
+void ForStatement() :
+{
+final Token token;
+final int pos = jj_input_stream.bufpos;
+}
+{
+ token = <FOR>
+ try {
+ <LPAREN>
+ } catch (ParseException e) {
+ errorMessage = "'(' expected after 'for' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ [ ForInit() ] <SEMICOLON> [ Expression() ] <SEMICOLON> [ StatementExpressionList() ] <RPAREN>
+ (
+ Statement()
+ |
+ <COLON> (Statement())*
+ {
+ try {
+ setMarker(fileToParse,
+ "Ugly syntax detected, you should for () {...} instead of for (): ... endfor;",
+ pos,
+ pos+token.image.length(),
+ INFO,
+ "Line " + token.beginLine);
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }
+ }
+ try {
+ <ENDFOR>
+ } catch (ParseException e) {
+ errorMessage = "'endfor' expected";
+ errorLevel = ERROR;
+ throw e;
+ }
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'endfor' keyword";
+ errorLevel = ERROR;
+ throw e;
+ }
+ )
}
void ForInit() :
StatementExpression() ( <COMMA> StatementExpression() )*
}
-void ForUpdate() :
-{}
-{
- StatementExpressionList()
-}
-
void BreakStatement() :
{}
{
- <BREAK> [ <IDENTIFIER> ] <SEMICOLON>
+ <BREAK> [ <IDENTIFIER> ]
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'break' statement";
+ errorLevel = ERROR;
+ throw e;
+ }
}
void ContinueStatement() :
{}
{
- <CONTINUE> [ <IDENTIFIER> ] <SEMICOLON>
+ <CONTINUE> [ <IDENTIFIER> ]
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'continue' statement";
+ errorLevel = ERROR;
+ throw e;
+ }
}
void ReturnStatement() :
{}
{
- <RETURN> [ Expression() ] <SEMICOLON>
+ <RETURN> [ Expression() ]
+ try {
+ <SEMICOLON>
+ } catch (ParseException e) {
+ errorMessage = "';' expected after 'return' statement";
+ errorLevel = ERROR;
+ throw e;
+ }
}
\ No newline at end of file