diff options
author | acolyer <acolyer> | 2004-01-26 16:23:41 +0000 |
---|---|---|
committer | acolyer <acolyer> | 2004-01-26 16:23:41 +0000 |
commit | 189c687a9f362a78c4df459ad4ea3bfbf5e154a9 (patch) | |
tree | bd02f91ca4fbd05a14f521e268776561fcb20b33 /org.aspectj.ajdt.core/src | |
parent | d24bc49248ecdb661cf08e7f8ad29bb44d9ed865 (diff) | |
download | aspectj-189c687a9f362a78c4df459ad4ea3bfbf5e154a9.tar.gz aspectj-189c687a9f362a78c4df459ad4ea3bfbf5e154a9.zip |
Bugzilla Bug 50458
Make a full implementation of org.eclipse.jdt.core for use in AJDT
Pushdown of AjParser and AjScanner into shadows/org.eclipse.jdt.core.
New class DeclarationFactory handles creation of AJDT-specific types
on behalf of Parser.
Diffstat (limited to 'org.aspectj.ajdt.core/src')
4 files changed, 265 insertions, 2060 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjParser.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjParser.java deleted file mode 100644 index 87232ada8..000000000 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjParser.java +++ /dev/null @@ -1,1984 +0,0 @@ -/* ******************************************************************* - * Copyright (c) 2002 Palo Alto Research Center, Incorporated (PARC). - * All rights reserved. - * This program and the accompanying materials are made available - * under the terms of the Common Public License v1.0 - * which accompanies this distribution and is available at - * http://www.eclipse.org/legal/cpl-v10.html - * - * Contributors: - * PARC initial implementation - * ******************************************************************/ - - -package org.aspectj.ajdt.internal.compiler.parser; - -import java.lang.reflect.Modifier; -import java.util.Arrays; -import java.util.List; - -import org.aspectj.ajdt.internal.compiler.ast.AdviceDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.AspectDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.DeclareDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.IfPseudoToken; -import org.aspectj.ajdt.internal.compiler.ast.InterTypeConstructorDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.InterTypeFieldDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.InterTypeMethodDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.PointcutDeclaration; -import org.aspectj.ajdt.internal.compiler.ast.PointcutDesignator; -import org.aspectj.ajdt.internal.compiler.ast.Proceed; -import org.aspectj.ajdt.internal.compiler.ast.PseudoToken; -import org.aspectj.ajdt.internal.compiler.ast.PseudoTokens; -import org.aspectj.ajdt.internal.core.builder.EclipseSourceContext; -import org.aspectj.weaver.AdviceKind; -import org.aspectj.weaver.ISourceContext; -import org.aspectj.weaver.patterns.Declare; -import org.eclipse.jdt.internal.compiler.CompilationResult; -import org.eclipse.jdt.internal.compiler.ast.Argument; -import org.eclipse.jdt.internal.compiler.ast.ASTNode; -import org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall; -import org.eclipse.jdt.internal.compiler.ast.Expression; -import org.eclipse.jdt.internal.compiler.ast.Literal; -import org.eclipse.jdt.internal.compiler.ast.MessageSend; -//import org.eclipse.jdt.internal.compiler.ast.OperatorExpression; -import org.eclipse.jdt.internal.compiler.ast.OperatorIds; -import org.eclipse.jdt.internal.compiler.ast.TypeReference; -import org.eclipse.jdt.internal.compiler.impl.CompilerOptions; -import org.eclipse.jdt.internal.compiler.parser.Parser; -import org.eclipse.jdt.internal.compiler.parser.RecoveredType; -import org.eclipse.jdt.internal.compiler.problem.ProblemReporter; -import org.eclipse.jdt.internal.compiler.problem.ProblemSeverities; -import org.eclipse.jdt.core.compiler.CharOperation; - - - -public class AjParser extends Parser { - - static { - try{ - initTables(AjParser.class); - } catch(java.io.IOException ex){ - throw new ExceptionInInitializerError(ex.getMessage()); - } - } - -// public final static void initAjTables(Class parserClass) -// throws java.io.IOException { -// -// final String prefix = FILEPREFIX; -// int i = 0; -// lhsStatic = readTable(parserClass, prefix + (++i) + ".rsc"); //$NON-NLS-1$ -// char[] chars = readTable(parserClass, prefix + (++i) + ".rsc"); //$NON-NLS-1$ -// check_tableStatic = new short[chars.length]; -// for (int c = chars.length; c-- > 0;) { -// check_tableStatic[c] = (short) (chars[c] - 32768); -// } -// asbStatic = readTable(parserClass, prefix + (++i) + ".rsc"); //$NON-NLS-1$ -// asrStatic = readTable(parserClass, prefix + (++i) + ".rsc"); //$NON-NLS-1$ -// symbol_indexStatic = readTable(parserClass, prefix + (++i) + ".rsc"); //$NON-NLS-1$ -// actionStatic = lhsStatic; -// } - - public void initializeScanner(){ - this.scanner = new AjScanner( - false /*comment*/, - false /*whitespace*/, - this.options.getSeverity(CompilerOptions.NonExternalizedString) != ProblemSeverities.Ignore /*nls*/, - this.options.sourceLevel /*sourceLevel*/, - this.options.taskTags/*taskTags*/, - this.options.taskPriorites/*taskPriorities*/); - } - - - -//*************New display debugging method - private static final boolean AJ_DEBUG = false; - - void println(Object o) { - if (AJ_DEBUG) System.out.println(o); - } - - private void printStack(Object[] s, int p) { - List list = Arrays.asList(s); - System.out.println(" " + list.subList(0, p+1)); - } - - private void printStack(int[] s, int p) { - StringBuffer buf = new StringBuffer("["); - for (int i=0; i<p+1; i++) { - if (i > 0) buf.append(", "); - buf.append(Integer.toString(s[i])); - } - buf.append("]"); - System.out.println(" " + buf); - } - - private void printStack(long[] s, int p) { - StringBuffer buf = new StringBuffer("["); - for (int i=0; i<p+1; i++) { - if (i > 0) buf.append(", "); - buf.append(Long.toString(s[i])); - } - buf.append("]"); - System.out.println(" " + buf); - } - - private void printStack(char[][] s, int p) { - StringBuffer buf = new StringBuffer("["); - for (int i=0; i<p+1; i++) { - if (i > 0) buf.append(", "); - buf.append(new String(s[i])); - } - buf.append("]"); - System.out.println(" " + buf); - } - - public void display() { - if (!AJ_DEBUG) return; - System.out.print("astStack: "); - printStack(astStack, astPtr); - System.out.print("astLengthStack: "); - printStack(astLengthStack, astLengthPtr); - - System.out.print("expressionStack: "); - printStack(expressionStack, expressionPtr); - System.out.print("expressionLengthStack: "); - printStack(expressionLengthStack, expressionLengthPtr); - - System.out.print("identifierStack: "); - printStack(identifierStack, identifierPtr); - System.out.print("identifierLengthStack: "); - printStack(identifierLengthStack, identifierLengthPtr); - System.out.print("identifierPositionStack: "); - printStack(identifierPositionStack, identifierPtr); - - - System.out.print("intStack:"); - printStack(intStack, intPtr); - System.out.println(); - } - - - -//************** Overriding behavior for standard Java rules - protected void consumeMethodInvocationName() { - super.consumeMethodInvocationName(); - - MessageSend m = (MessageSend)expressionStack[expressionPtr]; - if (CharOperation.equals(m.selector, "proceed".toCharArray())) { - expressionStack[expressionPtr] = new Proceed(m); - } - } - - protected void consumeToken(int type) { - currentTokenStart = scanner.startPosition; - super.consumeToken(type); - switch (type) { - case TokenNameaspect : // pseudo keyword - case TokenNameprivileged : // pseudo keyword - case TokenNamepointcut : // pseudo keyword - case TokenNamebefore : // pseudo keyword - case TokenNameafter : // pseudo keyword - case TokenNamearound : // pseudo keyword - case TokenNamedeclare : // pseudo keyword - pushIdentifier(); - scanner.commentPtr = -1; - break; - } - } - - -//************New AspectJ rules - protected void consumeAspectDeclaration() { - // AspectDeclaration ::= AspectHeader AspectBody - consumeClassDeclaration(); - //??? post parsing step here - } - - protected void consumeAspectHeader() { - // AspectHeader ::= AspectHeaderName ClassHeaderExtendsopt ClassHeaderImplementsopt AspectHeaderRest - consumeClassHeader(); - } - - protected void consumeAspectHeaderName(boolean isPrivileged) { - // (isPrivileged == false) -> AspectHeaderName ::= Modifiersopt 'aspect' 'Identifier' - // (isPrivileged == true) -> AspectHeaderName ::= Modifiersopt 'privileged' Modifiersopt 'aspect' 'Identifier' - AspectDeclaration aspectDecl = - new AspectDeclaration(this.compilationUnit.compilationResult); - - println("aspect header name: "); - this.display(); - - //highlight the name of the type - long pos = identifierPositionStack[identifierPtr]; - aspectDecl.sourceEnd = (int) pos; - aspectDecl.sourceStart = (int) (pos >>> 32); - aspectDecl.name = identifierStack[identifierPtr--]; - identifierLengthPtr--; - - // pop the aspect pseudo-token - eatIdentifier(); - - - // handle modifiers, only without privileged for now - if (isPrivileged) { - pos = eatIdentifier(); // eat the privileged -// int end = (int) pos; -// int start = (int) (pos >>> 32); - aspectDecl.isPrivileged = true; - //problemReporter().signalError(start, end, "privileged is unimplemented in 1.1alpha1"); - } - aspectDecl.modifiersSourceStart = intStack[intPtr--]; - aspectDecl.modifiers = intStack[intPtr--]; - if (isPrivileged) { - aspectDecl.modifiersSourceStart = intStack[intPtr--]; - aspectDecl.modifiers |= intStack[intPtr--]; - } - if (aspectDecl.modifiersSourceStart >= 0) { - aspectDecl.declarationSourceStart = aspectDecl.modifiersSourceStart; - } - - println("modifiers: " + aspectDecl.modifiers); - - aspectDecl.bodyStart = aspectDecl.sourceEnd + 1; - pushOnAstStack(aspectDecl); - - listLength = 0; // will be updated when reading super-interfaces - // recovery - if (currentElement != null) { - lastCheckPoint = aspectDecl.bodyStart; - currentElement = currentElement.add(aspectDecl, 0); - lastIgnoredToken = -1; - } - - this.display(); - } - - private long eatIdentifier() { - long pos = identifierPositionStack[identifierPtr]; - identifierPtr--; - identifierLengthPtr--; - return pos; - } - - protected void consumeAspectHeaderRest() { - //--[dominates TypePattern] [persingleton() | percflow(PCD) | perthis(PCD) | pertarget(PCD)] - //AspectHeaderRest ::= AspectHeaderRestStart PseudoTokens - concatNodeLists(); - this.display(); - PseudoTokens pseudoTokens = popPseudoTokens("{"); - println("pseudo: " + pseudoTokens); - - AspectDeclaration aspectDecl = (AspectDeclaration) astStack[astPtr]; - - aspectDecl.dominatesPattern = pseudoTokens.maybeParseDominatesPattern(this); - aspectDecl.perClause = pseudoTokens.parsePerClause(this); - // XXX handle dominates - } - - - protected void consumePointcutDeclaration() { - consumePointcutDesignatorOnDeclaration(); - } - - protected void consumeEmptyPointcutDeclaration() { - //??? set pcd to non-null - } - - protected void consumePointcutHeader() { - //PointcutDeclaration ::= Modifiersopt 'pointcut' JavaIdentifier '(' - - PointcutDeclaration ret = new PointcutDeclaration(compilationUnit.compilationResult); - - //the name - long pos = identifierPositionStack[identifierPtr]; -// int sourceEnd = (int) pos; - ret.sourceStart = (int) (pos >>> 32); - ret.selector = identifierStack[identifierPtr--]; - identifierLengthPtr--; - - // pop the 'pointcut' keyword - eatIdentifier(); - - // modifiers - ret.declarationSourceStart = intStack[intPtr--]; - ret.modifiers = intStack[intPtr--]; - - pushOnAstStack(ret); - } - - - - protected void consumeAroundDeclaration() { - // AroundDeclaration ::= AroundHeader MethodBody - consumeMethodDeclaration(true); - } - - protected void consumeAroundHeader() { - consumePointcutDesignatorOnAdvice(); - consumeMethodHeader(); - } - - protected void consumeAroundHeaderName() { - // AroundHeaderName ::= Modifiersopt Type 'around' '(' - - AdviceDeclaration adviceDecl = - new AdviceDeclaration(compilationUnit.compilationResult, AdviceKind.Around); - - // skip the name of the advice - long pos = eatIdentifier(); - adviceDecl.sourceStart = (int) (pos >>> 32); - - TypeReference returnType = getTypeReference(intStack[intPtr--]); - - //modifiers - adviceDecl.declarationSourceStart = intStack[intPtr--]; - adviceDecl.modifiers = intStack[intPtr--]; - - adviceDecl.returnType = returnType; - - //XXX get some locations right - - pushOnAstStack(adviceDecl); - } - - protected void consumePointcutDesignatorOnAdvice() { - PointcutDesignator des = popPointcutDesignator("{"); - AdviceDeclaration adviceDecl = (AdviceDeclaration)astStack[astPtr]; - adviceDecl.pointcutDesignator = des; - adviceDecl.sourceEnd = des.sourceEnd; - adviceDecl.bodyStart = des.sourceEnd+1; - } - - protected void consumePointcutDesignatorOnDeclaration() { - PointcutDesignator des = popPointcutDesignator(";"); - PointcutDeclaration adviceDecl = (PointcutDeclaration)astStack[astPtr]; - adviceDecl.pointcutDesignator = des; - adviceDecl.sourceEnd = des.sourceEnd; - adviceDecl.bodyStart = des.sourceEnd+1; - } - - - protected void consumeBasicAdviceDeclaration() { - // BasicAdviceDeclaration ::= BasicAdviceHeader MethodBody - consumeMethodDeclaration(true); - } - - protected void consumeBasicAdviceHeader() { - // BasicAdviceHeader ::= BasicAdviceHeaderName MethodHeaderParameters ExtraParamopt MethodHeaderThrowsClauseopt ':' PseudoTokens - consumePointcutDesignatorOnAdvice(); - - consumeMethodHeader(); - } - - - protected void consumeBasicAdviceHeaderName(boolean isAfter) { - // BasicAdviceHeaderName ::= 'before'|'after '(' - - AdviceDeclaration adviceDecl = - new AdviceDeclaration(compilationUnit.compilationResult, isAfter ? AdviceKind.After : AdviceKind.Before); - - // skip the name of the advice - long pos = eatIdentifier(); - adviceDecl.sourceStart = (int) (pos >>> 32); - - //modifiers - adviceDecl.declarationSourceStart = intStack[intPtr--]; - adviceDecl.modifiers = intStack[intPtr--]; - - - //??? get more locations right - - pushOnAstStack(adviceDecl); - } - - protected void consumeExtraParameterWithFormal() { - Argument arg = (Argument)astStack[astPtr--]; - astLengthPtr--; - - ((AdviceDeclaration)astStack[astPtr]).extraArgument = arg; - - consumeExtraParameterNoFormal(); - } - - - protected void consumeExtraParameterNoFormal() { - - - long pos = identifierPositionStack[identifierPtr]; - int end = (int) pos; - int start = (int) (pos >>> 32); - char[] name = identifierStack[identifierPtr--]; - identifierLengthPtr--; - - //System.out.println("extra parameter: " + new String(name)); - - AdviceDeclaration adviceDecl = (AdviceDeclaration)astStack[astPtr]; - if (adviceDecl.kind != AdviceKind.After) { - //XXX error, extra param makes no sense here - } - - if (CharOperation.equals(name, "throwing".toCharArray())) { - adviceDecl.kind = AdviceKind.AfterThrowing; - } else if (CharOperation.equals(name, "returning".toCharArray())) { - adviceDecl.kind = AdviceKind.AfterReturning; - } else { - problemReporter().parseError( - start, - end, - currentToken, - name, - String.valueOf(name), - new String[] {"throwing", "returning", ":"}); - } - } - - protected void consumeClassBodyDeclarationInAspect() { } - - - protected void consumeDeclareDeclaration() { - concatNodeLists(); - PseudoTokens tokens = popPseudoTokens(";"); - Declare declare = tokens.parseDeclare(this); - println("parsed declare: " + declare); - display(); - pushOnAstStack(new DeclareDeclaration(this.compilationUnit.compilationResult, declare)); - } - - - - - protected void consumeDeclareHeader() { - consumePseudoTokenIdentifier(); // name - consumePseudoTokenIdentifier(); // declare - swapAstStack(); - consumePseudoTokens(); - - consumePseudoToken(":", 0, false); - consumePseudoTokens(); - - println(">>>>>>>>>>>>>>>>>>>>>>>declare header"); - display(); - } - - - protected void consumeInterTypeFieldDeclaration() { - // InterTypeFieldDeclaration ::= Modifiersopt Type OnType '.' JavaIdentifier InterTypeFieldBody ';' - println("about to consume field"); - this.display(); - // FieldDeclaration field = new FieldDeclaration(); - - Expression initialization = null; - if (expressionPtr >= 0) { - expressionLengthPtr--; - initialization = expressionStack[expressionPtr--]; - } - - long pos = identifierPositionStack[identifierPtr]; - int end = (int) pos; - int start = (int) (pos >>> 32); - char[] name = identifierStack[identifierPtr--]; - identifierLengthPtr--; - - // field.name = name; - // field.sourceStart = start; - // field.sourceEnd = end; - - TypeReference onType = getTypeReference(0); - TypeReference returnType = getTypeReference(intStack[intPtr--]); - this.display(); - - int decSourceStart = intStack[intPtr--]; - int modifiers = intStack[intPtr--]; - - InterTypeFieldDeclaration dec = - new InterTypeFieldDeclaration( - this.compilationUnit.compilationResult, - onType); - - dec.returnType = returnType; - dec.sourceStart = start; - dec.sourceEnd = end; - dec.setSelector(name); - dec.declarationSourceStart = decSourceStart; - dec.setDeclaredModifiers(modifiers); - dec.setInitialization(initialization); - - pushOnAstStack(dec); - println("consumed field: " + dec); - this.display(); - } - - protected void consumeInterTypeMethodDeclaration(boolean isNotAbstract) { - consumeMethodDeclaration(isNotAbstract); - } - - protected void consumeInterTypeMethodHeader() { - consumeMethodHeader(); - } - - protected void consumeInterTypeConstructorDeclaration() { - consumeMethodDeclaration(true); - } - - protected void consumeInterTypeConstructorHeader() { - consumeMethodHeader(); - } - - protected void consumeInterTypeMethodHeaderName() { - //InterTypeMethodHeaderName ::= Modifiersopt Type OnType '.' JavaIdentifier '(' - this.display(); - InterTypeMethodDeclaration md = - new InterTypeMethodDeclaration( - this.compilationUnit.compilationResult, - null); - - //identifier - char[] name = identifierStack[identifierPtr]; - long selectorSource = identifierPositionStack[identifierPtr--]; - identifierLengthPtr--; - - //onType - md.onType = getTypeReference(0); - - //type - md.returnType = getTypeReference(intStack[intPtr--]); - - //modifiers - md.declarationSourceStart = intStack[intPtr--]; - md.setDeclaredModifiers(intStack[intPtr--]); - - //highlight starts at selector start - md.sourceStart = (int) (selectorSource >>> 32); - pushOnAstStack(md); - md.sourceEnd = lParenPos; - md.bodyStart = lParenPos + 1; - md.setSelector(name); - listLength = 0; - // initialize listLength before reading parameters/throws - - // recovery - if (currentElement != null) { - if (currentElement instanceof RecoveredType - //|| md.modifiers != 0 - || (scanner.getLineNumber(md.returnType.sourceStart) - == scanner.getLineNumber(md.sourceStart))) { - lastCheckPoint = md.bodyStart; - currentElement = currentElement.add(md, 0); - lastIgnoredToken = -1; - } else { - lastCheckPoint = md.sourceStart; - restartRecovery = true; - } - } - } - - protected void consumeInterTypeConstructorHeaderName() { - //InterTypeConstructorHeaderName ::= Modifiersopt Name '.' 'new' '(' - this.display(); - InterTypeConstructorDeclaration md = - new InterTypeConstructorDeclaration( - this.compilationUnit.compilationResult, - null); - - //identifier -// md.selector = identifierStack[identifierPtr]; -// long selectorSource = identifierPositionStack[identifierPtr--]; -//// identifierLengthPtr--; - - //onType - md.onType = getTypeReference(0); - - println("got onType: " + md.onType); - this.display(); - - intPtr--; // pop new info - //type - md.returnType = TypeReference.baseTypeReference(T_void, 0); //getTypeReference(intStack[intPtr--]); - - //modifiers - md.declarationSourceStart = intStack[intPtr--]; - md.setDeclaredModifiers(intStack[intPtr--]); - //md.modifiers = intStack[intPtr--]; - - //highlight starts at selector start - //md.sourceStart = (int) (selectorSource >>> 32); - md.sourceStart = md.onType.sourceStart; - pushOnAstStack(md); - md.sourceEnd = lParenPos; - md.bodyStart = lParenPos + 1; - listLength = 0; - // initialize listLength before reading parameters/throws - - md.setSelector( - (new String(CharOperation.concatWith(md.onType.getTypeName(), '_')) + "_new"). - toCharArray()); - - - // recovery - if (currentElement != null) { - if (currentElement instanceof RecoveredType - //|| md.modifiers != 0 - //|| (scanner.getLineNumber(md.returnType.sourceStart) - // == scanner.getLineNumber(md.sourceStart)) - ) { - //lastCheckPoint = md.bodyStart; - currentElement = currentElement.add(md, 0); - lastIgnoredToken = -1; - } else { - lastCheckPoint = md.sourceStart; - restartRecovery = true; - } - } - } - - - - -//********************************************************* - - - protected void consumePseudoToken(String value) { - consumePseudoToken(value, 0, false); - } - - protected void consumePseudoToken( - String value, - int popFromIntStack, - boolean isIdentifier) { - intPtr -= popFromIntStack; - - int start = currentTokenStart; - int end = start + value.length() - 1; - PseudoToken tok = new PseudoToken(this, value, isIdentifier); - tok.sourceStart = start; - tok.sourceEnd = end; - pushOnAstStack(tok); - } - - protected void consumePseudoTokenIdentifier() { - long pos = identifierPositionStack[identifierPtr]; - int end = (int) pos; - int start = (int) (pos >>> 32); - char[] name = identifierStack[identifierPtr--]; - identifierLengthPtr--; - - PseudoToken tok = new PseudoToken(this, new String(name), true); - tok.sourceStart = start; - tok.sourceEnd = end; - pushOnAstStack(tok); - } - - protected void consumePseudoTokenIf() { - //this.display(); - Expression expr = (Expression) expressionStack[expressionPtr--]; - expressionLengthPtr--; - println("expr: " + expr); - - int start = intStack[intPtr--]; - PseudoToken tok = new IfPseudoToken(this, expr); - tok.sourceStart = start; - tok.sourceEnd = this.rParenPos; - pushOnAstStack(tok); - } - - protected void consumePseudoTokenLiteral() { - Literal literal = (Literal) expressionStack[expressionPtr--]; - expressionLengthPtr--; - //System.out.println("literal: " + new String(literal.source())); - - PseudoToken tok = - new PseudoToken(this, new String(literal.source()), false); - tok.literalKind = "string"; - tok.sourceStart = literal.sourceStart; - tok.sourceEnd = literal.sourceEnd; - pushOnAstStack(tok); - } - - protected void consumePseudoTokenModifier() { - //int modifier = modifiers; - consumePseudoToken(Modifier.toString(modifiers), 0, true); - modifiers = AccDefault; - } - - protected void consumePseudoTokenPrimitiveType() { - TypeReference type = getTypeReference(0); - - PseudoToken tok = new PseudoToken(this, type.toString(), true); - tok.sourceStart = type.sourceStart; - tok.sourceEnd = type.sourceEnd; - pushOnAstStack(tok); - } - - protected void consumePseudoTokens() { - optimizedConcatNodeLists(); - } - -// Helpers - - protected PointcutDesignator popPointcutDesignator(String terminator) { - PseudoTokens tokens = popPseudoTokens(terminator); - return new PointcutDesignator(this, tokens); - } - - protected PseudoTokens popPseudoTokens(String terminator) { - consumePseudoToken(terminator); - consumePseudoTokens(); - //System.out.println("next token is: " + new String(scanner.getCurrentTokenSource())); - - int length = astLengthStack[astLengthPtr--]; - astPtr -= length; - - //arguments - PseudoToken[] tokens = new PseudoToken[length]; - System.arraycopy(astStack, astPtr + 1, tokens, 0, length); - //md.bodyStart = rParenPos+1; - listLength = 0; // reset listLength after having read all parameters - - return new PseudoTokens(tokens, makeSourceContext(this.compilationUnit.compilationResult())); - } - - private ISourceContext makeSourceContext(CompilationResult compilationResult) { - return new EclipseSourceContext(compilationResult); - } - - - private void swapAstStack() { - ASTNode top = astStack[astPtr]; - ASTNode next = astStack[astPtr-1]; - astStack[astPtr] = next; - astStack[astPtr-1] = top; - } - - - - // This method is part of an automatic generation : do NOT edit-modify - protected void consumeRule(int act) { - switch ( act ) { - case 30 : // System.out.println("Type ::= PrimitiveType"); //$NON-NLS-1$ - consumePrimitiveType(); - break ; - - case 44 : // System.out.println("ReferenceType ::= ClassOrInterfaceType"); //$NON-NLS-1$ - consumeReferenceType(); - break ; - - case 62 : // System.out.println("AjQualifiedName ::= AjName DOT SimpleName"); //$NON-NLS-1$ - consumeQualifiedName(); - break ; - - case 66 : // System.out.println("QualifiedName ::= Name DOT JavaIdentifier"); //$NON-NLS-1$ - consumeQualifiedName(); - break ; - - case 67 : // System.out.println("CompilationUnit ::= EnterCompilationUnit PackageDeclarationopt..."); //$NON-NLS-1$ - consumeCompilationUnit(); - break ; - - case 68 : // System.out.println("EnterCompilationUnit ::="); //$NON-NLS-1$ - consumeEnterCompilationUnit(); - break ; - - case 81 : // System.out.println("CatchHeader ::= catch LPAREN FormalParameter RPAREN LBRACE"); //$NON-NLS-1$ - consumeCatchHeader(); - break ; - - case 83 : // System.out.println("ImportDeclarations ::= ImportDeclarations ImportDeclaration"); //$NON-NLS-1$ - consumeImportDeclarations(); - break ; - - case 85 : // System.out.println("TypeDeclarations ::= TypeDeclarations TypeDeclaration"); //$NON-NLS-1$ - consumeTypeDeclarations(); - break ; - - case 86 : // System.out.println("PackageDeclaration ::= PackageDeclarationName SEMICOLON"); //$NON-NLS-1$ - consumePackageDeclaration(); - break ; - - case 87 : // System.out.println("PackageDeclarationName ::= package Name"); //$NON-NLS-1$ - consumePackageDeclarationName(); - break ; - - case 90 : // System.out.println("SingleTypeImportDeclaration ::= SingleTypeImportDeclarationName..."); //$NON-NLS-1$ - consumeSingleTypeImportDeclaration(); - break ; - - case 91 : // System.out.println("SingleTypeImportDeclarationName ::= import Name"); //$NON-NLS-1$ - consumeSingleTypeImportDeclarationName(); - break ; - - case 92 : // System.out.println("TypeImportOnDemandDeclaration ::= TypeImportOnDemandDeclarationName"); //$NON-NLS-1$ - consumeTypeImportOnDemandDeclaration(); - break ; - - case 93 : // System.out.println("TypeImportOnDemandDeclarationName ::= import Name DOT MULTIPLY"); //$NON-NLS-1$ - consumeTypeImportOnDemandDeclarationName(); - break ; - - case 96 : // System.out.println("TypeDeclaration ::= SEMICOLON"); //$NON-NLS-1$ - consumeEmptyTypeDeclaration(); - break ; - - case 122 : // System.out.println("AspectDeclaration ::= AspectHeader AspectBody"); //$NON-NLS-1$ - consumeAspectDeclaration(); - break ; - - case 123 : // System.out.println("AspectHeader ::= AspectHeaderName ClassHeaderExtendsopt..."); //$NON-NLS-1$ - consumeAspectHeader(); - break ; - - case 124 : // System.out.println("AspectHeaderName ::= Modifiersopt aspect Identifier"); //$NON-NLS-1$ - consumeAspectHeaderName(false); - break ; - - case 125 : // System.out.println("AspectHeaderName ::= Modifiersopt privileged Modifiersopt aspect..."); //$NON-NLS-1$ - consumeAspectHeaderName(true); - break ; - - case 127 : // System.out.println("AspectHeaderRest ::= AspectHeaderRestStart PseudoTokens"); //$NON-NLS-1$ - consumeAspectHeaderRest(); - break ; - - case 128 : // System.out.println("AspectHeaderRestStart ::= Identifier"); //$NON-NLS-1$ - consumePseudoTokenIdentifier(); - break ; - - case 131 : // System.out.println("AspectBodyDeclarations ::= AspectBodyDeclarations..."); //$NON-NLS-1$ - consumeClassBodyDeclarations(); - break ; - - case 132 : // System.out.println("AspectBodyDeclarationsopt ::="); //$NON-NLS-1$ - consumeEmptyClassBodyDeclarationsopt(); - break ; - - case 133 : // System.out.println("AspectBodyDeclarationsopt ::= NestedType AspectBodyDeclarations"); //$NON-NLS-1$ - consumeClassBodyDeclarationsopt(); - break ; - - case 134 : // System.out.println("AspectBodyDeclaration ::= ClassBodyDeclaration"); //$NON-NLS-1$ - consumeClassBodyDeclarationInAspect(); - break ; - - case 135 : // System.out.println("PointcutDeclaration ::= PointcutHeader MethodHeaderParameters..."); //$NON-NLS-1$ - consumeEmptyPointcutDeclaration(); - break ; - - case 136 : // System.out.println("PointcutDeclaration ::= PointcutHeader MethodHeaderParameters COLON"); //$NON-NLS-1$ - consumePointcutDeclaration(); - break ; - - case 137 : // System.out.println("PointcutHeader ::= Modifiersopt pointcut JavaIdentifier LPAREN"); //$NON-NLS-1$ - consumePointcutHeader(); - break ; - - case 140 : // System.out.println("AroundDeclaration ::= AroundHeader MethodBody"); //$NON-NLS-1$ - consumeAroundDeclaration(); - break ; - - case 141 : // System.out.println("AroundHeader ::= AroundHeaderName MethodHeaderParameters..."); //$NON-NLS-1$ - consumeAroundHeader(); - break ; - - case 142 : // System.out.println("AroundHeaderName ::= Modifiersopt Type around LPAREN"); //$NON-NLS-1$ - consumeAroundHeaderName(); - break ; - - case 143 : // System.out.println("BasicAdviceDeclaration ::= BasicAdviceHeader MethodBody"); //$NON-NLS-1$ - consumeBasicAdviceDeclaration(); - break ; - - case 144 : // System.out.println("BasicAdviceHeader ::= BasicAdviceHeaderName MethodHeaderParameters"); //$NON-NLS-1$ - consumeBasicAdviceHeader(); - break ; - - case 145 : // System.out.println("BasicAdviceHeaderName ::= Modifiersopt before LPAREN"); //$NON-NLS-1$ - consumeBasicAdviceHeaderName(false); - break ; - - case 146 : // System.out.println("BasicAdviceHeaderName ::= Modifiersopt after LPAREN"); //$NON-NLS-1$ - consumeBasicAdviceHeaderName(true); - break ; - - case 147 : // System.out.println("ExtraParamopt ::= Identifier LPAREN FormalParameter RPAREN"); //$NON-NLS-1$ - consumeExtraParameterWithFormal(); - break ; - - case 148 : // System.out.println("ExtraParamopt ::= Identifier LPAREN RPAREN"); //$NON-NLS-1$ - consumeExtraParameterNoFormal(); - break ; - - case 149 : // System.out.println("ExtraParamopt ::= Identifier"); //$NON-NLS-1$ - consumeExtraParameterNoFormal(); - break ; - - case 152 : // System.out.println("OnType ::= OnType DOT JavaIdentifier"); //$NON-NLS-1$ - consumeQualifiedName(); - break ; - - case 157 : // System.out.println("InterTypeMethodDeclaration ::= InterTypeMethodHeader MethodBody"); //$NON-NLS-1$ - // set to true to consume a method with a body - consumeInterTypeMethodDeclaration(true); - break ; - - case 158 : // System.out.println("InterTypeMethodHeader ::= InterTypeMethodHeaderName..."); //$NON-NLS-1$ - consumeInterTypeMethodHeader(); - break ; - - case 159 : // System.out.println("InterTypeMethodHeaderName ::= Modifiersopt Type OnType DOT..."); //$NON-NLS-1$ - consumeInterTypeMethodHeaderName(); - break ; - - case 160 : // System.out.println("AbstractInterTypeMethodDeclaration ::= InterTypeMethodHeader..."); //$NON-NLS-1$ - // set to false to consume a method without body - consumeInterTypeMethodDeclaration(false); - break ; - - case 161 : // System.out.println("InterTypeConstructorDeclaration ::= InterTypeConstructorHeader..."); //$NON-NLS-1$ - // set to true to consume a method with a body - consumeInterTypeConstructorDeclaration(); - break ; - - case 162 : // System.out.println("InterTypeConstructorHeader ::= InterTypeConstructorHeaderName..."); //$NON-NLS-1$ - consumeInterTypeConstructorHeader(); - break ; - - case 163 : // System.out.println("InterTypeConstructorHeaderName ::= Modifiersopt Name DOT new LPAREN"); //$NON-NLS-1$ - consumeInterTypeConstructorHeaderName(); - break ; - - case 164 : // System.out.println("InterTypeFieldDeclaration ::= Modifiersopt Type OnType DOT..."); //$NON-NLS-1$ - consumeInterTypeFieldDeclaration(); - break ; - - case 168 : // System.out.println("DeclareDeclaration ::= DeclareHeader PseudoTokens SEMICOLON"); //$NON-NLS-1$ - consumeDeclareDeclaration(); - break ; - - case 169 : // System.out.println("DeclareHeader ::= declare Identifier COLON"); //$NON-NLS-1$ - consumeDeclareHeader(); - break ; - - case 171 : // System.out.println("PseudoTokens ::= PseudoTokens PseudoToken"); //$NON-NLS-1$ - consumePseudoTokens(); - break ; - - case 172 : // System.out.println("PseudoToken ::= JavaIdentifier"); //$NON-NLS-1$ - consumePseudoTokenIdentifier(); - break ; - - case 173 : // System.out.println("PseudoToken ::= LPAREN"); //$NON-NLS-1$ - consumePseudoToken("("); - break ; - - case 174 : // System.out.println("PseudoToken ::= RPAREN"); //$NON-NLS-1$ - consumePseudoToken(")"); - break ; - - case 175 : // System.out.println("PseudoToken ::= DOT"); //$NON-NLS-1$ - consumePseudoToken("."); - break ; - - case 176 : // System.out.println("PseudoToken ::= MULTIPLY"); //$NON-NLS-1$ - consumePseudoToken("*"); - break ; - - case 177 : // System.out.println("PseudoToken ::= PLUS"); //$NON-NLS-1$ - consumePseudoToken("+"); - break ; - - case 178 : // System.out.println("PseudoToken ::= AND_AND"); //$NON-NLS-1$ - consumePseudoToken("&&"); - break ; - - case 179 : // System.out.println("PseudoToken ::= OR_OR"); //$NON-NLS-1$ - consumePseudoToken("||"); - break ; - - case 180 : // System.out.println("PseudoToken ::= NOT"); //$NON-NLS-1$ - consumePseudoToken("!"); - break ; - - case 181 : // System.out.println("PseudoToken ::= COLON"); //$NON-NLS-1$ - consumePseudoToken(":"); - break ; - - case 182 : // System.out.println("PseudoToken ::= COMMA"); //$NON-NLS-1$ - consumePseudoToken(","); - break ; - - case 183 : // System.out.println("PseudoToken ::= LBRACKET"); //$NON-NLS-1$ - consumePseudoToken("["); - break ; - - case 184 : // System.out.println("PseudoToken ::= RBRACKET"); //$NON-NLS-1$ - consumePseudoToken("]"); - break ; - - case 185 : // System.out.println("PseudoToken ::= PrimitiveType"); //$NON-NLS-1$ - consumePseudoTokenPrimitiveType(); - break ; - - case 186 : // System.out.println("PseudoToken ::= Modifier"); //$NON-NLS-1$ - consumePseudoTokenModifier(); - break ; - - case 187 : // System.out.println("PseudoToken ::= Literal"); //$NON-NLS-1$ - consumePseudoTokenLiteral(); - break ; - - case 188 : // System.out.println("PseudoToken ::= this"); //$NON-NLS-1$ - consumePseudoToken("this", 1, true); - break ; - - case 189 : // System.out.println("PseudoToken ::= super"); //$NON-NLS-1$ - consumePseudoToken("super", 1, true); - break ; - - case 190 : // System.out.println("PseudoToken ::= if LPAREN Expression RPAREN"); //$NON-NLS-1$ - consumePseudoTokenIf(); - break ; - - case 191 : // System.out.println("PseudoToken ::= assert"); //$NON-NLS-1$ - consumePseudoToken("assert", 1, true); - break ; - - case 192 : // System.out.println("PseudoToken ::= import"); //$NON-NLS-1$ - consumePseudoToken("import", 1, true); - break ; - - case 193 : // System.out.println("PseudoToken ::= package"); //$NON-NLS-1$ - consumePseudoToken("package", 1, true); - break ; - - case 194 : // System.out.println("PseudoToken ::= throw"); //$NON-NLS-1$ - consumePseudoToken("throw", 1, true); - break ; - - case 195 : // System.out.println("PseudoToken ::= new"); //$NON-NLS-1$ - consumePseudoToken("new", 1, true); - break ; - - case 196 : // System.out.println("PseudoToken ::= do"); //$NON-NLS-1$ - consumePseudoToken("do", 1, true); - break ; - - case 197 : // System.out.println("PseudoToken ::= for"); //$NON-NLS-1$ - consumePseudoToken("for", 1, true); - break ; - - case 198 : // System.out.println("PseudoToken ::= switch"); //$NON-NLS-1$ - consumePseudoToken("switch", 1, true); - break ; - - case 199 : // System.out.println("PseudoToken ::= try"); //$NON-NLS-1$ - consumePseudoToken("try", 1, true); - break ; - - case 200 : // System.out.println("PseudoToken ::= while"); //$NON-NLS-1$ - consumePseudoToken("while", 1, true); - break ; - - case 201 : // System.out.println("PseudoToken ::= break"); //$NON-NLS-1$ - consumePseudoToken("break", 1, true); - break ; - - case 202 : // System.out.println("PseudoToken ::= continue"); //$NON-NLS-1$ - consumePseudoToken("continue", 1, true); - break ; - - case 203 : // System.out.println("PseudoToken ::= return"); //$NON-NLS-1$ - consumePseudoToken("return", 1, true); - break ; - - case 204 : // System.out.println("PseudoToken ::= case"); //$NON-NLS-1$ - consumePseudoToken("case", 1, true); - break ; - - case 205 : // System.out.println("PseudoToken ::= catch"); //$NON-NLS-1$ - consumePseudoToken("catch", 0, true); - break ; - - case 206 : // System.out.println("PseudoToken ::= instanceof"); //$NON-NLS-1$ - consumePseudoToken("instanceof", 0, true); - break ; - - case 207 : // System.out.println("PseudoToken ::= else"); //$NON-NLS-1$ - consumePseudoToken("else", 0, true); - break ; - - case 208 : // System.out.println("PseudoToken ::= extends"); //$NON-NLS-1$ - consumePseudoToken("extends", 0, true); - break ; - - case 209 : // System.out.println("PseudoToken ::= finally"); //$NON-NLS-1$ - consumePseudoToken("finally", 0, true); - break ; - - case 210 : // System.out.println("PseudoToken ::= implements"); //$NON-NLS-1$ - consumePseudoToken("implements", 0, true); - break ; - - case 211 : // System.out.println("PseudoToken ::= throws"); //$NON-NLS-1$ - consumePseudoToken("throws", 0, true); - break ; - - case 212 : // System.out.println("ClassDeclaration ::= ClassHeader ClassBody"); //$NON-NLS-1$ - consumeClassDeclaration(); - break ; - - case 213 : // System.out.println("ClassHeader ::= ClassHeaderName ClassHeaderExtendsopt..."); //$NON-NLS-1$ - consumeClassHeader(); - break ; - - case 214 : // System.out.println("ClassHeaderName ::= Modifiersopt class JavaIdentifier"); //$NON-NLS-1$ - consumeClassHeaderName(); - break ; - - case 215 : // System.out.println("ClassHeaderExtends ::= extends ClassType"); //$NON-NLS-1$ - consumeClassHeaderExtends(); - break ; - - case 216 : // System.out.println("ClassHeaderImplements ::= implements InterfaceTypeList"); //$NON-NLS-1$ - consumeClassHeaderImplements(); - break ; - - case 218 : // System.out.println("InterfaceTypeList ::= InterfaceTypeList COMMA InterfaceType"); //$NON-NLS-1$ - consumeInterfaceTypeList(); - break ; - - case 219 : // System.out.println("InterfaceType ::= ClassOrInterfaceType"); //$NON-NLS-1$ - consumeInterfaceType(); - break ; - - case 222 : // System.out.println("ClassBodyDeclarations ::= ClassBodyDeclarations ClassBodyDeclaration"); //$NON-NLS-1$ - consumeClassBodyDeclarations(); - break ; - - case 226 : // System.out.println("ClassBodyDeclaration ::= Diet NestedMethod Block"); //$NON-NLS-1$ - consumeClassBodyDeclaration(); - break ; - - case 227 : // System.out.println("Diet ::="); //$NON-NLS-1$ - consumeDiet(); - break ; - - case 228 : // System.out.println("Initializer ::= Diet NestedMethod Block"); //$NON-NLS-1$ - consumeClassBodyDeclaration(); - break ; - - case 235 : // System.out.println("ClassMemberDeclaration ::= SEMICOLON"); //$NON-NLS-1$ - consumeEmptyClassMemberDeclaration(); - break ; - - case 236 : // System.out.println("FieldDeclaration ::= Modifiersopt Type VariableDeclarators SEMICOLON"); //$NON-NLS-1$ - consumeFieldDeclaration(); - break ; - - case 238 : // System.out.println("VariableDeclarators ::= VariableDeclarators COMMA VariableDeclarator"); //$NON-NLS-1$ - consumeVariableDeclarators(); - break ; - - case 241 : // System.out.println("EnterVariable ::="); //$NON-NLS-1$ - consumeEnterVariable(); - break ; - - case 242 : // System.out.println("ExitVariableWithInitialization ::="); //$NON-NLS-1$ - consumeExitVariableWithInitialization(); - break ; - - case 243 : // System.out.println("ExitVariableWithoutInitialization ::="); //$NON-NLS-1$ - consumeExitVariableWithoutInitialization(); - break ; - - case 244 : // System.out.println("ForceNoDiet ::="); //$NON-NLS-1$ - consumeForceNoDiet(); - break ; - - case 245 : // System.out.println("RestoreDiet ::="); //$NON-NLS-1$ - consumeRestoreDiet(); - break ; - - case 250 : // System.out.println("MethodDeclaration ::= MethodHeader MethodBody"); //$NON-NLS-1$ - // set to true to consume a method with a body - consumeMethodDeclaration(true); - break ; - - case 251 : // System.out.println("AbstractMethodDeclaration ::= MethodHeader SEMICOLON"); //$NON-NLS-1$ - // set to false to consume a method without body - consumeMethodDeclaration(false); - break ; - - case 252 : // System.out.println("MethodHeader ::= MethodHeaderName MethodHeaderParameters..."); //$NON-NLS-1$ - consumeMethodHeader(); - break ; - - case 253 : // System.out.println("MethodHeaderName ::= Modifiersopt Type JavaIdentifierNoAround LPAREN"); //$NON-NLS-1$ - consumeMethodHeaderName(); - break ; - - case 254 : // System.out.println("MethodHeaderParameters ::= FormalParameterListopt RPAREN"); //$NON-NLS-1$ - consumeMethodHeaderParameters(); - break ; - - case 255 : // System.out.println("MethodHeaderExtendedDims ::= Dimsopt"); //$NON-NLS-1$ - consumeMethodHeaderExtendedDims(); - break ; - - case 256 : // System.out.println("MethodHeaderThrowsClause ::= throws ClassTypeList"); //$NON-NLS-1$ - consumeMethodHeaderThrowsClause(); - break ; - - case 257 : // System.out.println("ConstructorHeader ::= ConstructorHeaderName MethodHeaderParameters"); //$NON-NLS-1$ - consumeConstructorHeader(); - break ; - - case 258 : // System.out.println("ConstructorHeaderName ::= Modifiersopt Identifier LPAREN"); //$NON-NLS-1$ - consumeConstructorHeaderName(); - break ; - - case 259 : // System.out.println("ConstructorHeaderName ::= Modifiersopt aspect LPAREN"); //$NON-NLS-1$ - consumeConstructorHeaderName(); - break ; - - case 261 : // System.out.println("FormalParameterList ::= FormalParameterList COMMA FormalParameter"); //$NON-NLS-1$ - consumeFormalParameterList(); - break ; - - case 262 : // System.out.println("FormalParameter ::= Modifiersopt Type VariableDeclaratorId"); //$NON-NLS-1$ - // the boolean is used to know if the modifiers should be reset - consumeFormalParameter(); - break ; - - case 264 : // System.out.println("ClassTypeList ::= ClassTypeList COMMA ClassTypeElt"); //$NON-NLS-1$ - consumeClassTypeList(); - break ; - - case 265 : // System.out.println("ClassTypeElt ::= ClassType"); //$NON-NLS-1$ - consumeClassTypeElt(); - break ; - - case 266 : // System.out.println("MethodBody ::= NestedMethod LBRACE BlockStatementsopt RBRACE"); //$NON-NLS-1$ - consumeMethodBody(); - break ; - - case 267 : // System.out.println("NestedMethod ::="); //$NON-NLS-1$ - consumeNestedMethod(); - break ; - - case 268 : // System.out.println("StaticInitializer ::= StaticOnly Block"); //$NON-NLS-1$ - consumeStaticInitializer(); - break ; - - case 269 : // System.out.println("StaticOnly ::= static"); //$NON-NLS-1$ - consumeStaticOnly(); - break ; - - case 270 : // System.out.println("ConstructorDeclaration ::= ConstructorHeader MethodBody"); //$NON-NLS-1$ - consumeConstructorDeclaration() ; - break ; - - case 271 : // System.out.println("ConstructorDeclaration ::= ConstructorHeader SEMICOLON"); //$NON-NLS-1$ - consumeInvalidConstructorDeclaration() ; - break ; - - case 272 : // System.out.println("ExplicitConstructorInvocation ::= this LPAREN ArgumentListopt RPAREN"); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(0,ExplicitConstructorCall.This); - break ; - - case 273 : // System.out.println("ExplicitConstructorInvocation ::= super LPAREN ArgumentListopt..."); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(0,ExplicitConstructorCall.Super); - break ; - - case 274 : // System.out.println("ExplicitConstructorInvocation ::= Primary DOT super LPAREN..."); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(1, ExplicitConstructorCall.Super); - break ; - - case 275 : // System.out.println("ExplicitConstructorInvocation ::= Name DOT super LPAREN..."); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(2, ExplicitConstructorCall.Super); - break ; - - case 276 : // System.out.println("ExplicitConstructorInvocation ::= Primary DOT this LPAREN..."); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(1, ExplicitConstructorCall.This); - break ; - - case 277 : // System.out.println("ExplicitConstructorInvocation ::= Name DOT this LPAREN..."); //$NON-NLS-1$ - consumeExplicitConstructorInvocation(2, ExplicitConstructorCall.This); - break ; - - case 278 : // System.out.println("InterfaceDeclaration ::= InterfaceHeader InterfaceBody"); //$NON-NLS-1$ - consumeInterfaceDeclaration(); - break ; - - case 279 : // System.out.println("InterfaceHeader ::= InterfaceHeaderName InterfaceHeaderExtendsopt"); //$NON-NLS-1$ - consumeInterfaceHeader(); - break ; - - case 280 : // System.out.println("InterfaceHeaderName ::= Modifiersopt interface JavaIdentifier"); //$NON-NLS-1$ - consumeInterfaceHeaderName(); - break ; - - case 282 : // System.out.println("InterfaceHeaderExtends ::= extends InterfaceTypeList"); //$NON-NLS-1$ - consumeInterfaceHeaderExtends(); - break ; - - case 285 : // System.out.println("InterfaceMemberDeclarations ::= InterfaceMemberDeclarations..."); //$NON-NLS-1$ - consumeInterfaceMemberDeclarations(); - break ; - - case 286 : // System.out.println("InterfaceMemberDeclaration ::= SEMICOLON"); //$NON-NLS-1$ - consumeEmptyInterfaceMemberDeclaration(); - break ; - - case 289 : // System.out.println("InterfaceMemberDeclaration ::= InvalidMethodDeclaration"); //$NON-NLS-1$ - ignoreMethodBody(); - break ; - - case 290 : // System.out.println("InvalidConstructorDeclaration ::= ConstructorHeader MethodBody"); //$NON-NLS-1$ - ignoreInvalidConstructorDeclaration(true); - break ; - - case 291 : // System.out.println("InvalidConstructorDeclaration ::= ConstructorHeader SEMICOLON"); //$NON-NLS-1$ - ignoreInvalidConstructorDeclaration(false); - break ; - - case 297 : // System.out.println("ArrayInitializer ::= LBRACE ,opt RBRACE"); //$NON-NLS-1$ - consumeEmptyArrayInitializer(); - break ; - - case 298 : // System.out.println("ArrayInitializer ::= LBRACE VariableInitializers RBRACE"); //$NON-NLS-1$ - consumeArrayInitializer(); - break ; - - case 299 : // System.out.println("ArrayInitializer ::= LBRACE VariableInitializers COMMA RBRACE"); //$NON-NLS-1$ - consumeArrayInitializer(); - break ; - - case 301 : // System.out.println("VariableInitializers ::= VariableInitializers COMMA..."); //$NON-NLS-1$ - consumeVariableInitializers(); - break ; - - case 302 : // System.out.println("Block ::= OpenBlock LBRACE BlockStatementsopt RBRACE"); //$NON-NLS-1$ - consumeBlock(); - break ; - - case 303 : // System.out.println("OpenBlock ::="); //$NON-NLS-1$ - consumeOpenBlock() ; - break ; - - case 305 : // System.out.println("BlockStatements ::= BlockStatements BlockStatement"); //$NON-NLS-1$ - consumeBlockStatements() ; - break ; - - case 309 : // System.out.println("BlockStatement ::= InvalidInterfaceDeclaration"); //$NON-NLS-1$ - ignoreInterfaceDeclaration(); - break ; - - case 310 : // System.out.println("LocalVariableDeclarationStatement ::= LocalVariableDeclaration..."); //$NON-NLS-1$ - consumeLocalVariableDeclarationStatement(); - break ; - - case 311 : // System.out.println("LocalVariableDeclaration ::= Type PushModifiers VariableDeclarators"); //$NON-NLS-1$ - consumeLocalVariableDeclaration(); - break ; - - case 312 : // System.out.println("LocalVariableDeclaration ::= Modifiers Type PushModifiers..."); //$NON-NLS-1$ - consumeLocalVariableDeclaration(); - break ; - - case 313 : // System.out.println("PushModifiers ::="); //$NON-NLS-1$ - consumePushModifiers(); - break ; - - case 337 : // System.out.println("EmptyStatement ::= SEMICOLON"); //$NON-NLS-1$ - consumeEmptyStatement(); - break ; - - case 338 : // System.out.println("LabeledStatement ::= JavaIdentifier COLON Statement"); //$NON-NLS-1$ - consumeStatementLabel() ; - break ; - - case 339 : // System.out.println("LabeledStatementNoShortIf ::= JavaIdentifier COLON..."); //$NON-NLS-1$ - consumeStatementLabel() ; - break ; - - case 340 : // System.out.println("ExpressionStatement ::= StatementExpression SEMICOLON"); //$NON-NLS-1$ - consumeExpressionStatement(); - break ; - - case 349 : // System.out.println("IfThenStatement ::= if LPAREN Expression RPAREN Statement"); //$NON-NLS-1$ - consumeStatementIfNoElse(); - break ; - - case 350 : // System.out.println("IfThenElseStatement ::= if LPAREN Expression RPAREN..."); //$NON-NLS-1$ - consumeStatementIfWithElse(); - break ; - - case 351 : // System.out.println("IfThenElseStatementNoShortIf ::= if LPAREN Expression RPAREN..."); //$NON-NLS-1$ - consumeStatementIfWithElse(); - break ; - - case 352 : // System.out.println("SwitchStatement ::= switch LPAREN Expression RPAREN OpenBlock..."); //$NON-NLS-1$ - consumeStatementSwitch() ; - break ; - - case 353 : // System.out.println("SwitchBlock ::= LBRACE RBRACE"); //$NON-NLS-1$ - consumeEmptySwitchBlock() ; - break ; - - case 356 : // System.out.println("SwitchBlock ::= LBRACE SwitchBlockStatements SwitchLabels RBRACE"); //$NON-NLS-1$ - consumeSwitchBlock() ; - break ; - - case 358 : // System.out.println("SwitchBlockStatements ::= SwitchBlockStatements SwitchBlockStatement"); //$NON-NLS-1$ - consumeSwitchBlockStatements() ; - break ; - - case 359 : // System.out.println("SwitchBlockStatement ::= SwitchLabels BlockStatements"); //$NON-NLS-1$ - consumeSwitchBlockStatement() ; - break ; - - case 361 : // System.out.println("SwitchLabels ::= SwitchLabels SwitchLabel"); //$NON-NLS-1$ - consumeSwitchLabels() ; - break ; - - case 362 : // System.out.println("SwitchLabel ::= case ConstantExpression COLON"); //$NON-NLS-1$ - consumeCaseLabel(); - break ; - - case 363 : // System.out.println("SwitchLabel ::= default COLON"); //$NON-NLS-1$ - consumeDefaultLabel(); - break ; - - case 364 : // System.out.println("WhileStatement ::= while LPAREN Expression RPAREN Statement"); //$NON-NLS-1$ - consumeStatementWhile() ; - break ; - - case 365 : // System.out.println("WhileStatementNoShortIf ::= while LPAREN Expression RPAREN..."); //$NON-NLS-1$ - consumeStatementWhile() ; - break ; - - case 366 : // System.out.println("DoStatement ::= do Statement while LPAREN Expression RPAREN..."); //$NON-NLS-1$ - consumeStatementDo() ; - break ; - - case 367 : // System.out.println("ForStatement ::= for LPAREN ForInitopt SEMICOLON Expressionopt..."); //$NON-NLS-1$ - consumeStatementFor() ; - break ; - - case 368 : // System.out.println("ForStatementNoShortIf ::= for LPAREN ForInitopt SEMICOLON..."); //$NON-NLS-1$ - consumeStatementFor() ; - break ; - - case 369 : // System.out.println("ForInit ::= StatementExpressionList"); //$NON-NLS-1$ - consumeForInit() ; - break ; - - case 373 : // System.out.println("StatementExpressionList ::= StatementExpressionList COMMA..."); //$NON-NLS-1$ - consumeStatementExpressionList() ; - break ; - - case 374 : // System.out.println("AssertStatement ::= assert Expression SEMICOLON"); //$NON-NLS-1$ - consumeSimpleAssertStatement() ; - break ; - - case 375 : // System.out.println("AssertStatement ::= assert Expression COLON Expression SEMICOLON"); //$NON-NLS-1$ - consumeAssertStatement() ; - break ; - - case 376 : // System.out.println("BreakStatement ::= break SEMICOLON"); //$NON-NLS-1$ - consumeStatementBreak() ; - break ; - - case 377 : // System.out.println("BreakStatement ::= break Identifier SEMICOLON"); //$NON-NLS-1$ - consumeStatementBreakWithLabel() ; - break ; - - case 378 : // System.out.println("ContinueStatement ::= continue SEMICOLON"); //$NON-NLS-1$ - consumeStatementContinue() ; - break ; - - case 379 : // System.out.println("ContinueStatement ::= continue Identifier SEMICOLON"); //$NON-NLS-1$ - consumeStatementContinueWithLabel() ; - break ; - - case 380 : // System.out.println("ReturnStatement ::= return Expressionopt SEMICOLON"); //$NON-NLS-1$ - consumeStatementReturn() ; - break ; - - case 381 : // System.out.println("ThrowStatement ::= throw Expression SEMICOLON"); //$NON-NLS-1$ - consumeStatementThrow(); - - break ; - - case 382 : // System.out.println("SynchronizedStatement ::= OnlySynchronized LPAREN Expression RPAREN"); //$NON-NLS-1$ - consumeStatementSynchronized(); - break ; - - case 383 : // System.out.println("OnlySynchronized ::= synchronized"); //$NON-NLS-1$ - consumeOnlySynchronized(); - break ; - - case 384 : // System.out.println("TryStatement ::= try TryBlock Catches"); //$NON-NLS-1$ - consumeStatementTry(false); - break ; - - case 385 : // System.out.println("TryStatement ::= try TryBlock Catchesopt Finally"); //$NON-NLS-1$ - consumeStatementTry(true); - break ; - - case 387 : // System.out.println("ExitTryBlock ::="); //$NON-NLS-1$ - consumeExitTryBlock(); - break ; - - case 389 : // System.out.println("Catches ::= Catches CatchClause"); //$NON-NLS-1$ - consumeCatches(); - break ; - - case 390 : // System.out.println("CatchClause ::= catch LPAREN FormalParameter RPAREN Block"); //$NON-NLS-1$ - consumeStatementCatch() ; - break ; - - case 392 : // System.out.println("PushLPAREN ::= LPAREN"); //$NON-NLS-1$ - consumeLeftParen(); - break ; - - case 393 : // System.out.println("PushRPAREN ::= RPAREN"); //$NON-NLS-1$ - consumeRightParen(); - break ; - - case 398 : // System.out.println("PrimaryNoNewArray ::= this"); //$NON-NLS-1$ - consumePrimaryNoNewArrayThis(); - break ; - - case 399 : // System.out.println("PrimaryNoNewArray ::= PushLPAREN Expression PushRPAREN"); //$NON-NLS-1$ - consumePrimaryNoNewArray(); - break ; - - case 402 : // System.out.println("PrimaryNoNewArray ::= Name DOT this"); //$NON-NLS-1$ - consumePrimaryNoNewArrayNameThis(); - break ; - - case 403 : // System.out.println("PrimaryNoNewArray ::= Name DOT super"); //$NON-NLS-1$ - consumePrimaryNoNewArrayNameSuper(); - break ; - - case 404 : // System.out.println("PrimaryNoNewArray ::= Name DOT class"); //$NON-NLS-1$ - consumePrimaryNoNewArrayName(); - break ; - - case 405 : // System.out.println("PrimaryNoNewArray ::= ArrayType DOT class"); //$NON-NLS-1$ - consumePrimaryNoNewArrayArrayType(); - break ; - - case 406 : // System.out.println("PrimaryNoNewArray ::= PrimitiveType DOT class"); //$NON-NLS-1$ - consumePrimaryNoNewArrayPrimitiveType(); - break ; - - case 409 : // System.out.println("AllocationHeader ::= new ClassType LPAREN ArgumentListopt RPAREN"); //$NON-NLS-1$ - consumeAllocationHeader(); - break ; - - case 410 : // System.out.println("ClassInstanceCreationExpression ::= new ClassType LPAREN..."); //$NON-NLS-1$ - consumeClassInstanceCreationExpression(); - break ; - - case 411 : // System.out.println("ClassInstanceCreationExpression ::= Primary DOT new SimpleName..."); //$NON-NLS-1$ - consumeClassInstanceCreationExpressionQualified() ; - break ; - - case 412 : // System.out.println("ClassInstanceCreationExpression ::=..."); //$NON-NLS-1$ - consumeClassInstanceCreationExpressionQualified() ; - break ; - - case 413 : // System.out.println("ClassInstanceCreationExpressionName ::= Name DOT"); //$NON-NLS-1$ - consumeClassInstanceCreationExpressionName() ; - break ; - - case 414 : // System.out.println("ClassBodyopt ::="); //$NON-NLS-1$ - consumeClassBodyopt(); - break ; - - case 416 : // System.out.println("EnterAnonymousClassBody ::="); //$NON-NLS-1$ - consumeEnterAnonymousClassBody(); - break ; - - case 418 : // System.out.println("ArgumentList ::= ArgumentList COMMA Expression"); //$NON-NLS-1$ - consumeArgumentList(); - break ; - - case 419 : // System.out.println("ArrayCreationHeader ::= new PrimitiveType DimWithOrWithOutExprs"); //$NON-NLS-1$ - consumeArrayCreationHeader(); - break ; - - case 420 : // System.out.println("ArrayCreationHeader ::= new ClassOrInterfaceType..."); //$NON-NLS-1$ - consumeArrayCreationHeader(); - break ; - - case 421 : // System.out.println("ArrayCreationWithoutArrayInitializer ::= new PrimitiveType..."); //$NON-NLS-1$ - consumeArrayCreationExpressionWithoutInitializer(); - break ; - - case 422 : // System.out.println("ArrayCreationWithArrayInitializer ::= new PrimitiveType..."); //$NON-NLS-1$ - consumeArrayCreationExpressionWithInitializer(); - break ; - - case 423 : // System.out.println("ArrayCreationWithoutArrayInitializer ::= new ClassOrInterfaceType..."); //$NON-NLS-1$ - consumeArrayCreationExpressionWithoutInitializer(); - break ; - - case 424 : // System.out.println("ArrayCreationWithArrayInitializer ::= new ClassOrInterfaceType..."); //$NON-NLS-1$ - consumeArrayCreationExpressionWithInitializer(); - break ; - - case 426 : // System.out.println("DimWithOrWithOutExprs ::= DimWithOrWithOutExprs DimWithOrWithOutExpr"); //$NON-NLS-1$ - consumeDimWithOrWithOutExprs(); - break ; - - case 428 : // System.out.println("DimWithOrWithOutExpr ::= LBRACKET RBRACKET"); //$NON-NLS-1$ - consumeDimWithOrWithOutExpr(); - break ; - - case 429 : // System.out.println("Dims ::= DimsLoop"); //$NON-NLS-1$ - consumeDims(); - break ; - - case 432 : // System.out.println("OneDimLoop ::= LBRACKET RBRACKET"); //$NON-NLS-1$ - consumeOneDimLoop(); - break ; - - case 433 : // System.out.println("FieldAccess ::= Primary DOT JavaIdentifier"); //$NON-NLS-1$ - consumeFieldAccess(false); - break ; - - case 434 : // System.out.println("FieldAccess ::= super DOT JavaIdentifier"); //$NON-NLS-1$ - consumeFieldAccess(true); - break ; - - case 435 : // System.out.println("MethodInvocation ::= NameOrAj LPAREN ArgumentListopt RPAREN"); //$NON-NLS-1$ - consumeMethodInvocationName(); - break ; - - case 436 : // System.out.println("MethodInvocation ::= Primary DOT JavaIdentifier LPAREN..."); //$NON-NLS-1$ - consumeMethodInvocationPrimary(); - break ; - - case 437 : // System.out.println("MethodInvocation ::= super DOT JavaIdentifier LPAREN ArgumentListopt"); //$NON-NLS-1$ - consumeMethodInvocationSuper(); - break ; - - case 438 : // System.out.println("ArrayAccess ::= Name LBRACKET Expression RBRACKET"); //$NON-NLS-1$ - consumeArrayAccess(true); - break ; - - case 439 : // System.out.println("ArrayAccess ::= PrimaryNoNewArray LBRACKET Expression RBRACKET"); //$NON-NLS-1$ - consumeArrayAccess(false); - break ; - - case 440 : // System.out.println("ArrayAccess ::= ArrayCreationWithArrayInitializer LBRACKET..."); //$NON-NLS-1$ - consumeArrayAccess(false); - break ; - - case 442 : // System.out.println("PostfixExpression ::= NameOrAj"); //$NON-NLS-1$ - consumePostfixExpression(); - break ; - - case 445 : // System.out.println("PostIncrementExpression ::= PostfixExpression PLUS_PLUS"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.PLUS,true); - break ; - - case 446 : // System.out.println("PostDecrementExpression ::= PostfixExpression MINUS_MINUS"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.MINUS,true); - break ; - - case 447 : // System.out.println("PushPosition ::="); //$NON-NLS-1$ - consumePushPosition(); - break ; - - case 450 : // System.out.println("UnaryExpression ::= PLUS PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.PLUS); - break ; - - case 451 : // System.out.println("UnaryExpression ::= MINUS PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.MINUS); - break ; - - case 453 : // System.out.println("PreIncrementExpression ::= PLUS_PLUS PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.PLUS,false); - break ; - - case 454 : // System.out.println("PreDecrementExpression ::= MINUS_MINUS PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.MINUS,false); - break ; - - case 456 : // System.out.println("UnaryExpressionNotPlusMinus ::= TWIDDLE PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.TWIDDLE); - break ; - - case 457 : // System.out.println("UnaryExpressionNotPlusMinus ::= NOT PushPosition UnaryExpression"); //$NON-NLS-1$ - consumeUnaryExpression(OperatorIds.NOT); - break ; - - case 459 : // System.out.println("CastExpression ::= PushLPAREN PrimitiveType Dimsopt PushRPAREN..."); //$NON-NLS-1$ - consumeCastExpression(); - break ; - - case 460 : // System.out.println("CastExpression ::= PushLPAREN Name Dims PushRPAREN..."); //$NON-NLS-1$ - consumeCastExpression(); - break ; - - case 461 : // System.out.println("CastExpression ::= PushLPAREN Expression PushRPAREN..."); //$NON-NLS-1$ - consumeCastExpressionLL1(); - break ; - - case 462 : // System.out.println("InsideCastExpression ::="); //$NON-NLS-1$ - consumeInsideCastExpression(); - break ; - - case 463 : // System.out.println("InsideCastExpressionLL1 ::="); //$NON-NLS-1$ - consumeInsideCastExpressionLL1(); - break ; - - case 465 : // System.out.println("MultiplicativeExpression ::= MultiplicativeExpression MULTIPLY..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.MULTIPLY); - break ; - - case 466 : // System.out.println("MultiplicativeExpression ::= MultiplicativeExpression DIVIDE..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.DIVIDE); - break ; - - case 467 : // System.out.println("MultiplicativeExpression ::= MultiplicativeExpression REMAINDER..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.REMAINDER); - break ; - - case 469 : // System.out.println("AdditiveExpression ::= AdditiveExpression PLUS..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.PLUS); - break ; - - case 470 : // System.out.println("AdditiveExpression ::= AdditiveExpression MINUS..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.MINUS); - break ; - - case 472 : // System.out.println("ShiftExpression ::= ShiftExpression LEFT_SHIFT AdditiveExpression"); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.LEFT_SHIFT); - break ; - - case 473 : // System.out.println("ShiftExpression ::= ShiftExpression RIGHT_SHIFT AdditiveExpression"); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.RIGHT_SHIFT); - break ; - - case 474 : // System.out.println("ShiftExpression ::= ShiftExpression UNSIGNED_RIGHT_SHIFT..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.UNSIGNED_RIGHT_SHIFT); - break ; - - case 476 : // System.out.println("RelationalExpression ::= RelationalExpression LESS ShiftExpression"); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.LESS); - break ; - - case 477 : // System.out.println("RelationalExpression ::= RelationalExpression GREATER..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.GREATER); - break ; - - case 478 : // System.out.println("RelationalExpression ::= RelationalExpression LESS_EQUAL..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.LESS_EQUAL); - break ; - - case 479 : // System.out.println("RelationalExpression ::= RelationalExpression GREATER_EQUAL..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.GREATER_EQUAL); - break ; - - case 480 : // System.out.println("RelationalExpression ::= RelationalExpression instanceof..."); //$NON-NLS-1$ - consumeInstanceOfExpression(OperatorIds.INSTANCEOF); - break ; - - case 482 : // System.out.println("EqualityExpression ::= EqualityExpression EQUAL_EQUAL..."); //$NON-NLS-1$ - consumeEqualityExpression(OperatorIds.EQUAL_EQUAL); - break ; - - case 483 : // System.out.println("EqualityExpression ::= EqualityExpression NOT_EQUAL..."); //$NON-NLS-1$ - consumeEqualityExpression(OperatorIds.NOT_EQUAL); - break ; - - case 485 : // System.out.println("AndExpression ::= AndExpression AND EqualityExpression"); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.AND); - break ; - - case 487 : // System.out.println("ExclusiveOrExpression ::= ExclusiveOrExpression XOR AndExpression"); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.XOR); - break ; - - case 489 : // System.out.println("InclusiveOrExpression ::= InclusiveOrExpression OR..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.OR); - break ; - - case 491 : // System.out.println("ConditionalAndExpression ::= ConditionalAndExpression AND_AND..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.AND_AND); - break ; - - case 493 : // System.out.println("ConditionalOrExpression ::= ConditionalOrExpression OR_OR..."); //$NON-NLS-1$ - consumeBinaryExpression(OperatorIds.OR_OR); - break ; - - case 495 : // System.out.println("ConditionalExpression ::= ConditionalOrExpression QUESTION..."); //$NON-NLS-1$ - consumeConditionalExpression(OperatorIds.QUESTIONCOLON) ; - break ; - - case 498 : // System.out.println("Assignment ::= PostfixExpression AssignmentOperator..."); //$NON-NLS-1$ - consumeAssignment(); - break ; - - case 500 : // System.out.println("Assignment ::= InvalidArrayInitializerAssignement"); //$NON-NLS-1$ - ignoreExpressionAssignment(); - break ; - - case 501 : // System.out.println("AssignmentOperator ::= EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(EQUAL); - break ; - - case 502 : // System.out.println("AssignmentOperator ::= MULTIPLY_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(MULTIPLY); - break ; - - case 503 : // System.out.println("AssignmentOperator ::= DIVIDE_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(DIVIDE); - break ; - - case 504 : // System.out.println("AssignmentOperator ::= REMAINDER_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(REMAINDER); - break ; - - case 505 : // System.out.println("AssignmentOperator ::= PLUS_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(PLUS); - break ; - - case 506 : // System.out.println("AssignmentOperator ::= MINUS_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(MINUS); - break ; - - case 507 : // System.out.println("AssignmentOperator ::= LEFT_SHIFT_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(LEFT_SHIFT); - break ; - - case 508 : // System.out.println("AssignmentOperator ::= RIGHT_SHIFT_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(RIGHT_SHIFT); - break ; - - case 509 : // System.out.println("AssignmentOperator ::= UNSIGNED_RIGHT_SHIFT_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(UNSIGNED_RIGHT_SHIFT); - break ; - - case 510 : // System.out.println("AssignmentOperator ::= AND_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(AND); - break ; - - case 511 : // System.out.println("AssignmentOperator ::= XOR_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(XOR); - break ; - - case 512 : // System.out.println("AssignmentOperator ::= OR_EQUAL"); //$NON-NLS-1$ - consumeAssignmentOperator(OR); - break ; - - case 519 : // System.out.println("Expressionopt ::="); //$NON-NLS-1$ - consumeEmptyExpression(); - break ; - - case 523 : // System.out.println("ImportDeclarationsopt ::="); //$NON-NLS-1$ - consumeEmptyImportDeclarationsopt(); - break ; - - case 524 : // System.out.println("ImportDeclarationsopt ::= ImportDeclarations"); //$NON-NLS-1$ - consumeImportDeclarationsopt(); - break ; - - case 525 : // System.out.println("TypeDeclarationsopt ::="); //$NON-NLS-1$ - consumeEmptyTypeDeclarationsopt(); - break ; - - case 526 : // System.out.println("TypeDeclarationsopt ::= TypeDeclarations"); //$NON-NLS-1$ - consumeTypeDeclarationsopt(); - break ; - - case 527 : // System.out.println("ClassBodyDeclarationsopt ::="); //$NON-NLS-1$ - consumeEmptyClassBodyDeclarationsopt(); - break ; - - case 528 : // System.out.println("ClassBodyDeclarationsopt ::= NestedType ClassBodyDeclarations"); //$NON-NLS-1$ - consumeClassBodyDeclarationsopt(); - break ; - - case 529 : // System.out.println("Modifiersopt ::="); //$NON-NLS-1$ - consumeDefaultModifiers(); - break ; - - case 530 : // System.out.println("Modifiersopt ::= Modifiers"); //$NON-NLS-1$ - consumeModifiers(); - break ; - - case 531 : // System.out.println("BlockStatementsopt ::="); //$NON-NLS-1$ - consumeEmptyBlockStatementsopt(); - break ; - - case 533 : // System.out.println("Dimsopt ::="); //$NON-NLS-1$ - consumeEmptyDimsopt(); - break ; - - case 535 : // System.out.println("ArgumentListopt ::="); //$NON-NLS-1$ - consumeEmptyArgumentListopt(); - break ; - - case 539 : // System.out.println("FormalParameterListopt ::="); //$NON-NLS-1$ - consumeFormalParameterListopt(); - break ; - - case 543 : // System.out.println("InterfaceMemberDeclarationsopt ::="); //$NON-NLS-1$ - consumeEmptyInterfaceMemberDeclarationsopt(); - break ; - - case 544 : // System.out.println("InterfaceMemberDeclarationsopt ::= NestedType..."); //$NON-NLS-1$ - consumeInterfaceMemberDeclarationsopt(); - break ; - - case 545 : // System.out.println("NestedType ::="); //$NON-NLS-1$ - consumeNestedType(); - break ; - - case 546 : // System.out.println("ForInitopt ::="); //$NON-NLS-1$ - consumeEmptyForInitopt(); - break ; - - case 548 : // System.out.println("ForUpdateopt ::="); //$NON-NLS-1$ - consumeEmptyForUpdateopt(); - break ; - - case 552 : // System.out.println("Catchesopt ::="); //$NON-NLS-1$ - consumeEmptyCatchesopt(); - break ; - - } - } - - -protected void consumeSimpleAssertStatement() { - super.consumeSimpleAssertStatement(); -} - public AjParser( - ProblemReporter problemReporter, - boolean optimizeStringLiterals) { - super(problemReporter, optimizeStringLiterals); - } - - // don't try to recover if we're parsing AspectJ constructs - protected boolean shouldTryToRecover() { - int index = 0; - ASTNode node; - while (index < astStack.length && (node = astStack[index++]) != null) { - if (node instanceof AspectDeclaration || - node instanceof PointcutDeclaration || - node instanceof AdviceDeclaration) { - return false; - } - } - return true; - } - -} diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjScanner.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjScanner.java deleted file mode 100644 index ff4103c5b..000000000 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/AjScanner.java +++ /dev/null @@ -1,74 +0,0 @@ -/* ******************************************************************* - * Copyright (c) 2002 Palo Alto Research Center, Incorporated (PARC). - * All rights reserved. - * This program and the accompanying materials are made available - * under the terms of the Common Public License v1.0 - * which accompanies this distribution and is available at - * http://www.eclipse.org/legal/cpl-v10.html - * - * Contributors: - * PARC initial implementation - * ******************************************************************/ - - - -package org.aspectj.ajdt.internal.compiler.parser; - -import org.aspectj.ajdt.compiler.IAjTerminalSymbols; -import org.eclipse.jdt.core.compiler.CharOperation; -import org.eclipse.jdt.internal.compiler.parser.Scanner; -import org.eclipse.jdt.internal.compiler.parser.TerminalTokens; - - -public class AjScanner extends Scanner implements TerminalTokens { - public AjScanner( - boolean tokenizeComments, - boolean tokenizeWhiteSpace, - boolean checkNonExternalizedStringLiterals, - long sourceLevel, - char[][] taskTags, - char[][] taskPriorities) { - super( - tokenizeComments, - tokenizeWhiteSpace, - checkNonExternalizedStringLiterals, - sourceLevel, - taskTags, - taskPriorities); - } - - public AjScanner() { - super(); - } - - - - - private static final char[] aspectV = "aspect".toCharArray(); - private static final char[] pointcutV = "pointcut".toCharArray(); - private static final char[] privilegedV = "privileged".toCharArray(); - private static final char[] beforeV = "before".toCharArray(); - private static final char[] afterV = "after".toCharArray(); - private static final char[] aroundV = "around".toCharArray(); - private static final char[] declareV = "declare".toCharArray(); - - - - public int scanIdentifierOrKeyword() { - int kind = super.scanIdentifierOrKeyword(); - if (kind != IAjTerminalSymbols.TokenNameIdentifier) return kind; - - char[] contents = getCurrentIdentifierSource(); - - //XXX performance here is less than optimal, but code simplicity is pretty damn good - if (CharOperation.equals(aspectV, contents)) return IAjTerminalSymbols.TokenNameaspect; - else if (CharOperation.equals(pointcutV, contents)) return IAjTerminalSymbols.TokenNamepointcut; - else if (CharOperation.equals(privilegedV, contents)) return IAjTerminalSymbols.TokenNameprivileged; - else if (CharOperation.equals(beforeV, contents)) return IAjTerminalSymbols.TokenNamebefore; - else if (CharOperation.equals(afterV, contents)) return IAjTerminalSymbols.TokenNameafter; - else if (CharOperation.equals(aroundV, contents)) return IAjTerminalSymbols.TokenNamearound; - else if (CharOperation.equals(declareV, contents)) return IAjTerminalSymbols.TokenNamedeclare; - - return kind; - } -} diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/DeclarationFactory.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/DeclarationFactory.java new file mode 100644 index 000000000..4c79c9a5a --- /dev/null +++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/compiler/parser/DeclarationFactory.java @@ -0,0 +1,263 @@ +/******************************************************************************* + * Copyright (c) 2002,2003 Palo Alto Research Center, Incorporated (PARC). + * Copyright (c) 2004 IBM Corporation and others. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Common Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/cpl-v10.html + * + * Contributors: + * PARC initial implementation + * IBM Corporation + *******************************************************************************/ +package org.aspectj.ajdt.internal.compiler.parser; + +import org.aspectj.ajdt.internal.compiler.ast.AdviceDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.AspectDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.DeclareDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.IfPseudoToken; +import org.aspectj.ajdt.internal.compiler.ast.InterTypeConstructorDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.InterTypeDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.InterTypeFieldDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.InterTypeMethodDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.PointcutDeclaration; +import org.aspectj.ajdt.internal.compiler.ast.PointcutDesignator; +import org.aspectj.ajdt.internal.compiler.ast.Proceed; +import org.aspectj.ajdt.internal.compiler.ast.PseudoToken; +import org.aspectj.ajdt.internal.compiler.ast.PseudoTokens; +import org.aspectj.ajdt.internal.core.builder.EclipseSourceContext; +import org.aspectj.weaver.AdviceKind; +import org.aspectj.weaver.patterns.Declare; +import org.eclipse.jdt.internal.compiler.CompilationResult; +import org.eclipse.jdt.internal.compiler.ast.ASTNode; +import org.eclipse.jdt.internal.compiler.ast.Argument; +import org.eclipse.jdt.internal.compiler.ast.Expression; +import org.eclipse.jdt.internal.compiler.ast.MessageSend; +import org.eclipse.jdt.internal.compiler.ast.MethodDeclaration; +import org.eclipse.jdt.internal.compiler.ast.TypeDeclaration; +import org.eclipse.jdt.internal.compiler.ast.TypeReference; +import org.eclipse.jdt.internal.compiler.parser.Parser; +import org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory; + +/** + * @author colyer + * + * To change the template for this generated type comment go to + * Window>Preferences>Java>Code Generation>Code and Comments + */ +public class DeclarationFactory implements IDeclarationFactory { + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createProceed(org.eclipse.jdt.internal.compiler.ast.MessageSend) + */ + public MessageSend createProceed(MessageSend m) { + return new Proceed(m); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createAspect(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public TypeDeclaration createAspect(CompilationResult result) { + return new AspectDeclaration(result); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setPrivileged(org.eclipse.jdt.internal.compiler.ast.TypeDeclaration, boolean) + */ + public void setPrivileged(TypeDeclaration aspectDecl, boolean isPrivileged) { + ((AspectDeclaration)aspectDecl).isPrivileged = isPrivileged; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setPerClauseFrom(org.eclipse.jdt.internal.compiler.ast.TypeDeclaration, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public void setPerClauseFrom(TypeDeclaration aspectDecl, ASTNode pseudoTokens, Parser parser) { + AspectDeclaration aspect = (AspectDeclaration) aspectDecl; + PseudoTokens tok = (PseudoTokens) pseudoTokens; + aspect.perClause = tok.parsePerClause(parser); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setDominatesPatternFrom(org.eclipse.jdt.internal.compiler.ast.TypeDeclaration, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public void setDominatesPatternFrom(TypeDeclaration aspectDecl, ASTNode pseudoTokens, Parser parser) { + AspectDeclaration aspect = (AspectDeclaration) aspectDecl; + PseudoTokens tok = (PseudoTokens) pseudoTokens; + aspect.dominatesPattern = tok.maybeParseDominatesPattern(parser); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createPseudoTokensFrom(org.eclipse.jdt.internal.compiler.ast.ASTNode[], org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public ASTNode createPseudoTokensFrom(ASTNode[] tokens, CompilationResult result) { + PseudoToken[] psts = new PseudoToken[tokens.length]; + for (int i = 0; i < psts.length; i++) { + psts[i] = (PseudoToken)tokens[i]; + } + return new PseudoTokens(psts,new EclipseSourceContext(result)); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createPointcutDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createPointcutDeclaration(CompilationResult result) { + return new PointcutDeclaration(result); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createAroundAdviceDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createAroundAdviceDeclaration(CompilationResult result) { + return new AdviceDeclaration(result,AdviceKind.Around); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createAfterAdviceDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createAfterAdviceDeclaration(CompilationResult result) { + return new AdviceDeclaration(result,AdviceKind.After); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createBeforeAdviceDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createBeforeAdviceDeclaration(CompilationResult result) { + return new AdviceDeclaration(result,AdviceKind.Before); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createPointcutDesignator(org.eclipse.jdt.internal.compiler.parser.Parser, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public ASTNode createPointcutDesignator(Parser parser, ASTNode pseudoTokens) { + return new PointcutDesignator(parser,(PseudoTokens)pseudoTokens); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setPointcutDesignator(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public void setPointcutDesignatorOnAdvice(MethodDeclaration adviceDecl, ASTNode des) { + ((AdviceDeclaration)adviceDecl).pointcutDesignator = (PointcutDesignator)des; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setPointcutDesignator(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public void setPointcutDesignatorOnPointcut(MethodDeclaration pcutDecl, ASTNode des) { + ((PointcutDeclaration)pcutDecl).pointcutDesignator = (PointcutDesignator)des; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setExtraArgument(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, org.eclipse.jdt.internal.compiler.ast.Argument) + */ + public void setExtraArgument(MethodDeclaration adviceDeclaration, Argument arg) { + ((AdviceDeclaration)adviceDeclaration).extraArgument = arg; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#isAfterAdvice(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) + */ + public boolean isAfterAdvice(MethodDeclaration adviceDecl) { + return ((AdviceDeclaration)adviceDecl).kind != AdviceKind.After; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setAfterThrowingAdviceKind(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) + */ + public void setAfterThrowingAdviceKind(MethodDeclaration adviceDecl) { + ((AdviceDeclaration)adviceDecl).kind = AdviceKind.AfterThrowing; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setAfterReturningAdviceKind(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) + */ + public void setAfterReturningAdviceKind(MethodDeclaration adviceDecl) { + ((AdviceDeclaration)adviceDecl).kind = AdviceKind.AfterReturning; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createDeclareDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult, org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public MethodDeclaration createDeclareDeclaration(CompilationResult result, ASTNode pseudoTokens, Parser parser) { + Declare declare = ((PseudoTokens)pseudoTokens).parseDeclare(parser); + return new DeclareDeclaration(result,declare); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createInterTypeFieldDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult, org.eclipse.jdt.internal.compiler.ast.TypeReference) + */ + public MethodDeclaration createInterTypeFieldDeclaration(CompilationResult result, TypeReference onType) { + return new InterTypeFieldDeclaration(result,onType); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createInterTypeMethodDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createInterTypeMethodDeclaration(CompilationResult result) { + return new InterTypeMethodDeclaration(result,null); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createInterTypeConstructorDeclaration(org.eclipse.jdt.internal.compiler.CompilationResult) + */ + public MethodDeclaration createInterTypeConstructorDeclaration(CompilationResult result) { + return new InterTypeConstructorDeclaration(result,null); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setSelector(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, char[]) + */ + public void setSelector(MethodDeclaration interTypeDecl, char[] selector) { + ((InterTypeDeclaration)interTypeDecl).setSelector(selector); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setDeclaredModifiers(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, int) + */ + public void setDeclaredModifiers(MethodDeclaration interTypeDecl, int modifiers) { + ((InterTypeDeclaration)interTypeDecl).setDeclaredModifiers(modifiers); } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setInitialization(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, org.eclipse.jdt.internal.compiler.ast.Expression) + */ + public void setInitialization(MethodDeclaration itdFieldDecl, Expression initialization) { + ((InterTypeFieldDeclaration)itdFieldDecl).setInitialization(initialization); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setOnType(org.eclipse.jdt.internal.compiler.ast.MethodDeclaration, org.eclipse.jdt.internal.compiler.ast.TypeReference) + */ + public void setOnType(MethodDeclaration interTypeDecl, TypeReference onType) { + ((InterTypeDeclaration)interTypeDecl).onType = onType; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createPseudoToken(org.eclipse.jdt.internal.compiler.parser.Parser, java.lang.String, boolean) + */ + public ASTNode createPseudoToken(Parser parser, String value, boolean isIdentifier) { + return new PseudoToken(parser,value,isIdentifier); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#createIfPseudoToken(org.eclipse.jdt.internal.compiler.parser.Parser, org.eclipse.jdt.internal.compiler.ast.Expression) + */ + public ASTNode createIfPseudoToken(Parser parser, Expression expr) { + return new IfPseudoToken(parser,expr); + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#setLiteralKind(org.eclipse.jdt.internal.compiler.ast.ASTNode, java.lang.String) + */ + public void setLiteralKind(ASTNode pseudoToken, String string) { + ((PseudoToken)pseudoToken).literalKind = string; + } + + /* (non-Javadoc) + * @see org.eclipse.jdt.internal.compiler.parser.Parser.IDeclarationFactory#shouldTryToRecover(org.eclipse.jdt.internal.compiler.ast.ASTNode) + */ + public boolean shouldTryToRecover(ASTNode node) { + return !(node instanceof AspectDeclaration || + node instanceof PointcutDeclaration || + node instanceof AdviceDeclaration) ; + } + +} diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java index 89fc57071..d0a79ca3c 100644 --- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java +++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java @@ -19,7 +19,6 @@ import java.util.jar.*; import org.aspectj.ajdt.internal.compiler.AjCompiler; import org.aspectj.ajdt.internal.compiler.lookup.*; -import org.aspectj.ajdt.internal.compiler.parser.AjParser; import org.aspectj.ajdt.internal.compiler.problem.AjProblemReporter; import org.aspectj.asm.*; //import org.aspectj.asm.internal.*; @@ -33,6 +32,7 @@ import org.eclipse.jdt.internal.compiler.batch.*; import org.eclipse.jdt.internal.compiler.batch.FileSystem; import org.eclipse.jdt.internal.compiler.env.*; import org.eclipse.jdt.internal.compiler.impl.CompilerOptions; +import org.eclipse.jdt.internal.compiler.parser.Parser; import org.eclipse.jdt.internal.compiler.problem.DefaultProblemFactory; //import org.eclipse.jdt.internal.compiler.util.HashtableOfObject; @@ -373,7 +373,7 @@ public class AjBuildManager { compiler.lookupEnvironment = le; compiler.parser = - new AjParser( + new Parser( pr, compiler.options.parseLiteralExpressionsAsConstants); |