options {
  LOOKAHEAD = 1;
  CHOICE_AMBIGUITY_CHECK = 2;
  OTHER_AMBIGUITY_CHECK = 1;
  STATIC = true;
  DEBUG_PARSER = false;
  DEBUG_LOOKAHEAD = false;
  DEBUG_TOKEN_MANAGER = false;
  OPTIMIZE_TOKEN_MANAGER = false;
  ERROR_REPORTING = true;
  JAVA_UNICODE_ESCAPE = false;
  UNICODE_INPUT = false;
  IGNORE_CASE = true;
  USER_TOKEN_MANAGER = false;
  USER_CHAR_STREAM = false;
  BUILD_PARSER = true;
  BUILD_TOKEN_MANAGER = true;
  SANITY_CHECK = true;
  FORCE_LA_CHECK = false;
}
PARSER_BEGIN(PHPParser)
package test;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IMarker;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.ui.texteditor.MarkerUtilities;
import org.eclipse.jface.preference.IPreferenceStore;
import java.util.Hashtable;
import java.io.StringReader;
import java.text.MessageFormat;
import net.sourceforge.phpeclipse.actions.PHPStartApacheAction;
import net.sourceforge.phpeclipse.PHPeclipsePlugin;
import net.sourceforge.phpdt.internal.compiler.parser.PHPOutlineInfo;
import net.sourceforge.phpdt.internal.compiler.parser.PHPSegmentWithChildren;
import net.sourceforge.phpdt.internal.compiler.parser.PHPFunctionDeclaration;
import net.sourceforge.phpdt.internal.compiler.parser.PHPClassDeclaration;
import net.sourceforge.phpdt.internal.compiler.parser.PHPVarDeclaration;
import net.sourceforge.phpdt.internal.compiler.parser.PHPReqIncDeclaration;
/**
 * A new php parser.
 * This php parser is inspired by the Java 1.2 grammar example 
 * given with JavaCC. You can get JavaCC at http://www.webgain.com
 * You can test the parser with the PHPParserTestCase2.java
 * @author Matthieu Casanova
 */
