/* Generated By:JavaCC: Do not edit this line. TheParser.java */
package edu.neu.ccs.demeterf.demfgen.classes;

import edu.neu.ccs.demeterf.lib.*;
import edu.neu.ccs.demeterf.lib.*;
import edu.neu.ccs.demeterf.demfgen.*;
import edu.neu.ccs.demeterf.demfgen.dgp.DGPFunc;
import edu.neu.ccs.demeterf.demfgen.traversals.Travs;
import edu.neu.ccs.demeterf.demfgen.pcdgp.PCDGPFunc;
import edu.neu.ccs.demeterf.dispatch.*;
import edu.neu.ccs.demeterf.*;
import edu.neu.ccs.demeterf.demfgen.ClassHier.InhrtPair;
import edu.neu.ccs.demeterf.demfgen.DemFGenMain;
import java.io.*;
import java.io.FileInputStream;
import edu.neu.ccs.demeterf.util.Util;
import edu.neu.ccs.demeterf.util.CLI;
import edu.neu.ccs.demeterf.Fields;
import edu.neu.ccs.demeterf.lib.ident;
import edu.neu.ccs.demeterf.lib.verbatim;

  public class TheParser implements TheParserConstants {

   public static String unescape(String str){
      String retval = "";
      int index = 0;
      char ch, ch1;
      int ordinal = 0;
      while (index < str.length()) {
         if(str.charAt(index) != '\u005c\u005c') { retval += str.charAt(index++); continue; }
         ch = str.charAt(++index);
         if(ch == 'b') { retval += '\u005cb'; index++; continue; }
         if(ch == 't') { retval += '\u005ct'; index++; continue; }
         if(ch == 'n') { retval += '\u005cn'; index++; continue; }
         if(ch == 'f') { retval += '\u005cf'; index++; continue; }
         if(ch == 'r') { retval += '\u005cr'; index++; continue; }
         if(ch == '"') { retval += '\u005c"'; index++; continue; }
         if(ch == '\u005c'') { retval += '\u005c''; index++; continue; }
         if(ch == '\u005c\u005c') { retval += '\u005c\u005c'; index++; continue; }
         if(ch >= '0' && ch <= '7'){
            ordinal = ((int)ch) - ((int)'0'); index++;
            ch1 = str.charAt(index);
            if(ch1 >= '0' && ch1 <= '7'){
               ordinal = ordinal*8 + ((int)ch1) - ((int)'0'); index++;
               ch1 = str.charAt(index);
               if(ch <= '3' && ch1 >= '0' && ch1 <= '7'){
                  ordinal = ordinal*8 + ((int)ch1) - ((int)'0'); index++;
               }
            }
            retval += (char)ordinal;
            continue;
         }
         if(ch == 'u'){
            ordinal = 0;
            for(int i = 0; i < 4; i++){
               index++; ch = str.charAt(index);
               ordinal = ordinal*16+hexval(ch);
            }
            index++;
            retval += (char)ordinal;
            continue;
         }
      }
      return retval;
   }
   static int hexval(char c){
      int r = "0123456789ABCDEF".indexOf(Character.toUpperCase(c));
      if(r >= 0)return r;
      throw new RuntimeException(" ** Bad Escaped Character");
   }

  final public byte parse_byte() throws ParseException {
                    int i;
    i = parse_int();
                      {if (true) return (byte)i;}
    throw new Error("Missing return statement in function");
  }

  final public Byte parse_Byte() throws ParseException {
                    byte b;
    b = parse_byte();
                       {if (true) return b;}
    throw new Error("Missing return statement in function");
  }

  final public short parse_short() throws ParseException {
                      int i;
    i = parse_int();
                      {if (true) return (short)i;}
    throw new Error("Missing return statement in function");
  }

  final public Short parse_Short() throws ParseException {
                      short s;
    s = parse_short();
                        {if (true) return s;}
    throw new Error("Missing return statement in function");
  }

  final public int parse_int() throws ParseException {
                  Token t;
    t = jj_consume_token(INT);
      if(t.image.length() > 1 && Character.toLowerCase(t.image.charAt(1)) == 'x')
          {if (true) return Integer.parseInt(t.image.substring(2), 16);}
      {if (true) return Integer.parseInt(t.image);}
    throw new Error("Missing return statement in function");
  }

  final public Integer parse_Integer() throws ParseException {
                          int i;
    i = parse_int();
                      {if (true) return i;}
    throw new Error("Missing return statement in function");
  }

  final public long parse_long() throws ParseException {
                    Token t;
    t = jj_consume_token(INT);
      if(t.image.length() > 1 && Character.toLowerCase(t.image.charAt(1)) == 'x')
          {if (true) return Long.parseLong(t.image.substring(2), 16);}
    {if (true) return Long.parseLong(t.image);}
    throw new Error("Missing return statement in function");
  }

  final public Long parse_Long() throws ParseException {
                    long l;
    l = parse_long();
                       {if (true) return l;}
    throw new Error("Missing return statement in function");
  }

  final public double parse_double() throws ParseException {
                        Token t;
    t = jj_consume_token(DOUBLE);
      {if (true) return Double.parseDouble(t.image);}
    throw new Error("Missing return statement in function");
  }

  final public Double parse_Double() throws ParseException {
                        double d;
    d = parse_double();
                         {if (true) return d;}
    throw new Error("Missing return statement in function");
  }

  final public float parse_float() throws ParseException {
                      Token t;
    t = jj_consume_token(DOUBLE);
      {if (true) return Float.parseFloat(t.image);}
    throw new Error("Missing return statement in function");
  }

  final public Float parse_Float() throws ParseException {
                      float f;
    f = parse_float();
                        {if (true) return f;}
    throw new Error("Missing return statement in function");
  }

  final public String parse_String() throws ParseException {
                        Token t;
    t = jj_consume_token(STRING);
      {if (true) return unescape(t.image.substring(1,t.image.length()-1));}
    throw new Error("Missing return statement in function");
  }

  final public boolean parse_boolean() throws ParseException {
                          Token t;
    if (jj_2_1(3)) {
      t = jj_consume_token(TRUE);
                 {if (true) return true;}
    } else if (jj_2_2(3)) {
      t = jj_consume_token(FALSE);
                  {if (true) return false;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public Boolean parse_Boolean() throws ParseException {
                          boolean b;
    b = parse_boolean();
                          {if (true) return b;}
    throw new Error("Missing return statement in function");
  }

  final public char parse_char() throws ParseException {
                    Token t;
    t = jj_consume_token(CHAR);
      {if (true) return unescape(t.image.substring(1,t.image.length()-1)).charAt(0);}
    throw new Error("Missing return statement in function");
  }

  final public Character parse_Character() throws ParseException {
                              char c;
    c = parse_char();
                       {if (true) return c;}
    throw new Error("Missing return statement in function");
  }

  final public ident parse_ident() throws ParseException {
                      Token t;
    t = jj_consume_token(IDENT);
      {if (true) return new ident(t.image);}
    throw new Error("Missing return statement in function");
  }

  final public verbatim parse_verbatim() throws ParseException {
                            Token t;
    t = jj_consume_token(TEXT);
      {if (true) return new verbatim(t.image.substring(2,t.image.length()-2));}
    throw new Error("Missing return statement in function");
  }

  final public CDFile parse_CDFile() throws ParseException {
     IncludeList incl;
     DGPUses dgpuse;
     PackageDef pkg;
     LookDef look;
     ImportList imports;
     TypeDefList types;
    incl = parse_IncludeList();
    dgpuse = parse_DGPUses();
    pkg = parse_PackageDef();
    look = parse_LookDef();
    imports = parse_ImportList();
    types = parse_TypeDefList();
    jj_consume_token(0);
      {if (true) return new CDFile(incl,dgpuse,pkg,look,imports,types);}
    throw new Error("Missing return statement in function");
  }

  final public Include parse_Include() throws ParseException {
     DoGen gen;
     String file;
    gen = parse_DoGen();
    jj_consume_token(1);
    file = parse_String();
    jj_consume_token(2);
      {if (true) return new Include(gen,file);}
    throw new Error("Missing return statement in function");
  }

  final public IncludeList parse_IncludeList() throws ParseException {
    IncludeList sup = null;
    if (jj_2_3(3)) {
      sup = parse_IncludeCons();
                                {if (true) return sup;}
    } else {
      sup = parse_IncludeEmpty();
                                 {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public IncludeCons parse_IncludeCons() throws ParseException {
     Include first;
     IncludeList rest;
    first = parse_Include();
    rest = parse_IncludeList();
      {if (true) return new IncludeCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public IncludeEmpty parse_IncludeEmpty() throws ParseException {
      {if (true) return new IncludeEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public DGPUses parse_DGPUses() throws ParseException {
    DGPUses sup = null;
    if (jj_2_4(3)) {
      sup = parse_DGPUse();
                           {if (true) return sup;}
    } else {
      sup = parse_NoDGPUse();
                             {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public DGPUse parse_DGPUse() throws ParseException {
     NENameList pkg;
    jj_consume_token(3);
    pkg = parse_NENameList();
    jj_consume_token(2);
      {if (true) return new DGPUse(pkg);}
    throw new Error("Missing return statement in function");
  }

  final public NoDGPUse parse_NoDGPUse() throws ParseException {
      {if (true) return new NoDGPUse();}
    throw new Error("Missing return statement in function");
  }

  final public PackageDef parse_PackageDef() throws ParseException {
    PackageDef sup = null;
    if (jj_2_5(3)) {
      sup = parse_Package();
                            {if (true) return sup;}
    } else {
      sup = parse_NoPackage();
                              {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public Package parse_Package() throws ParseException {
     NEPkgList pkg;
    jj_consume_token(4);
    pkg = parse_NEPkgList();
    jj_consume_token(2);
      {if (true) return new Package(pkg);}
    throw new Error("Missing return statement in function");
  }

  final public NoPackage parse_NoPackage() throws ParseException {
      {if (true) return new NoPackage();}
    throw new Error("Missing return statement in function");
  }

  final public LookDef parse_LookDef() throws ParseException {
    LookDef sup = null;
    if (jj_2_6(3)) {
      sup = parse_LookAhead();
                              {if (true) return sup;}
    } else {
      sup = parse_NoLook();
                           {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public LookAhead parse_LookAhead() throws ParseException {
     int n;
    jj_consume_token(5);
    jj_consume_token(6);
    n = parse_int();
    jj_consume_token(2);
      {if (true) return new LookAhead(n);}
    throw new Error("Missing return statement in function");
  }

  final public NoLook parse_NoLook() throws ParseException {
      {if (true) return new NoLook();}
    throw new Error("Missing return statement in function");
  }

  final public Import parse_Import() throws ParseException {
     NEPkgList pkg;
    jj_consume_token(7);
    pkg = parse_NEPkgList();
    jj_consume_token(2);
      {if (true) return new Import(pkg);}
    throw new Error("Missing return statement in function");
  }

  final public PkgList parse_PkgList() throws ParseException {
    PkgList sup = null;
    if (jj_2_7(3)) {
      sup = parse_PkgCons();
                            {if (true) return sup;}
    } else if (jj_2_8(3)) {
      sup = parse_PkgStar();
                            {if (true) return sup;}
    } else {
      sup = parse_PkgEmpty();
                             {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NEPkgList parse_NEPkgList() throws ParseException {
     ident id;
     PkgList rest;
    id = parse_ident();
    rest = parse_PkgList();
      {if (true) return new NEPkgList(id,rest);}
    throw new Error("Missing return statement in function");
  }

  final public PkgCons parse_PkgCons() throws ParseException {
     ident id;
     PkgList rest;
    jj_consume_token(8);
    id = parse_ident();
    rest = parse_PkgList();
      {if (true) return new PkgCons(id,rest);}
    throw new Error("Missing return statement in function");
  }

  final public PkgStar parse_PkgStar() throws ParseException {
    jj_consume_token(9);
      {if (true) return new PkgStar();}
    throw new Error("Missing return statement in function");
  }

  final public PkgEmpty parse_PkgEmpty() throws ParseException {
      {if (true) return new PkgEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public ImportList parse_ImportList() throws ParseException {
    ImportList sup = null;
    if (jj_2_9(3)) {
      sup = parse_ImportCons();
                               {if (true) return sup;}
    } else {
      sup = parse_ImportEmpty();
                                {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public ImportCons parse_ImportCons() throws ParseException {
     Import first;
     ImportList rest;
    first = parse_Import();
    rest = parse_ImportList();
      {if (true) return new ImportCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public ImportEmpty parse_ImportEmpty() throws ParseException {
      {if (true) return new ImportEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public TypeDef parse_TypeDef() throws ParseException {
    TypeDef sup = null;
    if (jj_2_10(3)) {
      sup = parse_IntfcDef();
                             {if (true) return sup;}
    } else if (jj_2_11(3)) {
      sup = parse_ClassDef();
                             {if (true) return sup;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public IntfcDef parse_IntfcDef() throws ParseException {
     DoGen gen;
     ident name;
     TypeDefParams tparams;
     PESubtypeList subtypes;
    gen = parse_DoGen();
    jj_consume_token(10);
    name = parse_ident();
    tparams = parse_TypeDefParams();
    jj_consume_token(6);
    subtypes = parse_PESubtypeList();
    jj_consume_token(8);
      {if (true) return new IntfcDef(gen,name,tparams,subtypes);}
    throw new Error("Missing return statement in function");
  }

  final public ClassDef parse_ClassDef() throws ParseException {
     DoGen gen;
     ident name;
     TypeDefParams tparams;
     PESubtypeList subtypes;
     FieldList fields;
     Impl ext;
    gen = parse_DoGen();
    name = parse_ident();
    tparams = parse_TypeDefParams();
    jj_consume_token(6);
    subtypes = parse_PESubtypeList();
    fields = parse_FieldList();
    ext = parse_Impl();
    jj_consume_token(8);
      {if (true) return new ClassDef(gen,name,tparams,subtypes,fields,ext);}
    throw new Error("Missing return statement in function");
  }

  final public DoGen parse_DoGen() throws ParseException {
    DoGen sup = null;
    if (jj_2_12(3)) {
      sup = parse_NoParse();
                            {if (true) return sup;}
    } else if (jj_2_13(3)) {
      sup = parse_NoGen();
                          {if (true) return sup;}
    } else if (jj_2_14(3)) {
      sup = parse_Extern();
                           {if (true) return sup;}
    } else {
      sup = parse_YesGen();
                           {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NoGen parse_NoGen() throws ParseException {
    jj_consume_token(11);
      {if (true) return new NoGen();}
    throw new Error("Missing return statement in function");
  }

  final public NoParse parse_NoParse() throws ParseException {
    jj_consume_token(12);
      {if (true) return new NoParse();}
    throw new Error("Missing return statement in function");
  }

  final public Extern parse_Extern() throws ParseException {
    jj_consume_token(13);
      {if (true) return new Extern();}
    throw new Error("Missing return statement in function");
  }

  final public YesGen parse_YesGen() throws ParseException {
      {if (true) return new YesGen();}
    throw new Error("Missing return statement in function");
  }

  final public TypeDefParams parse_TypeDefParams() throws ParseException {
    TypeDefParams sup = null;
    if (jj_2_15(3)) {
      sup = parse_DefParams();
                              {if (true) return sup;}
    } else {
      sup = parse_EmptyDefParams();
                                   {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public DefParams parse_DefParams() throws ParseException {
     NENameList types;
    jj_consume_token(14);
    types = parse_NENameList();
    jj_consume_token(15);
      {if (true) return new DefParams(types);}
    throw new Error("Missing return statement in function");
  }

  final public EmptyDefParams parse_EmptyDefParams() throws ParseException {
      {if (true) return new EmptyDefParams();}
    throw new Error("Missing return statement in function");
  }

  final public NameDef parse_NameDef() throws ParseException {
     ident id;
     Bound bnd;
    id = parse_ident();
    bnd = parse_Bound();
      {if (true) return new NameDef(id,bnd);}
    throw new Error("Missing return statement in function");
  }

  final public Bound parse_Bound() throws ParseException {
    Bound sup = null;
    if (jj_2_16(3)) {
      sup = parse_ClassBound();
                               {if (true) return sup;}
    } else {
      sup = parse_NoBound();
                            {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public ClassBound parse_ClassBound() throws ParseException {
     TypeUse bound;
    jj_consume_token(16);
    bound = parse_TypeUse();
      {if (true) return new ClassBound(bound);}
    throw new Error("Missing return statement in function");
  }

  final public NoBound parse_NoBound() throws ParseException {
      {if (true) return new NoBound();}
    throw new Error("Missing return statement in function");
  }

  final public Impl parse_Impl() throws ParseException {
    Impl sup = null;
    if (jj_2_17(3)) {
      sup = parse_IntfImpl();
                             {if (true) return sup;}
    } else {
      sup = parse_NoImpl();
                           {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NoImpl parse_NoImpl() throws ParseException {
      {if (true) return new NoImpl();}
    throw new Error("Missing return statement in function");
  }

  final public IntfImpl parse_IntfImpl() throws ParseException {
     NETypeUseList intf;
    jj_consume_token(17);
    intf = parse_NETypeUseList();
      {if (true) return new IntfImpl(intf);}
    throw new Error("Missing return statement in function");
  }

  final public NameList parse_NameList() throws ParseException {
    NameList sup = null;
    if (jj_2_18(3)) {
      sup = parse_NameCons();
                             {if (true) return sup;}
    } else {
      sup = parse_NameEmpty();
                              {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NENameList parse_NENameList() throws ParseException {
     NameDef first;
     NameList rest;
    first = parse_NameDef();
    rest = parse_NameList();
      {if (true) return new NENameList(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public NameCons parse_NameCons() throws ParseException {
     NameDef first;
     NameList rest;
    jj_consume_token(18);
    first = parse_NameDef();
    rest = parse_NameList();
      {if (true) return new NameCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public NameEmpty parse_NameEmpty() throws ParseException {
      {if (true) return new NameEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public TypeUse parse_TypeUse() throws ParseException {
     ident name;
     TypeUseParams tparams;
    name = parse_ident();
    tparams = parse_TypeUseParams();
      {if (true) return new TypeUse(name,tparams);}
    throw new Error("Missing return statement in function");
  }

  final public TypeUseParams parse_TypeUseParams() throws ParseException {
    TypeUseParams sup = null;
    if (jj_2_19(3)) {
      sup = parse_UseParams();
                              {if (true) return sup;}
    } else {
      sup = parse_EmptyUseParams();
                                   {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public UseParams parse_UseParams() throws ParseException {
     NETypeUseList types;
    jj_consume_token(14);
    types = parse_NETypeUseList();
    jj_consume_token(15);
      {if (true) return new UseParams(types);}
    throw new Error("Missing return statement in function");
  }

  final public EmptyUseParams parse_EmptyUseParams() throws ParseException {
      {if (true) return new EmptyUseParams();}
    throw new Error("Missing return statement in function");
  }

  final public TypeUseList parse_TypeUseList() throws ParseException {
    TypeUseList sup = null;
    if (jj_2_20(3)) {
      sup = parse_TypeUseCons();
                                {if (true) return sup;}
    } else {
      sup = parse_TypeUseEmpty();
                                 {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NETypeUseList parse_NETypeUseList() throws ParseException {
     TypeUse first;
     TypeUseList rest;
    first = parse_TypeUse();
    rest = parse_TypeUseList();
      {if (true) return new NETypeUseList(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public TypeUseCons parse_TypeUseCons() throws ParseException {
     TypeUse first;
     TypeUseList rest;
    jj_consume_token(18);
    first = parse_TypeUse();
    rest = parse_TypeUseList();
      {if (true) return new TypeUseCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public TypeUseEmpty parse_TypeUseEmpty() throws ParseException {
      {if (true) return new TypeUseEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public Field parse_Field() throws ParseException {
     ident name;
     TypeUse type;
    jj_consume_token(19);
    name = parse_ident();
    jj_consume_token(20);
    type = parse_TypeUse();
      {if (true) return new Field(name,type);}
    throw new Error("Missing return statement in function");
  }

  final public FieldOrSyntax parse_FieldOrSyntax() throws ParseException {
    FieldOrSyntax sup = null;
    if (jj_2_21(3)) {
      sup = parse_Field();
                          {if (true) return sup;}
    } else if (jj_2_22(3)) {
      sup = parse_Syntax();
                           {if (true) return sup;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public Syntax parse_Syntax() throws ParseException {
    Syntax sup = null;
    if (jj_2_23(3)) {
      sup = parse_AddSpace();
                             {if (true) return sup;}
    } else if (jj_2_24(3)) {
      sup = parse_AddTab();
                           {if (true) return sup;}
    } else if (jj_2_25(3)) {
      sup = parse_AddLine();
                            {if (true) return sup;}
    } else if (jj_2_26(3)) {
      sup = parse_AddReturn();
                              {if (true) return sup;}
    } else if (jj_2_27(3)) {
      sup = parse_Plus();
                         {if (true) return sup;}
    } else if (jj_2_28(3)) {
      sup = parse_Minus();
                          {if (true) return sup;}
    } else if (jj_2_29(3)) {
      sup = parse_AddToken();
                             {if (true) return sup;}
    } else if (jj_2_30(3)) {
      sup = parse_TheEOF();
                           {if (true) return sup;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public AddSpace parse_AddSpace() throws ParseException {
    jj_consume_token(21);
      {if (true) return new AddSpace();}
    throw new Error("Missing return statement in function");
  }

  final public AddTab parse_AddTab() throws ParseException {
    jj_consume_token(22);
      {if (true) return new AddTab();}
    throw new Error("Missing return statement in function");
  }

  final public AddLine parse_AddLine() throws ParseException {
    jj_consume_token(23);
      {if (true) return new AddLine();}
    throw new Error("Missing return statement in function");
  }

  final public AddReturn parse_AddReturn() throws ParseException {
    jj_consume_token(24);
      {if (true) return new AddReturn();}
    throw new Error("Missing return statement in function");
  }

  final public Plus parse_Plus() throws ParseException {
    jj_consume_token(25);
      {if (true) return new Plus();}
    throw new Error("Missing return statement in function");
  }

  final public Minus parse_Minus() throws ParseException {
    jj_consume_token(26);
      {if (true) return new Minus();}
    throw new Error("Missing return statement in function");
  }

  final public AddToken parse_AddToken() throws ParseException {
     String str;
    str = parse_String();
      {if (true) return new AddToken(str);}
    throw new Error("Missing return statement in function");
  }

  final public TheEOF parse_TheEOF() throws ParseException {
    jj_consume_token(27);
      {if (true) return new TheEOF();}
    throw new Error("Missing return statement in function");
  }

  final public SumToken parse_SumToken() throws ParseException {
    SumToken sup = null;
    if (jj_2_31(3)) {
      sup = parse_RealToken();
                              {if (true) return sup;}
    } else {
      sup = parse_EmptyToken();
                               {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public RealToken parse_RealToken() throws ParseException {
     String str;
    str = parse_String();
      {if (true) return new RealToken(str);}
    throw new Error("Missing return statement in function");
  }

  final public EmptyToken parse_EmptyToken() throws ParseException {
      {if (true) return new EmptyToken();}
    throw new Error("Missing return statement in function");
  }

  final public TypeDefList parse_TypeDefList() throws ParseException {
    TypeDefList sup = null;
    if (jj_2_32(3)) {
      sup = parse_TypeDefCons();
                                {if (true) return sup;}
    } else {
      sup = parse_TypeDefEmpty();
                                 {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public TypeDefCons parse_TypeDefCons() throws ParseException {
     TypeDef first;
     TypeDefList rest;
    first = parse_TypeDef();
    rest = parse_TypeDefList();
      {if (true) return new TypeDefCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public TypeDefEmpty parse_TypeDefEmpty() throws ParseException {
      {if (true) return new TypeDefEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public FieldList parse_FieldList() throws ParseException {
    FieldList sup = null;
    if (jj_2_33(3)) {
      sup = parse_FieldCons();
                              {if (true) return sup;}
    } else {
      sup = parse_FieldEmpty();
                               {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public FieldCons parse_FieldCons() throws ParseException {
     FieldOrSyntax first;
     FieldList rest;
    first = parse_FieldOrSyntax();
    rest = parse_FieldList();
      {if (true) return new FieldCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public FieldEmpty parse_FieldEmpty() throws ParseException {
      {if (true) return new FieldEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public PESubtypeList parse_PESubtypeList() throws ParseException {
    PESubtypeList sup = null;
    if (jj_2_34(3)) {
      sup = parse_NESubtypeList();
                                  {if (true) return sup;}
    } else {
      sup = parse_SubtypeEmpty();
                                 {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public NESubtypeList parse_NESubtypeList() throws ParseException {
     TypeUse first;
     SubtypeList rest;
    first = parse_TypeUse();
    rest = parse_SubtypeList();
      {if (true) return new NESubtypeList(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public SubtypeList parse_SubtypeList() throws ParseException {
    SubtypeList sup = null;
    if (jj_2_35(3)) {
      sup = parse_SubtypeCons();
                                {if (true) return sup;}
    } else {
      sup = parse_SubtypeEmpty();
                                 {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public SubtypeCons parse_SubtypeCons() throws ParseException {
     TypeUse first;
     SubtypeList rest;
    jj_consume_token(28);
    first = parse_TypeUse();
    rest = parse_SubtypeList();
      {if (true) return new SubtypeCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public SubtypeEmpty parse_SubtypeEmpty() throws ParseException {
      {if (true) return new SubtypeEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public BehFile parse_BehFile() throws ParseException {
     IncludeList incl;
     BehDefList behs;
    incl = parse_IncludeList();
    behs = parse_BehDefList();
    jj_consume_token(0);
      {if (true) return new BehFile(incl,behs);}
    throw new Error("Missing return statement in function");
  }

  final public BehDefList parse_BehDefList() throws ParseException {
    BehDefList sup = null;
    if (jj_2_36(3)) {
      sup = parse_BehDefCons();
                               {if (true) return sup;}
    } else {
      sup = parse_BehDefEmpty();
                                {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public BehDefCons parse_BehDefCons() throws ParseException {
     BehDef first;
     BehDefList rest;
    first = parse_BehDef();
    rest = parse_BehDefList();
      {if (true) return new BehDefCons(first,rest);}
    throw new Error("Missing return statement in function");
  }

  final public BehDefEmpty parse_BehDefEmpty() throws ParseException {
      {if (true) return new BehDefEmpty();}
    throw new Error("Missing return statement in function");
  }

  final public BehDef parse_BehDef() throws ParseException {
     ident name;
     verbatim body;
    name = parse_ident();
    body = parse_verbatim();
      {if (true) return new BehDef(name,body);}
    throw new Error("Missing return statement in function");
  }

  final public EmptyList parse_EmptyList() throws ParseException {
    EmptyList sup = null;
    sup = parse_IncludeEmpty();
                                 {if (true) return sup;}
    throw new Error("Missing return statement in function");
  }

  final public ConsList parse_ConsList() throws ParseException {
    ConsList sup = null;
    if (jj_2_37(3)) {
      sup = parse_IncludeCons();
                                {if (true) return sup;}
    } else if (jj_2_38(3)) {
      sup = parse_NEPkgList();
                              {if (true) return sup;}
    } else if (jj_2_39(3)) {
      sup = parse_PkgCons();
                            {if (true) return sup;}
    } else if (jj_2_40(3)) {
      sup = parse_ImportCons();
                               {if (true) return sup;}
    } else if (jj_2_41(3)) {
      sup = parse_NENameList();
                               {if (true) return sup;}
    } else if (jj_2_42(3)) {
      sup = parse_NameCons();
                             {if (true) return sup;}
    } else if (jj_2_43(3)) {
      sup = parse_NETypeUseList();
                                  {if (true) return sup;}
    } else if (jj_2_44(3)) {
      sup = parse_TypeUseCons();
                                {if (true) return sup;}
    } else if (jj_2_45(3)) {
      sup = parse_TypeDefCons();
                                {if (true) return sup;}
    } else if (jj_2_46(3)) {
      sup = parse_FieldCons();
                              {if (true) return sup;}
    } else if (jj_2_47(3)) {
      sup = parse_NESubtypeList();
                                  {if (true) return sup;}
    } else if (jj_2_48(3)) {
      sup = parse_SubtypeCons();
                                {if (true) return sup;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public LitToken parse_LitToken() throws ParseException {
    LitToken sup = null;
    if (jj_2_49(3)) {
      sup = parse_AddToken();
                             {if (true) return sup;}
    } else if (jj_2_50(3)) {
      sup = parse_TheEOF();
                           {if (true) return sup;}
    } else {
      sup = parse_SumToken();
                             {if (true) return sup;}
    }
    throw new Error("Missing return statement in function");
  }

  final public RuntimeException parse_RuntimeException() throws ParseException {
    RuntimeException sup = null;
    sup = parse_TE();
                       {if (true) return sup;}
    throw new Error("Missing return statement in function");
  }

  final public TE parse_TE() throws ParseException {
      {if (true) return new TE();}
    throw new Error("Missing return statement in function");
  }

  final public RTParseException parse_RTParseException() throws ParseException {
      {if (true) return new RTParseException();}
    throw new Error("Missing return statement in function");
  }

  final public RTFileNotFound parse_RTFileNotFound() throws ParseException {
      {if (true) return new RTFileNotFound();}
    throw new Error("Missing return statement in function");
  }

  final public DummyDGP parse_DummyDGP() throws ParseException {
     String behavior;
    behavior = parse_String();
      {if (true) return new DummyDGP(behavior);}
    throw new Error("Missing return statement in function");
  }

  final public RBColor parse_RBColor() throws ParseException {
    RBColor sup = null;
    if (jj_2_51(3)) {
      sup = parse_RED();
                        {if (true) return sup;}
    } else if (jj_2_52(3)) {
      sup = parse_BLACK();
                          {if (true) return sup;}
    } else {
      jj_consume_token(-1);
      throw new ParseException();
    }
    throw new Error("Missing return statement in function");
  }

  final public RED parse_RED() throws ParseException {
    jj_consume_token(29);
      {if (true) return new RED();}
    throw new Error("Missing return statement in function");
  }

  final public BLACK parse_BLACK() throws ParseException {
    jj_consume_token(30);
      {if (true) return new BLACK();}
    throw new Error("Missing return statement in function");
  }

  private boolean jj_2_1(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_1(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(0, xla); }
  }

  private boolean jj_2_2(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_2(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(1, xla); }
  }

  private boolean jj_2_3(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_3(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(2, xla); }
  }

  private boolean jj_2_4(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_4(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(3, xla); }
  }

  private boolean jj_2_5(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_5(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(4, xla); }
  }

  private boolean jj_2_6(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_6(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(5, xla); }
  }

  private boolean jj_2_7(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_7(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(6, xla); }
  }

  private boolean jj_2_8(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_8(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(7, xla); }
  }

  private boolean jj_2_9(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_9(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(8, xla); }
  }

  private boolean jj_2_10(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_10(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(9, xla); }
  }

  private boolean jj_2_11(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_11(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(10, xla); }
  }

  private boolean jj_2_12(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_12(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(11, xla); }
  }

  private boolean jj_2_13(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_13(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(12, xla); }
  }

  private boolean jj_2_14(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_14(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(13, xla); }
  }

  private boolean jj_2_15(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_15(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(14, xla); }
  }

  private boolean jj_2_16(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_16(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(15, xla); }
  }

  private boolean jj_2_17(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_17(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(16, xla); }
  }

  private boolean jj_2_18(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_18(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(17, xla); }
  }

  private boolean jj_2_19(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_19(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(18, xla); }
  }

  private boolean jj_2_20(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_20(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(19, xla); }
  }

  private boolean jj_2_21(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_21(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(20, xla); }
  }

  private boolean jj_2_22(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_22(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(21, xla); }
  }

  private boolean jj_2_23(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_23(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(22, xla); }
  }

  private boolean jj_2_24(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_24(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(23, xla); }
  }

  private boolean jj_2_25(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_25(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(24, xla); }
  }

  private boolean jj_2_26(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_26(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(25, xla); }
  }

  private boolean jj_2_27(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_27(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(26, xla); }
  }

  private boolean jj_2_28(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_28(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(27, xla); }
  }

  private boolean jj_2_29(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_29(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(28, xla); }
  }

  private boolean jj_2_30(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_30(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(29, xla); }
  }

  private boolean jj_2_31(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_31(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(30, xla); }
  }

  private boolean jj_2_32(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_32(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(31, xla); }
  }

  private boolean jj_2_33(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_33(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(32, xla); }
  }

  private boolean jj_2_34(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_34(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(33, xla); }
  }

  private boolean jj_2_35(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_35(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(34, xla); }
  }

  private boolean jj_2_36(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_36(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(35, xla); }
  }

  private boolean jj_2_37(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_37(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(36, xla); }
  }

  private boolean jj_2_38(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_38(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(37, xla); }
  }

  private boolean jj_2_39(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_39(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(38, xla); }
  }

  private boolean jj_2_40(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_40(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(39, xla); }
  }

  private boolean jj_2_41(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_41(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(40, xla); }
  }

  private boolean jj_2_42(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_42(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(41, xla); }
  }

  private boolean jj_2_43(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_43(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(42, xla); }
  }

  private boolean jj_2_44(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_44(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(43, xla); }
  }

  private boolean jj_2_45(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_45(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(44, xla); }
  }

  private boolean jj_2_46(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_46(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(45, xla); }
  }

  private boolean jj_2_47(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_47(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(46, xla); }
  }

  private boolean jj_2_48(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_48(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(47, xla); }
  }

  private boolean jj_2_49(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_49(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(48, xla); }
  }

  private boolean jj_2_50(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_50(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(49, xla); }
  }

  private boolean jj_2_51(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_51(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(50, xla); }
  }

  private boolean jj_2_52(int xla) {
    jj_la = xla; jj_lastpos = jj_scanpos = token;
    try { return !jj_3_52(); }
    catch(LookaheadSuccess ls) { return true; }
    finally { jj_save(51, xla); }
  }

  private boolean jj_3_3() {
    if (jj_3R_1()) return true;
    return false;
  }

  private boolean jj_3R_33() {
    if (jj_scan_token(28)) return true;
    if (jj_3R_47()) return true;
    if (jj_3R_55()) return true;
    return false;
  }

  private boolean jj_3R_37() {
    if (jj_3R_47()) return true;
    if (jj_3R_50()) return true;
    return false;
  }

  private boolean jj_3R_9() {
    if (jj_3R_45()) return true;
    if (jj_3R_42()) return true;
    if (jj_3R_46()) return true;
    if (jj_scan_token(6)) return true;
    return false;
  }

  private boolean jj_3R_66() {
    if (jj_3R_77()) return true;
    return false;
  }

  private boolean jj_3R_40() {
    if (jj_3R_45()) return true;
    if (jj_scan_token(1)) return true;
    if (jj_3R_51()) return true;
    return false;
  }

  private boolean jj_3R_64() {
    if (jj_3R_75()) return true;
    return false;
  }

  private boolean jj_3_35() {
    if (jj_3R_33()) return true;
    return false;
  }

  private boolean jj_3_20() {
    if (jj_3R_18()) return true;
    return false;
  }

  private boolean jj_3R_55() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_35()) {
    jj_scanpos = xsp;
    if (jj_3R_66()) return true;
    }
    return false;
  }

  private boolean jj_3R_50() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_20()) {
    jj_scanpos = xsp;
    if (jj_3R_64()) return true;
    }
    return false;
  }

  private boolean jj_3R_79() {
    return false;
  }

  private boolean jj_3R_32() {
    if (jj_3R_47()) return true;
    if (jj_3R_55()) return true;
    return false;
  }

  private boolean jj_3R_8() {
    if (jj_3R_45()) return true;
    if (jj_scan_token(10)) return true;
    if (jj_3R_42()) return true;
    return false;
  }

  private boolean jj_3R_17() {
    if (jj_scan_token(14)) return true;
    if (jj_3R_37()) return true;
    if (jj_scan_token(15)) return true;
    return false;
  }

  private boolean jj_3_34() {
    if (jj_3R_32()) return true;
    return false;
  }

  private boolean jj_3_11() {
    if (jj_3R_9()) return true;
    return false;
  }

  private boolean jj_3_10() {
    if (jj_3R_8()) return true;
    return false;
  }

  private boolean jj_3R_76() {
    return false;
  }

  private boolean jj_3R_72() {
    if (jj_3R_79()) return true;
    return false;
  }

  private boolean jj_3_19() {
    if (jj_3R_17()) return true;
    return false;
  }

  private boolean jj_3R_67() {
    if (jj_scan_token(TEXT)) return true;
    return false;
  }

  private boolean jj_3R_52() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_10()) {
    jj_scanpos = xsp;
    if (jj_3_11()) return true;
    }
    return false;
  }

  private boolean jj_3R_61() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_19()) {
    jj_scanpos = xsp;
    if (jj_3R_72()) return true;
    }
    return false;
  }

  private boolean jj_3R_39() {
    if (jj_scan_token(30)) return true;
    return false;
  }

  private boolean jj_3R_42() {
    if (jj_scan_token(IDENT)) return true;
    return false;
  }

  private boolean jj_3R_31() {
    if (jj_3R_53()) return true;
    if (jj_3R_54()) return true;
    return false;
  }

  private boolean jj_3R_47() {
    if (jj_3R_42()) return true;
    if (jj_3R_61()) return true;
    return false;
  }

  private boolean jj_3R_38() {
    if (jj_scan_token(29)) return true;
    return false;
  }

  private boolean jj_3R_7() {
    if (jj_3R_44()) return true;
    return false;
  }

  private boolean jj_3R_65() {
    if (jj_3R_76()) return true;
    return false;
  }

  private boolean jj_3R_74() {
    return false;
  }

  private boolean jj_3_33() {
    if (jj_3R_31()) return true;
    return false;
  }

  private boolean jj_3_52() {
    if (jj_3R_39()) return true;
    return false;
  }

  private boolean jj_3_51() {
    if (jj_3R_38()) return true;
    return false;
  }

  private boolean jj_3R_54() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_33()) {
    jj_scanpos = xsp;
    if (jj_3R_65()) return true;
    }
    return false;
  }

  private boolean jj_3_2() {
    if (jj_scan_token(FALSE)) return true;
    return false;
  }

  private boolean jj_3_1() {
    if (jj_scan_token(TRUE)) return true;
    return false;
  }

  private boolean jj_3_9() {
    if (jj_3R_7()) return true;
    return false;
  }

  private boolean jj_3R_51() {
    if (jj_scan_token(STRING)) return true;
    return false;
  }

  private boolean jj_3R_16() {
    if (jj_scan_token(18)) return true;
    if (jj_3R_48()) return true;
    if (jj_3R_49()) return true;
    return false;
  }

  private boolean jj_3R_69() {
    return false;
  }

  private boolean jj_3R_30() {
    if (jj_3R_52()) return true;
    return false;
  }

  private boolean jj_3R_36() {
    if (jj_3R_48()) return true;
    if (jj_3R_49()) return true;
    return false;
  }

  private boolean jj_3R_6() {
    if (jj_scan_token(9)) return true;
    return false;
  }

  private boolean jj_3_32() {
    if (jj_3R_30()) return true;
    return false;
  }

  private boolean jj_3R_63() {
    if (jj_3R_74()) return true;
    return false;
  }

  private boolean jj_3R_5() {
    if (jj_scan_token(8)) return true;
    if (jj_3R_42()) return true;
    if (jj_3R_43()) return true;
    return false;
  }

  private boolean jj_3_18() {
    if (jj_3R_16()) return true;
    return false;
  }

  private boolean jj_3R_49() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_18()) {
    jj_scanpos = xsp;
    if (jj_3R_63()) return true;
    }
    return false;
  }

  private boolean jj_3R_15() {
    if (jj_scan_token(17)) return true;
    if (jj_3R_37()) return true;
    return false;
  }

  private boolean jj_3R_35() {
    if (jj_3R_42()) return true;
    if (jj_3R_43()) return true;
    return false;
  }

  private boolean jj_3R_29() {
    if (jj_3R_51()) return true;
    return false;
  }

  private boolean jj_3R_41() {
    if (jj_scan_token(INT)) return true;
    return false;
  }

  private boolean jj_3R_58() {
    if (jj_3R_69()) return true;
    return false;
  }

  private boolean jj_3_31() {
    if (jj_3R_29()) return true;
    return false;
  }

  private boolean jj_3_8() {
    if (jj_3R_6()) return true;
    return false;
  }

  private boolean jj_3_7() {
    if (jj_3R_5()) return true;
    return false;
  }

  private boolean jj_3_17() {
    if (jj_3R_15()) return true;
    return false;
  }

  private boolean jj_3R_43() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_7()) {
    jj_scanpos = xsp;
    if (jj_3_8()) {
    jj_scanpos = xsp;
    if (jj_3R_58()) return true;
    }
    }
    return false;
  }

  private boolean jj_3R_28() {
    if (jj_scan_token(27)) return true;
    return false;
  }

  private boolean jj_3R_80() {
    return false;
  }

  private boolean jj_3R_44() {
    if (jj_scan_token(7)) return true;
    if (jj_3R_35()) return true;
    return false;
  }

  private boolean jj_3R_27() {
    if (jj_3R_51()) return true;
    return false;
  }

  private boolean jj_3_50() {
    if (jj_3R_28()) return true;
    return false;
  }

  private boolean jj_3_49() {
    if (jj_3R_27()) return true;
    return false;
  }

  private boolean jj_3R_14() {
    if (jj_scan_token(16)) return true;
    if (jj_3R_47()) return true;
    return false;
  }

  private boolean jj_3R_26() {
    if (jj_scan_token(26)) return true;
    return false;
  }

  private boolean jj_3_48() {
    if (jj_3R_33()) return true;
    return false;
  }

  private boolean jj_3_47() {
    if (jj_3R_32()) return true;
    return false;
  }

  private boolean jj_3_46() {
    if (jj_3R_31()) return true;
    return false;
  }

  private boolean jj_3_45() {
    if (jj_3R_30()) return true;
    return false;
  }

  private boolean jj_3_44() {
    if (jj_3R_18()) return true;
    return false;
  }

  private boolean jj_3R_73() {
    if (jj_3R_80()) return true;
    return false;
  }

  private boolean jj_3_43() {
    if (jj_3R_37()) return true;
    return false;
  }

  private boolean jj_3R_25() {
    if (jj_scan_token(25)) return true;
    return false;
  }

  private boolean jj_3_16() {
    if (jj_3R_14()) return true;
    return false;
  }

  private boolean jj_3_42() {
    if (jj_3R_16()) return true;
    return false;
  }

  private boolean jj_3R_4() {
    if (jj_scan_token(5)) return true;
    if (jj_scan_token(6)) return true;
    if (jj_3R_41()) return true;
    return false;
  }

  private boolean jj_3_41() {
    if (jj_3R_36()) return true;
    return false;
  }

  private boolean jj_3_40() {
    if (jj_3R_7()) return true;
    return false;
  }

  private boolean jj_3_39() {
    if (jj_3R_5()) return true;
    return false;
  }

  private boolean jj_3R_62() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_16()) {
    jj_scanpos = xsp;
    if (jj_3R_73()) return true;
    }
    return false;
  }

  private boolean jj_3_38() {
    if (jj_3R_35()) return true;
    return false;
  }

  private boolean jj_3_37() {
    if (jj_3R_1()) return true;
    return false;
  }

  private boolean jj_3R_24() {
    if (jj_scan_token(24)) return true;
    return false;
  }

  private boolean jj_3R_48() {
    if (jj_3R_42()) return true;
    if (jj_3R_62()) return true;
    return false;
  }

  private boolean jj_3_6() {
    if (jj_3R_4()) return true;
    return false;
  }

  private boolean jj_3R_23() {
    if (jj_scan_token(23)) return true;
    return false;
  }

  private boolean jj_3R_71() {
    return false;
  }

  private boolean jj_3R_22() {
    if (jj_scan_token(22)) return true;
    return false;
  }

  private boolean jj_3R_3() {
    if (jj_scan_token(4)) return true;
    if (jj_3R_35()) return true;
    return false;
  }

  private boolean jj_3R_21() {
    if (jj_scan_token(21)) return true;
    return false;
  }

  private boolean jj_3R_13() {
    if (jj_scan_token(14)) return true;
    if (jj_3R_36()) return true;
    if (jj_scan_token(15)) return true;
    return false;
  }

  private boolean jj_3R_56() {
    if (jj_3R_42()) return true;
    if (jj_3R_67()) return true;
    return false;
  }

  private boolean jj_3_30() {
    if (jj_3R_28()) return true;
    return false;
  }

  private boolean jj_3R_60() {
    if (jj_3R_71()) return true;
    return false;
  }

  private boolean jj_3_5() {
    if (jj_3R_3()) return true;
    return false;
  }

  private boolean jj_3_29() {
    if (jj_3R_27()) return true;
    return false;
  }

  private boolean jj_3_15() {
    if (jj_3R_13()) return true;
    return false;
  }

  private boolean jj_3_28() {
    if (jj_3R_26()) return true;
    return false;
  }

  private boolean jj_3_27() {
    if (jj_3R_25()) return true;
    return false;
  }

  private boolean jj_3_26() {
    if (jj_3R_24()) return true;
    return false;
  }

  private boolean jj_3_25() {
    if (jj_3R_23()) return true;
    return false;
  }

  private boolean jj_3R_46() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_15()) {
    jj_scanpos = xsp;
    if (jj_3R_60()) return true;
    }
    return false;
  }

  private boolean jj_3_24() {
    if (jj_3R_22()) return true;
    return false;
  }

  private boolean jj_3R_78() {
    return false;
  }

  private boolean jj_3_23() {
    if (jj_3R_21()) return true;
    return false;
  }

  private boolean jj_3R_70() {
    return false;
  }

  private boolean jj_3R_20() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_23()) {
    jj_scanpos = xsp;
    if (jj_3_24()) {
    jj_scanpos = xsp;
    if (jj_3_25()) {
    jj_scanpos = xsp;
    if (jj_3_26()) {
    jj_scanpos = xsp;
    if (jj_3_27()) {
    jj_scanpos = xsp;
    if (jj_3_28()) {
    jj_scanpos = xsp;
    if (jj_3_29()) {
    jj_scanpos = xsp;
    if (jj_3_30()) return true;
    }
    }
    }
    }
    }
    }
    }
    return false;
  }

  private boolean jj_3_22() {
    if (jj_3R_20()) return true;
    return false;
  }

  private boolean jj_3_21() {
    if (jj_3R_19()) return true;
    return false;
  }

  private boolean jj_3R_34() {
    if (jj_3R_56()) return true;
    if (jj_3R_57()) return true;
    return false;
  }

  private boolean jj_3R_12() {
    if (jj_scan_token(13)) return true;
    return false;
  }

  private boolean jj_3R_2() {
    if (jj_scan_token(3)) return true;
    if (jj_3R_36()) return true;
    if (jj_scan_token(2)) return true;
    return false;
  }

  private boolean jj_3R_53() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_21()) {
    jj_scanpos = xsp;
    if (jj_3_22()) return true;
    }
    return false;
  }

  private boolean jj_3R_10() {
    if (jj_scan_token(12)) return true;
    return false;
  }

  private boolean jj_3R_68() {
    if (jj_3R_78()) return true;
    return false;
  }

  private boolean jj_3_4() {
    if (jj_3R_2()) return true;
    return false;
  }

  private boolean jj_3_36() {
    if (jj_3R_34()) return true;
    return false;
  }

  private boolean jj_3R_19() {
    if (jj_scan_token(19)) return true;
    if (jj_3R_42()) return true;
    if (jj_scan_token(20)) return true;
    return false;
  }

  private boolean jj_3R_57() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_36()) {
    jj_scanpos = xsp;
    if (jj_3R_68()) return true;
    }
    return false;
  }

  private boolean jj_3R_11() {
    if (jj_scan_token(11)) return true;
    return false;
  }

  private boolean jj_3R_75() {
    return false;
  }

  private boolean jj_3R_59() {
    if (jj_3R_70()) return true;
    return false;
  }

  private boolean jj_3_14() {
    if (jj_3R_12()) return true;
    return false;
  }

  private boolean jj_3_13() {
    if (jj_3R_11()) return true;
    return false;
  }

  private boolean jj_3_12() {
    if (jj_3R_10()) return true;
    return false;
  }

  private boolean jj_3R_1() {
    if (jj_3R_40()) return true;
    return false;
  }

  private boolean jj_3R_77() {
    return false;
  }

  private boolean jj_3R_45() {
    Token xsp;
    xsp = jj_scanpos;
    if (jj_3_12()) {
    jj_scanpos = xsp;
    if (jj_3_13()) {
    jj_scanpos = xsp;
    if (jj_3_14()) {
    jj_scanpos = xsp;
    if (jj_3R_59()) return true;
    }
    }
    }
    return false;
  }

  private boolean jj_3R_18() {
    if (jj_scan_token(18)) return true;
    if (jj_3R_47()) return true;
    if (jj_3R_50()) return true;
    return false;
  }

  /** Generated Token Manager. */
  public TheParserTokenManager token_source;
  SimpleCharStream jj_input_stream;
  /** Current token. */
  public Token token;
  /** Next token. */
  public Token jj_nt;
  private int jj_ntk;
  private Token jj_scanpos, jj_lastpos;
  private int jj_la;
  private int jj_gen;
  final private int[] jj_la1 = new int[0];
  static private int[] jj_la1_0;
  static private int[] jj_la1_1;
  static {
      jj_la1_init_0();
      jj_la1_init_1();
   }
   private static void jj_la1_init_0() {
      jj_la1_0 = new int[] {};
   }
   private static void jj_la1_init_1() {
      jj_la1_1 = new int[] {};
   }
  final private JJCalls[] jj_2_rtns = new JJCalls[52];
  private boolean jj_rescan = false;
  private int jj_gc = 0;

  /** Constructor with InputStream. */
  public TheParser(java.io.InputStream stream) {
     this(stream, null);
  }
  /** Constructor with InputStream and supplied encoding */
  public TheParser(java.io.InputStream stream, String encoding) {
    try { jj_input_stream = new SimpleCharStream(stream, encoding, 1, 1); } catch(java.io.UnsupportedEncodingException e) { throw new RuntimeException(e); }
    token_source = new TheParserTokenManager(jj_input_stream);
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  /** Reinitialise. */
  public void ReInit(java.io.InputStream stream) {
     ReInit(stream, null);
  }
  /** Reinitialise. */
  public void ReInit(java.io.InputStream stream, String encoding) {
    try { jj_input_stream.ReInit(stream, encoding, 1, 1); } catch(java.io.UnsupportedEncodingException e) { throw new RuntimeException(e); }
    token_source.ReInit(jj_input_stream);
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  /** Constructor. */
  public TheParser(java.io.Reader stream) {
    jj_input_stream = new SimpleCharStream(stream, 1, 1);
    token_source = new TheParserTokenManager(jj_input_stream);
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  /** Reinitialise. */
  public void ReInit(java.io.Reader stream) {
    jj_input_stream.ReInit(stream, 1, 1);
    token_source.ReInit(jj_input_stream);
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  /** Constructor with generated Token Manager. */
  public TheParser(TheParserTokenManager tm) {
    token_source = tm;
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  /** Reinitialise. */
  public void ReInit(TheParserTokenManager tm) {
    token_source = tm;
    token = new Token();
    jj_ntk = -1;
    jj_gen = 0;
    for (int i = 0; i < 0; i++) jj_la1[i] = -1;
    for (int i = 0; i < jj_2_rtns.length; i++) jj_2_rtns[i] = new JJCalls();
  }

  private Token jj_consume_token(int kind) throws ParseException {
    Token oldToken;
    if ((oldToken = token).next != null) token = token.next;
    else token = token.next = token_source.getNextToken();
    jj_ntk = -1;
    if (token.kind == kind) {
      jj_gen++;
      if (++jj_gc > 100) {
        jj_gc = 0;
        for (int i = 0; i < jj_2_rtns.length; i++) {
          JJCalls c = jj_2_rtns[i];
          while (c != null) {
            if (c.gen < jj_gen) c.first = null;
            c = c.next;
          }
        }
      }
      return token;
    }
    token = oldToken;
    jj_kind = kind;
    throw generateParseException();
  }

  static private final class LookaheadSuccess extends java.lang.Error { }
  final private LookaheadSuccess jj_ls = new LookaheadSuccess();
  private boolean jj_scan_token(int kind) {
    if (jj_scanpos == jj_lastpos) {
      jj_la--;
      if (jj_scanpos.next == null) {
        jj_lastpos = jj_scanpos = jj_scanpos.next = token_source.getNextToken();
      } else {
        jj_lastpos = jj_scanpos = jj_scanpos.next;
      }
    } else {
      jj_scanpos = jj_scanpos.next;
    }
    if (jj_rescan) {
      int i = 0; Token tok = token;
      while (tok != null && tok != jj_scanpos) { i++; tok = tok.next; }
      if (tok != null) jj_add_error_token(kind, i);
    }
    if (jj_scanpos.kind != kind) return true;
    if (jj_la == 0 && jj_scanpos == jj_lastpos) throw jj_ls;
    return false;
  }


/** Get the next Token. */
  final public Token getNextToken() {
    if (token.next != null) token = token.next;
    else token = token.next = token_source.getNextToken();
    jj_ntk = -1;
    jj_gen++;
    return token;
  }

/** Get the specific Token. */
  final public Token getToken(int index) {
    Token t = token;
    for (int i = 0; i < index; i++) {
      if (t.next != null) t = t.next;
      else t = t.next = token_source.getNextToken();
    }
    return t;
  }

  private int jj_ntk() {
    if ((jj_nt=token.next) == null)
      return (jj_ntk = (token.next=token_source.getNextToken()).kind);
    else
      return (jj_ntk = jj_nt.kind);
  }

  private java.util.List<int[]> jj_expentries = new java.util.ArrayList<int[]>();
  private int[] jj_expentry;
  private int jj_kind = -1;
  private int[] jj_lasttokens = new int[100];
  private int jj_endpos;

  private void jj_add_error_token(int kind, int pos) {
    if (pos >= 100) return;
    if (pos == jj_endpos + 1) {
      jj_lasttokens[jj_endpos++] = kind;
    } else if (jj_endpos != 0) {
      jj_expentry = new int[jj_endpos];
      for (int i = 0; i < jj_endpos; i++) {
        jj_expentry[i] = jj_lasttokens[i];
      }
      jj_entries_loop: for (java.util.Iterator<?> it = jj_expentries.iterator(); it.hasNext();) {
        int[] oldentry = (int[])(it.next());
        if (oldentry.length == jj_expentry.length) {
          for (int i = 0; i < jj_expentry.length; i++) {
            if (oldentry[i] != jj_expentry[i]) {
              continue jj_entries_loop;
            }
          }
          jj_expentries.add(jj_expentry);
          break jj_entries_loop;
        }
      }
      if (pos != 0) jj_lasttokens[(jj_endpos = pos) - 1] = kind;
    }
  }

  /** Generate ParseException. */
  public ParseException generateParseException() {
    jj_expentries.clear();
    boolean[] la1tokens = new boolean[47];
    if (jj_kind >= 0) {
      la1tokens[jj_kind] = true;
      jj_kind = -1;
    }
    for (int i = 0; i < 0; i++) {
      if (jj_la1[i] == jj_gen) {
        for (int j = 0; j < 32; j++) {
          if ((jj_la1_0[i] & (1<<j)) != 0) {
            la1tokens[j] = true;
          }
          if ((jj_la1_1[i] & (1<<j)) != 0) {
            la1tokens[32+j] = true;
          }
        }
      }
    }
    for (int i = 0; i < 47; i++) {
      if (la1tokens[i]) {
        jj_expentry = new int[1];
        jj_expentry[0] = i;
        jj_expentries.add(jj_expentry);
      }
    }
    jj_endpos = 0;
    jj_rescan_token();
    jj_add_error_token(0, 0);
    int[][] exptokseq = new int[jj_expentries.size()][];
    for (int i = 0; i < jj_expentries.size(); i++) {
      exptokseq[i] = jj_expentries.get(i);
    }
    return new ParseException(token, exptokseq, tokenImage);
  }

  /** Enable tracing. */
  final public void enable_tracing() {
  }

  /** Disable tracing. */
  final public void disable_tracing() {
  }

  private void jj_rescan_token() {
    jj_rescan = true;
    for (int i = 0; i < 52; i++) {
    try {
      JJCalls p = jj_2_rtns[i];
      do {
        if (p.gen > jj_gen) {
          jj_la = p.arg; jj_lastpos = jj_scanpos = p.first;
          switch (i) {
            case 0: jj_3_1(); break;
            case 1: jj_3_2(); break;
            case 2: jj_3_3(); break;
            case 3: jj_3_4(); break;
            case 4: jj_3_5(); break;
            case 5: jj_3_6(); break;
            case 6: jj_3_7(); break;
            case 7: jj_3_8(); break;
            case 8: jj_3_9(); break;
            case 9: jj_3_10(); break;
            case 10: jj_3_11(); break;
            case 11: jj_3_12(); break;
            case 12: jj_3_13(); break;
            case 13: jj_3_14(); break;
            case 14: jj_3_15(); break;
            case 15: jj_3_16(); break;
            case 16: jj_3_17(); break;
            case 17: jj_3_18(); break;
            case 18: jj_3_19(); break;
            case 19: jj_3_20(); break;
            case 20: jj_3_21(); break;
            case 21: jj_3_22(); break;
            case 22: jj_3_23(); break;
            case 23: jj_3_24(); break;
            case 24: jj_3_25(); break;
            case 25: jj_3_26(); break;
            case 26: jj_3_27(); break;
            case 27: jj_3_28(); break;
            case 28: jj_3_29(); break;
            case 29: jj_3_30(); break;
            case 30: jj_3_31(); break;
            case 31: jj_3_32(); break;
            case 32: jj_3_33(); break;
            case 33: jj_3_34(); break;
            case 34: jj_3_35(); break;
            case 35: jj_3_36(); break;
            case 36: jj_3_37(); break;
            case 37: jj_3_38(); break;
            case 38: jj_3_39(); break;
            case 39: jj_3_40(); break;
            case 40: jj_3_41(); break;
            case 41: jj_3_42(); break;
            case 42: jj_3_43(); break;
            case 43: jj_3_44(); break;
            case 44: jj_3_45(); break;
            case 45: jj_3_46(); break;
            case 46: jj_3_47(); break;
            case 47: jj_3_48(); break;
            case 48: jj_3_49(); break;
            case 49: jj_3_50(); break;
            case 50: jj_3_51(); break;
            case 51: jj_3_52(); break;
          }
        }
        p = p.next;
      } while (p != null);
      } catch(LookaheadSuccess ls) { }
    }
    jj_rescan = false;
  }

  private void jj_save(int index, int xla) {
    JJCalls p = jj_2_rtns[index];
    while (p.gen > jj_gen) {
      if (p.next == null) { p = p.next = new JJCalls(); break; }
      p = p.next;
    }
    p.gen = jj_gen + xla - jj_la; p.first = token; p.arg = xla;
  }

  static final class JJCalls {
    int gen;
    Token first;
    int arg;
    JJCalls next;
  }

  }