import net.sourceforge.phpdt.internal.compiler.problem.AbortCompilation;
import net.sourceforge.phpdt.internal.compiler.problem.ProblemReporter;
import net.sourceforge.phpdt.internal.compiler.util.Util;
-import net.sourceforge.phpdt.internal.core.BasicCompilationUnit;
import net.sourceforge.phpeclipse.internal.compiler.ast.CompilationUnitDeclaration;
import net.sourceforge.phpeclipse.internal.compiler.ast.ConstructorDeclaration;
import net.sourceforge.phpeclipse.internal.compiler.ast.FieldDeclaration;
firstToken = TokenNameMINUS_MINUS;
scanner.recordLineSeparator = false;
}
- public void initialize() {
- super.initialize();
+ public void initialize(boolean phpMode) {
+ super.initialize(phpMode);
//positionning the parser for a new compilation unit
//avoiding stack reallocation and all that....
// astPtr = -1;
// A P I
- public CompilationUnitDeclaration parse(ICompilationUnit sourceUnit, CompilationResult compilationResult) {
+ public CompilationUnitDeclaration parse(ICompilationUnit sourceUnit, CompilationResult compilationResult, boolean phpMode) {
// parses a compilation unit and manages error handling (even bugs....)
CompilationUnitDeclaration unit;
try {
/* automaton initialization */
- initialize();
+ initialize(phpMode);
goForCompilationUnit();
/* scanner initialization */
// storeProblemsFor(((BasicCompilationUnit)sourceUnit).getResource(), compilationResult.getAllProblems());
// }
// // jsurfer end
- } catch (CoreException e) {
- e.printStackTrace();
+
} finally {
unit = compilationUnit;
compilationUnit = null; // reset parser
//convert bugs into parse error
- initialize();
+ initialize(false);
goForConstructorBody();
nestedMethod[nestedType]++;
parse();
} catch (AbortCompilation ex) {
lastAct = ERROR_ACTION;
- } catch (CoreException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
+
} finally {
nestedMethod[nestedType]--;
}
if (lastAct == ERROR_ACTION) {
- initialize();
+ initialize(false);
return;
}
//convert bugs into parse error
- initialize();
+ initialize(false);
goForExpression();
nestedMethod[nestedType]++;
parse();
} catch (AbortCompilation ex) {
lastAct = ERROR_ACTION;
- } catch (CoreException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
} finally {
nestedMethod[nestedType]--;
}
//convert bugs into parse error
- initialize();
+ initialize(false);
goForInitializer();
nestedMethod[nestedType]++;
parse();
} catch (AbortCompilation ex) {
lastAct = ERROR_ACTION;
- } catch (CoreException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
} finally {
nestedMethod[nestedType]--;
}
// if ((md.modifiers & AccSemicolonBody) != 0)
// return;
- initialize();
+ initialize(false);
goForMethodBody();
nestedMethod[nestedType]++;
parse();
} catch (AbortCompilation ex) {
lastAct = ERROR_ACTION;
- } catch (CoreException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
} finally {
nestedMethod[nestedType]--;
}
CompilationUnitDeclaration unit;
try {
/* automaton initialization */
- initialize();
+ initialize(false);
goForCompilationUnit();
/* scanner initialization */
compilationUnit = new CompilationUnitDeclaration(problemReporter, compilationResult, scanner.source.length);
/* run automaton */
parse();
- } catch (CoreException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
} catch (SyntaxError syntaxError) {
//
} finally {
}
public CompilationUnitDeclaration dietParse(ICompilationUnit sourceUnit, CompilationResult compilationResult) {
+ return dietParse(sourceUnit, compilationResult, false);
+ }
+ public CompilationUnitDeclaration dietParse(ICompilationUnit sourceUnit, CompilationResult compilationResult, boolean phpMode) {
CompilationUnitDeclaration parsedUnit;
boolean old = diet;
try {
diet = true;
- parsedUnit = parse(sourceUnit, compilationResult);
+ parsedUnit = parse(sourceUnit, compilationResult, phpMode);
} finally {
diet = old;
}