public final class PHPParser extends PHPParserSuperclass {
  private static IFile fileToParse;
  /** The current segment */
  private static PHPSegmentWithChildren currentSegment;
  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;
  private static int errorLevel = ERROR;
  private static String errorMessage;
  public PHPParser() {
  }
  public final void setFileToParse(IFile fileToParse) {
    this.fileToParse = fileToParse;
  }
  public PHPParser(IFile fileToParse) {
    this(new StringReader(""));
    this.fileToParse = fileToParse;
  }
  public static final void phpParserTester(String strEval) throws CoreException, ParseException {
    PHPParserTokenManager.SwitchTo(PHPParserTokenManager.PHPPARSING);
    StringReader stream = new StringReader(strEval);
    if (jj_input_stream == null) {
      jj_input_stream = new SimpleCharStream(stream, 1, 1);
    }
    ReInit(new StringReader(strEval));
    phpTest();
  }
  public static final void htmlParserTester(String strEval) throws CoreException, ParseException {
    StringReader stream = new StringReader(strEval);
    if (jj_input_stream == null) {
      jj_input_stream = new SimpleCharStream(stream, 1, 1);
    }
    ReInit(stream);
    phpFile();
  }
  public final PHPOutlineInfo parseInfo(Object parent, String s) {
    outlineInfo = new PHPOutlineInfo(parent);
    currentSegment = outlineInfo.getDeclarations();
    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) {
      processParseException(e);
    }
    return outlineInfo;
  }
  /**
   * This method will process the parse exception.
   * If the error message is null, the parse exception wasn't catched and a trace is written in the log
   * @param e the ParseException
   */
  private static void processParseException(final ParseException e) {
    if (errorMessage == null) {
      PHPeclipsePlugin.log(e);
      errorMessage = "this exception wasn't handled by the parser please tell us how to reproduce it";
    }
    setMarker(e);
    errorMessage = null;
  }
  /**
   * Create marker for the parse error
   */
  private static void setMarker(ParseException e) {
    try {
      setMarker(fileToParse,
                errorMessage,
                jj_input_stream.tokenBegin,
                jj_input_stream.tokenBegin + e.currentToken.image.length(),
                errorLevel,
                "Line " + e.currentToken.beginLine);
    } catch (CoreException e2) {
      PHPeclipsePlugin.log(e2);
    }
  }
  /**
   * Create markers according to the external parser output
   */
  private static void createMarkers(String output, IFile file) throws CoreException {
    // delete all markers
    file.deleteMarkers(IMarker.PROBLEM, false, 0);
    int indx = 0;
    int brIndx = 0;
    boolean flag = true;
    while ((brIndx = output.indexOf("
", indx)) != -1) {
      // newer php error output (tested with 4.2.3)
      scanLine(output, file, indx, brIndx);
      indx = brIndx + 6;
      flag = false;
    }
    if (flag) {
      while ((brIndx = output.indexOf("
", indx)) != -1) {
        // older php error output (tested with 4.2.3)
        scanLine(output, file, indx, brIndx);
        indx = brIndx + 4;
      }
    }
  }
  private static void scanLine(String output, IFile file, int indx, int brIndx) throws CoreException {
    String current;
    StringBuffer lineNumberBuffer = new StringBuffer(10);
    char ch;
    current = output.substring(indx, brIndx);
    if (current.indexOf(PARSE_WARNING_STRING) != -1 || current.indexOf(PARSE_ERROR_STRING) != -1) {
      int onLine = current.indexOf("on line ");
      if (onLine != -1) {
        lineNumberBuffer.delete(0, lineNumberBuffer.length());
        for (int i = onLine; i < current.length(); i++) {
          ch = current.charAt(i);
          if ('0' <= ch && '9' >= ch) {
            lineNumberBuffer.append(ch);
          }
        }
        int lineNumber = Integer.parseInt(lineNumberBuffer.toString());
        Hashtable attributes = new Hashtable();
        current = current.replaceAll("\n", "");
        current = current.replaceAll("", "");
        current = current.replaceAll("", "");
        MarkerUtilities.setMessage(attributes, current);
        if (current.indexOf(PARSE_ERROR_STRING) != -1)
          attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_ERROR));
        else if (current.indexOf(PARSE_WARNING_STRING) != -1)
          attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_WARNING));
        else
          attributes.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_INFO));
        MarkerUtilities.setLineNumber(attributes, lineNumber);
        MarkerUtilities.createMarker(file, attributes, IMarker.PROBLEM);
      }
    }
  }
  public final void parse(String s) throws CoreException {
    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) {
      processParseException(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();
    String[] arguments = { filename };
    MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_PARSER_PREF));
    String command = form.format(arguments);
    String parserResult = PHPStartApacheAction.getParserOutput(command, "External parser: ");
    try {
      // parse the buffer to find the errors and warnings
      createMarkers(parserResult, file);
    } catch (CoreException e) {
      PHPeclipsePlugin.log(e);
    }
  }
  public static final void parse() throws ParseException {
	  phpFile();
  }
}
PARSER_END(PHPParser)
 TOKEN :
{
   : PHPPARSING
}
 TOKEN :
{
  "> : DEFAULT
}
 SKIP :
{
 < ~[] >
}
/* WHITE SPACE */
 SKIP :
{
  " "
| "\t"
| "\n"
| "\r"
| "\f"
}
/* COMMENTS */
 MORE :
{
  "//" : IN_SINGLE_LINE_COMMENT
|
  <"/**" ~["/"]> { input_stream.backup(1); } : IN_FORMAL_COMMENT
|
  "/*" : IN_MULTI_LINE_COMMENT
}
 SPECIAL_TOKEN :
{
   : PHPPARSING
}
 TOKEN :
{
  " > : DEFAULT
}
SPECIAL_TOKEN :
{
   : PHPPARSING
}
SPECIAL_TOKEN :
{
   : PHPPARSING
}
MORE :
{
  < ~[] >
}
/* KEYWORDS */
 TOKEN :
{
  
| 
| 
| 
| 
| 
| 
}
/* LANGUAGE CONSTRUCT */
 TOKEN :
{
  
| 
| 
| 
| 
| 
| 
| 
| ">
| 
| ">
}
/* RESERVED WORDS AND LITERALS */
 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" >
| 
| 
| 
| 
}
/* TYPES */
 TOKEN :
{
  
|