Moved to test plugin to eliminate dependency upon junit plugin
[phpeclipse.git] / net.sourceforge.phpeclipse / src / test / PHPParserTokenManager.java
index e8a8a8e..bffc8ef 100644 (file)
@@ -6,74 +6,187 @@ import org.eclipse.core.runtime.CoreException;
 import org.eclipse.ui.texteditor.MarkerUtilities;
 import org.eclipse.jface.preference.IPreferenceStore;
 import java.util.Hashtable;
+import java.util.Enumeration;
 import java.io.StringReader;
+import java.io.*;
 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;
+import net.sourceforge.phpdt.internal.compiler.parser.*;
+import net.sourceforge.phpdt.internal.compiler.ast.*;
 
 public class PHPParserTokenManager implements PHPParserConstants
 {
   public static  java.io.PrintStream debugStream = System.out;
   public static  void setDebugStream(java.io.PrintStream ds) { debugStream = ds; }
-private static final int jjStopStringLiteralDfa_0(int pos, long active0, long active1, long active2)
+static private final int jjStopAtPos(int pos, int kind)
 {
-   switch (pos)
+   jjmatchedKind = kind;
+   jjmatchedPos = pos;
+   return pos + 1;
+}
+static private final int jjMoveStringLiteralDfa0_0()
+{
+   switch(curChar)
    {
+      case 60:
+         return jjMoveStringLiteralDfa1_0(0xeL);
       default :
-         return -1;
+         return 1;
    }
 }
-private static final int jjStartNfa_0(int pos, long active0, long active1, long active2)
+static private final int jjMoveStringLiteralDfa1_0(long active0)
 {
-   return jjMoveNfa_0(jjStopStringLiteralDfa_0(pos, active0, active1, active2), pos + 1);
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      return 1;
+   }
+   switch(curChar)
+   {
+      case 63:
+         if ((active0 & 0x2L) != 0L)
+         {
+            jjmatchedKind = 1;
+            jjmatchedPos = 1;
+         }
+         return jjMoveStringLiteralDfa2_0(active0, 0xcL);
+      default :
+         return 2;
+   }
 }
-static private final int jjStopAtPos(int pos, int kind)
+static private final int jjMoveStringLiteralDfa2_0(long old0, long active0)
 {
-   jjmatchedKind = kind;
-   jjmatchedPos = pos;
-   return pos + 1;
+   if (((active0 &= old0)) == 0L)
+      return 2;
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      return 2;
+   }
+   switch(curChar)
+   {
+      case 61:
+         if ((active0 & 0x8L) != 0L)
+            return jjStopAtPos(2, 3);
+         break;
+      case 80:
+      case 112:
+         return jjMoveStringLiteralDfa3_0(active0, 0x4L);
+      default :
+         return 3;
+   }
+   return 3;
+}
+static private final int jjMoveStringLiteralDfa3_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return 3;
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      return 3;
+   }
+   switch(curChar)
+   {
+      case 72:
+      case 104:
+         return jjMoveStringLiteralDfa4_0(active0, 0x4L);
+      default :
+         return 4;
+   }
+}
+static private final int jjMoveStringLiteralDfa4_0(long old0, long active0)
+{
+   if (((active0 &= old0)) == 0L)
+      return 4;
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      return 4;
+   }
+   switch(curChar)
+   {
+      case 80:
+      case 112:
+         if ((active0 & 0x4L) != 0L)
+            return jjStopAtPos(4, 2);
+         break;
+      default :
+         return 5;
+   }
+   return 5;
+}
+static private final int jjMoveStringLiteralDfa0_4()
+{
+   switch(curChar)
+   {
+      case 42:
+         return jjMoveStringLiteralDfa1_4(0x40000L);
+      default :
+         return 1;
+   }
+}
+static private final int jjMoveStringLiteralDfa1_4(long active0)
+{
+   try { curChar = input_stream.readChar(); }
+   catch(java.io.IOException e) {
+      return 1;
+   }
+   switch(curChar)
+   {
+      case 47:
+         if ((active0 & 0x40000L) != 0L)
+            return jjStopAtPos(1, 18);
+         break;
+      default :
+         return 2;
+   }
+   return 2;
+}
+private static final int jjStopStringLiteralDfa_2(int pos, long active0)
+{
+   switch (pos)
+   {
+      default :
+         return -1;
+   }
 }
-static private final int jjStartNfaWithStates_0(int pos, int kind, int state)
+private static final int jjStartNfa_2(int pos, long active0)
+{
+   return jjMoveNfa_2(jjStopStringLiteralDfa_2(pos, active0), pos + 1);
+}
+static private final int jjStartNfaWithStates_2(int pos, int kind, int state)
 {
    jjmatchedKind = kind;
    jjmatchedPos = pos;
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) { return pos + 1; }
-   return jjMoveNfa_0(state, pos + 1);
+   return jjMoveNfa_2(state, pos + 1);
 }
-static private final int jjMoveStringLiteralDfa0_0()
+static private final int jjMoveStringLiteralDfa0_2()
 {
    switch(curChar)
    {
       case 63:
-         return jjMoveStringLiteralDfa1_0(0x8000000000000000L);
+         return jjMoveStringLiteralDfa1_2(0x10000L);
       default :
-         return jjMoveNfa_0(0, 0);
+         return jjMoveNfa_2(0, 0);
    }
 }
-static private final int jjMoveStringLiteralDfa1_0(long active1)
+static private final int jjMoveStringLiteralDfa1_2(long active0)
 {
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_0(0, 0L, active1, 0L);
+      jjStopStringLiteralDfa_2(0, active0);
       return 1;
    }
    switch(curChar)
    {
       case 62:
-         if ((active1 & 0x8000000000000000L) != 0L)
-            return jjStopAtPos(1, 127);
+         if ((active0 & 0x10000L) != 0L)
+            return jjStopAtPos(1, 16);
          break;
       default :
          break;
    }
-   return jjStartNfa_0(0, 0L, active1, 0L);
+   return jjStartNfa_2(0, active0);
 }
 static private final void jjCheckNAdd(int state)
 {
@@ -105,125 +218,11 @@ static private final void jjCheckNAddStates(int start)
    jjCheckNAdd(jjnextStates[start]);
    jjCheckNAdd(jjnextStates[start + 1]);
 }
-static private final int jjMoveNfa_0(int startState, int curPos)
-{
-   int[] nextStates;
-   int startsAt = 0;
-   jjnewStateCnt = 6;
-   int i = 1;
-   jjstateSet[0] = startState;
-   int j, kind = 0x7fffffff;
-   for (;;)
-   {
-      if (++jjround == 0x7fffffff)
-         ReInitRounds();
-      if (curChar < 64)
-      {
-         long l = 1L << curChar;
-         MatchLoop: do
-         {
-            switch(jjstateSet[--i])
-            {
-               case 0:
-                  if (curChar == 60)
-                     jjAddStates(0, 1);
-                  break;
-               case 4:
-                  if (curChar == 63)
-                     jjstateSet[jjnewStateCnt++] = 3;
-                  break;
-               case 5:
-                  if (curChar == 63 && kind > 1)
-                     kind = 1;
-                  break;
-               default : break;
-            }
-         } while(i != startsAt);
-      }
-      else if (curChar < 128)
-      {
-         long l = 1L << (curChar & 077);
-         MatchLoop: do
-         {
-            switch(jjstateSet[--i])
-            {
-               case 1:
-                  if ((0x1000000010000L & l) != 0L && kind > 1)
-                     kind = 1;
-                  break;
-               case 2:
-                  if ((0x10000000100L & l) != 0L)
-                     jjstateSet[jjnewStateCnt++] = 1;
-                  break;
-               case 3:
-                  if ((0x1000000010000L & l) != 0L)
-                     jjstateSet[jjnewStateCnt++] = 2;
-                  break;
-               default : break;
-            }
-         } while(i != startsAt);
-      }
-      else
-      {
-         int i2 = (curChar & 0xff) >> 6;
-         long l2 = 1L << (curChar & 077);
-         MatchLoop: do
-         {
-            switch(jjstateSet[--i])
-            {
-               default : break;
-            }
-         } while(i != startsAt);
-      }
-      if (kind != 0x7fffffff)
-      {
-         jjmatchedKind = kind;
-         jjmatchedPos = curPos;
-         kind = 0x7fffffff;
-      }
-      ++curPos;
-      if ((i = jjnewStateCnt) == (startsAt = 6 - (jjnewStateCnt = startsAt)))
-         return curPos;
-      try { curChar = input_stream.readChar(); }
-      catch(java.io.IOException e) { return curPos; }
-   }
-}
-static private final int jjMoveStringLiteralDfa0_4()
-{
-   switch(curChar)
-   {
-      case 42:
-         return jjMoveStringLiteralDfa1_4(0x4000L);
-      default :
-         return 1;
-   }
-}
-static private final int jjMoveStringLiteralDfa1_4(long active0)
-{
-   try { curChar = input_stream.readChar(); }
-   catch(java.io.IOException e) {
-      return 1;
-   }
-   switch(curChar)
-   {
-      case 47:
-         if ((active0 & 0x4000L) != 0L)
-            return jjStopAtPos(1, 14);
-         break;
-      default :
-         return 2;
-   }
-   return 2;
-}
-static private final int jjMoveStringLiteralDfa0_2()
-{
-   return jjMoveNfa_2(0, 0);
-}
 static private final int jjMoveNfa_2(int startState, int curPos)
 {
    int[] nextStates;
    int startsAt = 0;
-   jjnewStateCnt = 5;
+   jjnewStateCnt = 3;
    int i = 1;
    jjstateSet[0] = startState;
    int j, kind = 0x7fffffff;
@@ -241,30 +240,20 @@ static private final int jjMoveNfa_2(int startState, int curPos)
                case 0:
                   if ((0x2400L & l) != 0L)
                   {
-                     if (kind > 12)
-                        kind = 12;
+                     if (kind > 15)
+                        kind = 15;
                   }
-                  else if (curChar == 63)
-                     jjstateSet[jjnewStateCnt++] = 3;
                   if (curChar == 13)
                      jjstateSet[jjnewStateCnt++] = 1;
                   break;
                case 1:
-                  if (curChar == 10 && kind > 12)
-                     kind = 12;
+                  if (curChar == 10 && kind > 15)
+                     kind = 15;
                   break;
                case 2:
                   if (curChar == 13)
                      jjstateSet[jjnewStateCnt++] = 1;
                   break;
-               case 3:
-                  if (curChar == 62)
-                     kind = 12;
-                  break;
-               case 4:
-                  if (curChar == 63)
-                     jjstateSet[jjnewStateCnt++] = 3;
-                  break;
                default : break;
             }
          } while(i != startsAt);
@@ -299,133 +288,135 @@ static private final int jjMoveNfa_2(int startState, int curPos)
          kind = 0x7fffffff;
       }
       ++curPos;
-      if ((i = jjnewStateCnt) == (startsAt = 5 - (jjnewStateCnt = startsAt)))
+      if ((i = jjnewStateCnt) == (startsAt = 3 - (jjnewStateCnt = startsAt)))
          return curPos;
       try { curChar = input_stream.readChar(); }
       catch(java.io.IOException e) { return curPos; }
    }
 }
-private static final int jjStopStringLiteralDfa_1(int pos, long active0, long active1)
+private static final int jjStopStringLiteralDfa_1(int pos, long active0, long active1, long active2)
 {
    switch (pos)
    {
       case 0:
-         if ((active0 & 0xfffffffc7fff0000L) != 0L)
-         {
-            jjmatchedKind = 74;
-            return 14;
-         }
-         if ((active0 & 0xa00L) != 0L || (active1 & 0x20040000000000L) != 0L)
+         if ((active0 & 0x4800L) != 0L || (active1 & 0x400000000000L) != 0L || (active2 & 0x4L) != 0L)
             return 2;
-         if ((active1 & 0x1000000L) != 0L)
+         if ((active1 & 0x40000000000000L) != 0L)
             return 16;
-         if ((active1 & 0x200000000400000L) != 0L)
+         if ((active1 & 0x4000100000000L) != 0L)
             return 8;
+         if ((active0 & 0xffffff1ffff00000L) != 0L || (active1 & 0x3ffL) != 0L)
+         {
+            jjmatchedKind = 84;
+            return 14;
+         }
          return -1;
       case 1:
-         if ((active0 & 0x800L) != 0L)
-            return 0;
-         if ((active0 & 0x4400008000080000L) != 0L)
-            return 14;
-         if ((active0 & 0xbbffff7c7ff70000L) != 0L)
+         if ((active0 & 0xbfffef1fff700000L) != 0L || (active1 & 0x2efL) != 0L)
          {
             if (jjmatchedPos != 1)
             {
-               jjmatchedKind = 74;
+               jjmatchedKind = 84;
                jjmatchedPos = 1;
             }
             return 14;
          }
+         if ((active0 & 0x4000L) != 0L)
+            return 0;
+         if ((active0 & 0x4000100000800000L) != 0L || (active1 & 0x110L) != 0L)
+            return 14;
          return -1;
       case 2:
-         if ((active0 & 0xb000140000040000L) != 0L)
+         if ((active0 & 0x2001400000400000L) != 0L || (active1 & 0x2c0L) != 0L)
             return 14;
-         if ((active0 & 0xfffeb7c7ff30000L) != 0L)
+         if ((active0 & 0x9ffeaf1fff300000L) != 0L || (active1 & 0x3fL) != 0L)
          {
             if (jjmatchedPos != 2)
             {
-               jjmatchedKind = 74;
+               jjmatchedKind = 84;
                jjmatchedPos = 2;
             }
             return 14;
          }
          return -1;
       case 3:
-         if ((active0 & 0x2c79c3747ec30000L) != 0L)
+         if ((active0 & 0x62810053000000L) != 0L || (active1 & 0xeL) != 0L)
+            return 14;
+         if ((active0 & 0xbf9c2e1fac300000L) != 0L || (active1 & 0xb1L) != 0L)
          {
             if (jjmatchedPos != 3)
             {
-               jjmatchedKind = 74;
+               jjmatchedKind = 84;
                jjmatchedPos = 3;
             }
             return 14;
          }
-         if ((active0 & 0x386280801300000L) != 0L)
-            return 14;
          return -1;
       case 4:
-         if ((active0 & 0x808821400c10000L) != 0L)
-            return 14;
-         if ((active0 & 0x257141607e120000L) != 0L)
+         if ((active0 & 0xb6142c1f81200000L) != 0L || (active1 & 0x95L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 4;
             return 14;
          }
+         if ((active0 & 0x98802002c100000L) != 0L || (active1 & 0x20L) != 0L)
+            return 14;
          return -1;
       case 5:
-         if ((active0 & 0x461400060100000L) != 0L)
+         if ((active0 & 0x9014001801000000L) != 0L || (active1 & 0x11L) != 0L)
             return 14;
-         if ((active0 & 0x211001601e020000L) != 0L)
+         if ((active0 & 0x26002c0780200000L) != 0L || (active1 & 0x84L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 5;
             return 14;
          }
          return -1;
       case 6:
-         if ((active0 & 0x210001401e000000L) != 0L)
+         if ((active0 & 0x2000280780000000L) != 0L || (active1 & 0x84L) != 0L)
             return 14;
-         if ((active0 & 0x10002000020000L) != 0L)
+         if ((active0 & 0x600040000200000L) != 0L)
          {
             if (jjmatchedPos != 6)
             {
-               jjmatchedKind = 74;
+               jjmatchedKind = 84;
                jjmatchedPos = 6;
             }
             return 14;
          }
          return -1;
       case 7:
-         if ((active0 & 0x10002000020000L) != 0L)
+         if ((active0 & 0x200040000200000L) != 0L)
             return 14;
-         if ((active0 & 0x18000000L) != 0L)
+         if ((active0 & 0x400000600000000L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 7;
             return 14;
          }
          return -1;
       case 8:
-         if ((active0 & 0x18000000L) != 0L)
+         if ((active0 & 0x600000000L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 8;
             return 14;
          }
+         if ((active0 & 0x400000000000000L) != 0L)
+            return 14;
          return -1;
       case 9:
-         if ((active0 & 0x18000000L) != 0L)
+         if ((active0 & 0x600000000L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 9;
             return 14;
          }
          return -1;
       case 10:
-         if ((active0 & 0x18000000L) != 0L)
+         if ((active0 & 0x600000000L) != 0L)
          {
-            jjmatchedKind = 74;
+            jjmatchedKind = 84;
             jjmatchedPos = 10;
             return 14;
          }
@@ -434,9 +425,9 @@ private static final int jjStopStringLiteralDfa_1(int pos, long active0, long ac
          return -1;
    }
 }
-private static final int jjStartNfa_1(int pos, long active0, long active1)
+private static final int jjStartNfa_1(int pos, long active0, long active1, long active2)
 {
-   return jjMoveNfa_1(jjStopStringLiteralDfa_1(pos, active0, active1), pos + 1);
+   return jjMoveNfa_1(jjStopStringLiteralDfa_1(pos, active0, active1, active2), pos + 1);
 }
 static private final int jjStartNfaWithStates_1(int pos, int kind, int state)
 {
@@ -451,750 +442,807 @@ static private final int jjMoveStringLiteralDfa0_1()
    switch(curChar)
    {
       case 33:
-         jjmatchedKind = 92;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x400000000L);
+         jjmatchedKind = 119;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x14000000000L, 0x0L);
+      case 35:
+         return jjStopAtPos(0, 12);
       case 36:
-         return jjStartNfaWithStates_1(0, 88, 16);
+         return jjStartNfaWithStates_1(0, 118, 16);
       case 37:
-         jjmatchedKind = 110;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x400000000000000L);
+         jjmatchedKind = 134;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x8000000000000L, 0x0L);
       case 38:
-         jjmatchedKind = 107;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x40001000000000L);
+         jjmatchedKind = 131;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x1000800000000000L, 0x0L);
       case 40:
-         return jjStopAtPos(0, 78);
+         return jjStopAtPos(0, 88);
       case 41:
-         return jjStopAtPos(0, 79);
+         return jjStopAtPos(0, 89);
       case 42:
-         jjmatchedKind = 105;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x10000000000000L);
+         jjmatchedKind = 129;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x200000000000L, 0x0L);
       case 43:
-         jjmatchedKind = 103;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x4002000000000L);
+         jjmatchedKind = 127;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x2000080000000000L, 0x0L);
       case 44:
-         return jjStopAtPos(0, 85);
+         return jjStopAtPos(0, 95);
       case 45:
-         jjmatchedKind = 104;
-         return jjMoveStringLiteralDfa1_1(0x80000000L, 0x8004000000000L);
+         jjmatchedKind = 128;
+         return jjMoveStringLiteralDfa1_1(0x2000000000L, 0x4000100000000000L, 0x0L);
       case 46:
-         jjmatchedKind = 86;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x200000000000000L);
+         jjmatchedKind = 96;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x4000000000000L, 0x0L);
       case 47:
-         jjmatchedKind = 106;
-         return jjMoveStringLiteralDfa1_1(0xa00L, 0x20000000000000L);
+         jjmatchedKind = 130;
+         return jjMoveStringLiteralDfa1_1(0x4800L, 0x400000000000L, 0x0L);
       case 58:
-         jjmatchedKind = 94;
-         return jjMoveStringLiteralDfa1_1(0x100000000L, 0x0L);
+         jjmatchedKind = 122;
+         return jjMoveStringLiteralDfa1_1(0x4000000000L, 0x0L, 0x0L);
       case 59:
-         return jjStopAtPos(0, 84);
+         return jjStopAtPos(0, 94);
       case 60:
-         jjmatchedKind = 91;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x800800100000000L);
+         jjmatchedKind = 98;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x9000000000L, 0x480L);
       case 61:
-         jjmatchedKind = 89;
-         return jjMoveStringLiteralDfa1_1(0x200000000L, 0x80000000L);
+         jjmatchedKind = 106;
+         return jjMoveStringLiteralDfa1_1(0x8000000000L, 0x20800000000L, 0x0L);
       case 62:
-         jjmatchedKind = 90;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x3003000200000000L);
+         jjmatchedKind = 97;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x2000000000L, 0xb00L);
       case 63:
-         jjmatchedKind = 93;
-         return jjMoveStringLiteralDfa1_1(0x4L, 0x0L);
+         jjmatchedKind = 121;
+         return jjMoveStringLiteralDfa1_1(0x10L, 0x0L, 0x0L);
       case 64:
-         return jjStopAtPos(0, 87);
+         return jjStopAtPos(0, 117);
       case 91:
-         return jjStopAtPos(0, 82);
+         return jjStopAtPos(0, 92);
       case 93:
-         return jjStopAtPos(0, 83);
+         return jjStopAtPos(0, 93);
       case 94:
-         jjmatchedKind = 109;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x100000000000000L);
+         jjmatchedKind = 133;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x2000000000000L, 0x0L);
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa1_1(0x8000000000400000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x4000000004000000L, 0x200L, 0x0L);
       case 66:
       case 98:
-         return jjMoveStringLiteralDfa1_1(0x180000400000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x8000000L, 0x6L, 0x0L);
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa1_1(0x3800010000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x70000100000L, 0x0L, 0x0L);
       case 68:
       case 100:
-         return jjMoveStringLiteralDfa1_1(0x40000c000000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x180000000000L, 0x10L, 0x0L);
       case 69:
       case 101:
-         return jjMoveStringLiteralDfa1_1(0x10010001300000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x1e00200043000000L, 0x0L, 0x0L);
       case 70:
       case 102:
-         return jjMoveStringLiteralDfa1_1(0x800060000020000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x2080400000200000L, 0x20L, 0x0L);
       case 71:
       case 103:
-         return jjMoveStringLiteralDfa1_1(0x80020000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x800800000000L, 0x0L, 0x0L);
       case 73:
       case 105:
-         return jjMoveStringLiteralDfa1_1(0x300000000a080000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x280800000L, 0xc0L, 0x0L);
+      case 76:
+      case 108:
+         return jjMoveStringLiteralDfa1_1(0x10000000L, 0x0L, 0x0L);
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa1_1(0x300000000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x3000000000000L, 0x0L, 0x0L);
       case 79:
       case 111:
-         return jjMoveStringLiteralDfa1_1(0x4040000000000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x101L, 0x0L);
       case 80:
       case 112:
-         return jjMoveStringLiteralDfa1_1(0x800000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x20000000L, 0x0L, 0x0L);
       case 82:
       case 114:
-         return jjMoveStringLiteralDfa1_1(0x200400014000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x4000500000000L, 0x8L, 0x0L);
       case 83:
       case 115:
-         return jjMoveStringLiteralDfa1_1(0x21800040000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x8018001000000000L, 0x0L, 0x0L);
       case 84:
       case 116:
-         return jjMoveStringLiteralDfa1_1(0x6000000000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x60000000000000L, 0x0L, 0x0L);
       case 86:
       case 118:
-         return jjMoveStringLiteralDfa1_1(0x40000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x400000L, 0x0L, 0x0L);
       case 87:
       case 119:
-         return jjMoveStringLiteralDfa1_1(0x8000000000000L, 0x0L);
+         return jjMoveStringLiteralDfa1_1(0x100000000000000L, 0x0L, 0x0L);
       case 123:
-         return jjStopAtPos(0, 80);
+         return jjStopAtPos(0, 90);
       case 124:
-         jjmatchedKind = 108;
-         return jjMoveStringLiteralDfa1_1(0x0L, 0x80000800000000L);
+         jjmatchedKind = 132;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x801000000000000L, 0x0L);
       case 125:
-         return jjStopAtPos(0, 81);
+         return jjStopAtPos(0, 91);
+      case 126:
+         jjmatchedKind = 120;
+         return jjMoveStringLiteralDfa1_1(0x0L, 0x10000000000000L, 0x0L);
       default :
          return jjMoveNfa_1(3, 0);
    }
 }
-static private final int jjMoveStringLiteralDfa1_1(long active0, long active1)
+static private final int jjMoveStringLiteralDfa1_1(long active0, long active1, long active2)
 {
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(0, active0, active1);
+      jjStopStringLiteralDfa_1(0, active0, active1, active2);
       return 1;
    }
    switch(curChar)
    {
       case 38:
-         if ((active1 & 0x1000000000L) != 0L)
-            return jjStopAtPos(1, 100);
+         if ((active1 & 0x1000000000000000L) != 0L)
+            return jjStopAtPos(1, 124);
          break;
       case 42:
-         if ((active0 & 0x800L) != 0L)
-            return jjStartNfaWithStates_1(1, 11, 0);
+         if ((active0 & 0x4000L) != 0L)
+            return jjStartNfaWithStates_1(1, 14, 0);
          break;
       case 43:
-         if ((active1 & 0x2000000000L) != 0L)
-            return jjStopAtPos(1, 101);
+         if ((active1 & 0x2000000000000000L) != 0L)
+            return jjStopAtPos(1, 125);
          break;
       case 45:
-         if ((active1 & 0x4000000000L) != 0L)
-            return jjStopAtPos(1, 102);
+         if ((active1 & 0x4000000000000000L) != 0L)
+            return jjStopAtPos(1, 126);
          break;
       case 47:
-         if ((active0 & 0x200L) != 0L)
-            return jjStopAtPos(1, 9);
+         if ((active0 & 0x800L) != 0L)
+            return jjStopAtPos(1, 11);
          break;
       case 58:
-         if ((active0 & 0x100000000L) != 0L)
-            return jjStopAtPos(1, 32);
+         if ((active0 & 0x4000000000L) != 0L)
+            return jjStopAtPos(1, 38);
          break;
       case 60:
-         if ((active1 & 0x800000000000L) != 0L)
+         if ((active2 & 0x80L) != 0L)
          {
-            jjmatchedKind = 111;
+            jjmatchedKind = 135;
             jjmatchedPos = 1;
          }
-         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0x800000000000000L);
+         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0L, active2, 0x400L);
       case 61:
-         if ((active1 & 0x80000000L) != 0L)
-            return jjStopAtPos(1, 95);
-         else if ((active1 & 0x100000000L) != 0L)
-            return jjStopAtPos(1, 96);
-         else if ((active1 & 0x200000000L) != 0L)
-            return jjStopAtPos(1, 97);
-         else if ((active1 & 0x400000000L) != 0L)
-            return jjStopAtPos(1, 98);
+         if ((active1 & 0x800000000L) != 0L)
+         {
+            jjmatchedKind = 99;
+            jjmatchedPos = 1;
+         }
+         else if ((active1 & 0x1000000000L) != 0L)
+            return jjStopAtPos(1, 100);
+         else if ((active1 & 0x2000000000L) != 0L)
+            return jjStopAtPos(1, 101);
+         else if ((active1 & 0x4000000000L) != 0L)
+         {
+            jjmatchedKind = 102;
+            jjmatchedPos = 1;
+         }
+         else if ((active1 & 0x80000000000L) != 0L)
+            return jjStopAtPos(1, 107);
+         else if ((active1 & 0x100000000000L) != 0L)
+            return jjStopAtPos(1, 108);
+         else if ((active1 & 0x200000000000L) != 0L)
+            return jjStopAtPos(1, 109);
+         else if ((active1 & 0x400000000000L) != 0L)
+            return jjStopAtPos(1, 110);
+         else if ((active1 & 0x800000000000L) != 0L)
+            return jjStopAtPos(1, 111);
+         else if ((active1 & 0x1000000000000L) != 0L)
+            return jjStopAtPos(1, 112);
+         else if ((active1 & 0x2000000000000L) != 0L)
+            return jjStopAtPos(1, 113);
          else if ((active1 & 0x4000000000000L) != 0L)
             return jjStopAtPos(1, 114);
          else if ((active1 & 0x8000000000000L) != 0L)
             return jjStopAtPos(1, 115);
          else if ((active1 & 0x10000000000000L) != 0L)
             return jjStopAtPos(1, 116);
-         else if ((active1 & 0x20000000000000L) != 0L)
-            return jjStopAtPos(1, 117);
-         else if ((active1 & 0x40000000000000L) != 0L)
-            return jjStopAtPos(1, 118);
-         else if ((active1 & 0x80000000000000L) != 0L)
-            return jjStopAtPos(1, 119);
-         else if ((active1 & 0x100000000000000L) != 0L)
-            return jjStopAtPos(1, 120);
-         else if ((active1 & 0x200000000000000L) != 0L)
-            return jjStopAtPos(1, 121);
-         else if ((active1 & 0x400000000000000L) != 0L)
-            return jjStopAtPos(1, 122);
-         break;
+         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0x30000000000L, active2, 0L);
       case 62:
-         if ((active0 & 0x4L) != 0L)
-            return jjStopAtPos(1, 2);
-         else if ((active0 & 0x80000000L) != 0L)
-            return jjStopAtPos(1, 31);
-         else if ((active0 & 0x200000000L) != 0L)
-            return jjStopAtPos(1, 33);
-         else if ((active1 & 0x1000000000000L) != 0L)
+         if ((active0 & 0x10L) != 0L)
+            return jjStopAtPos(1, 4);
+         else if ((active0 & 0x2000000000L) != 0L)
+            return jjStopAtPos(1, 37);
+         else if ((active0 & 0x8000000000L) != 0L)
+            return jjStopAtPos(1, 39);
+         else if ((active1 & 0x8000000000L) != 0L)
+            return jjStopAtPos(1, 103);
+         else if ((active2 & 0x100L) != 0L)
          {
-            jjmatchedKind = 112;
+            jjmatchedKind = 136;
             jjmatchedPos = 1;
          }
-         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0x3002000000000000L);
+         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0L, active2, 0xa00L);
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa2_1(active0, 0x20800040000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x80010000400000L, active1, 0L, active2, 0L);
       case 66:
       case 98:
-         return jjMoveStringLiteralDfa2_1(active0, 0x40000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0L, active1, 0x1L, active2, 0L);
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa2_1(active0, 0x1000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x40000000L, active1, 0L, active2, 0L);
       case 69:
       case 101:
-         return jjMoveStringLiteralDfa2_1(active0, 0x200504014000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x5080500000000L, active1, 0x8L, active2, 0L);
       case 70:
       case 102:
-         if ((active0 & 0x80000L) != 0L)
-            return jjStartNfaWithStates_1(1, 19, 14);
+         if ((active0 & 0x800000L) != 0L)
+            return jjStartNfaWithStates_1(1, 23, 14);
          break;
       case 72:
       case 104:
-         return jjMoveStringLiteralDfa2_1(active0, 0xa000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x120000000000000L, active1, 0L, active2, 0L);
+      case 73:
+      case 105:
+         return jjMoveStringLiteralDfa2_1(active0, 0x10000000L, active1, 0L, active2, 0L);
       case 76:
       case 108:
-         return jjMoveStringLiteralDfa2_1(active0, 0x800000020310000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x803100000L, active1, 0x20L, active2, 0L);
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa2_1(active0, 0xb01000000a000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x1e00000280000000L, active1, 0x2c0L, active2, 0L);
       case 79:
       case 111:
-         if ((active0 & 0x8000000000L) != 0L)
+         if ((active0 & 0x100000000000L) != 0L)
          {
-            jjmatchedKind = 39;
+            jjmatchedKind = 44;
             jjmatchedPos = 1;
          }
-         return jjMoveStringLiteralDfa2_1(active0, 0x5800c3000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x2000c60000000000L, active1, 0x16L, active2, 0L);
       case 82:
       case 114:
+         if ((active1 & 0x100L) != 0L)
+            return jjStartNfaWithStates_1(1, 72, 14);
+         return jjMoveStringLiteralDfa2_1(active0, 0x4000002c000000L, active1, 0L, active2, 0L);
+      case 83:
+      case 115:
          if ((active0 & 0x4000000000000000L) != 0L)
             return jjStartNfaWithStates_1(1, 62, 14);
-         return jjMoveStringLiteralDfa2_1(active0, 0x4000400c00000L, active1, 0L);
+         break;
       case 84:
       case 116:
-         return jjMoveStringLiteralDfa2_1(active0, 0x20000040000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x8000001000000000L, active1, 0L, active2, 0L);
       case 85:
       case 117:
-         return jjMoveStringLiteralDfa2_1(active0, 0xa00000020000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0xa000000200000L, active1, 0L, active2, 0L);
       case 87:
       case 119:
-         return jjMoveStringLiteralDfa2_1(active0, 0x1000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x10000000000000L, active1, 0L, active2, 0L);
       case 88:
       case 120:
-         return jjMoveStringLiteralDfa2_1(active0, 0x10000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa2_1(active0, 0x200000000000L, active1, 0L, active2, 0L);
       case 124:
-         if ((active1 & 0x800000000L) != 0L)
-            return jjStopAtPos(1, 99);
+         if ((active1 & 0x800000000000000L) != 0L)
+            return jjStopAtPos(1, 123);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(0, active0, active1);
+   return jjStartNfa_1(0, active0, active1, active2);
 }
-static private final int jjMoveStringLiteralDfa2_1(long old0, long active0, long old1, long active1)
+static private final int jjMoveStringLiteralDfa2_1(long old0, long active0, long old1, long active1, long old2, long active2)
 {
-   if (((active0 &= old0) | (active1 &= old1)) == 0L)
-      return jjStartNfa_1(0, old0, old1); 
+   if (((active0 &= old0) | (active1 &= old1) | (active2 &= old2)) == 0L)
+      return jjStartNfa_1(0, old0, old1, old2); 
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(1, active0, active1);
+      jjStopStringLiteralDfa_1(1, active0, active1, active2);
       return 2;
    }
    switch(curChar)
    {
       case 61:
-         if ((active1 & 0x800000000000000L) != 0L)
-            return jjStopAtPos(2, 123);
-         else if ((active1 & 0x1000000000000000L) != 0L)
-            return jjStopAtPos(2, 124);
+         if ((active1 & 0x10000000000L) != 0L)
+            return jjStopAtPos(2, 104);
+         else if ((active1 & 0x20000000000L) != 0L)
+            return jjStopAtPos(2, 105);
+         else if ((active2 & 0x400L) != 0L)
+            return jjStopAtPos(2, 138);
+         else if ((active2 & 0x800L) != 0L)
+            return jjStopAtPos(2, 139);
          break;
       case 62:
-         if ((active1 & 0x2000000000000L) != 0L)
-         {
-            jjmatchedKind = 113;
-            jjmatchedPos = 2;
-         }
-         return jjMoveStringLiteralDfa3_1(active0, 0L, active1, 0x2000000000000000L);
+         if ((active2 & 0x200L) != 0L)
+            return jjStopAtPos(2, 137);
+         break;
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa3_1(active0, 0x200000040010000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x1000100000L, active1, 0x8L, active2, 0L);
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa3_1(active0, 0xa000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x280000000L, active1, 0L, active2, 0L);
       case 68:
       case 100:
-         if ((active0 & 0x8000000000000000L) != 0L)
-            return jjStartNfaWithStates_1(2, 63, 14);
-         return jjMoveStringLiteralDfa3_1(active0, 0x10000000000000L, active1, 0L);
+         if ((active1 & 0x200L) != 0L)
+            return jjStartNfaWithStates_1(2, 73, 14);
+         return jjMoveStringLiteralDfa3_1(active0, 0x1e00000000000000L, active1, 0L, active2, 0L);
       case 69:
       case 101:
-         return jjMoveStringLiteralDfa3_1(active0, 0x400000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x8000000L, active1, 0L, active2, 0L);
       case 70:
       case 102:
-         return jjMoveStringLiteralDfa3_1(active0, 0x4000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x80000000000L, active1, 0L, active2, 0L);
       case 72:
       case 104:
-         return jjMoveStringLiteralDfa3_1(active0, 0x1000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x40000000L, active1, 0L, active2, 0L);
       case 73:
       case 105:
-         return jjMoveStringLiteralDfa3_1(active0, 0xb000000800000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x130000020000000L, active1, 0L, active2, 0L);
       case 74:
       case 106:
-         return jjMoveStringLiteralDfa3_1(active0, 0x40000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0L, active1, 0x1L, active2, 0L);
       case 76:
       case 108:
-         return jjMoveStringLiteralDfa3_1(active0, 0x220000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x82000000000000L, active1, 0L, active2, 0L);
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa3_1(active0, 0x3000020000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x60000200000L, active1, 0L, active2, 0L);
       case 79:
       case 111:
-         return jjMoveStringLiteralDfa3_1(active0, 0x980000020000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x800000000L, active1, 0x26L, active2, 0L);
       case 80:
       case 112:
-         return jjMoveStringLiteralDfa3_1(active0, 0x800000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x8000000000000L, active1, 0L, active2, 0L);
       case 81:
       case 113:
-         return jjMoveStringLiteralDfa3_1(active0, 0x14000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x500000000L, active1, 0L, active2, 0L);
       case 82:
       case 114:
-         if ((active0 & 0x40000L) != 0L)
-            return jjStartNfaWithStates_1(2, 18, 14);
-         else if ((active0 & 0x40000000000L) != 0L)
-            return jjStartNfaWithStates_1(2, 42, 14);
-         return jjMoveStringLiteralDfa3_1(active0, 0x20000000400000L, active1, 0L);
+         if ((active0 & 0x400000L) != 0L)
+            return jjStartNfaWithStates_1(2, 22, 14);
+         else if ((active0 & 0x400000000000L) != 0L)
+         {
+            jjmatchedKind = 46;
+            jjmatchedPos = 2;
+         }
+         return jjMoveStringLiteralDfa3_1(active0, 0xa000000004000000L, active1, 0L, active2, 0L);
       case 83:
       case 115:
-         return jjMoveStringLiteralDfa3_1(active0, 0x800300000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x10013000000L, active1, 0L, active2, 0L);
       case 84:
       case 116:
-         if ((active0 & 0x1000000000000000L) != 0L)
+         if ((active1 & 0x40L) != 0L)
          {
-            jjmatchedKind = 60;
+            jjmatchedKind = 70;
             jjmatchedPos = 2;
          }
-         return jjMoveStringLiteralDfa3_1(active0, 0x2000490000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x4a00000000000L, active1, 0x80L, active2, 0L);
       case 85:
       case 117:
-         return jjMoveStringLiteralDfa3_1(active0, 0x404000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa3_1(active0, 0x40000000000000L, active1, 0x10L, active2, 0L);
       case 87:
       case 119:
-         if ((active0 & 0x100000000000L) != 0L)
-            return jjStartNfaWithStates_1(2, 44, 14);
+         if ((active0 & 0x1000000000000L) != 0L)
+            return jjStartNfaWithStates_1(2, 48, 14);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(1, active0, active1);
+   return jjStartNfa_1(1, active0, active1, active2);
 }
-static private final int jjMoveStringLiteralDfa3_1(long old0, long active0, long old1, long active1)
+static private final int jjMoveStringLiteralDfa3_1(long old0, long active0, long old1, long active1, long old2, long active2)
 {
-   if (((active0 &= old0) | (active1 &= old1)) == 0L)
-      return jjStartNfa_1(1, old0, old1); 
+   if (((active0 &= old0) | (active1 &= old1) | (active2 &= old2)) == 0L)
+      return jjStartNfa_1(1, old0, old1, old2); 
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(2, active0, active1);
+      jjStopStringLiteralDfa_1(2, active0, active1, 0L);
       return 3;
    }
    switch(curChar)
    {
-      case 61:
-         if ((active1 & 0x2000000000000000L) != 0L)
-            return jjStopAtPos(3, 125);
-         break;
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa4_1(active0, 0x800004400400000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x8000c000000L, active1, 0x20L);
       case 66:
       case 98:
-         return jjMoveStringLiteralDfa4_1(active0, 0x400000020000000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x800000000L, active1, 0x10L);
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa4_1(active0, 0x20000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x200000L, active1, 0L);
       case 69:
       case 101:
-         if ((active0 & 0x200000L) != 0L)
+         if ((active0 & 0x2000000L) != 0L)
          {
-            jjmatchedKind = 21;
+            jjmatchedKind = 25;
             jjmatchedPos = 3;
          }
-         else if ((active0 & 0x800000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 35, 14);
-         else if ((active0 & 0x4000000000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 50, 14);
-         return jjMoveStringLiteralDfa4_1(active0, 0x2040810000100000L, active1, 0L);
+         else if ((active0 & 0x10000000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 40, 14);
+         else if ((active0 & 0x40000000000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 54, 14);
+         return jjMoveStringLiteralDfa4_1(active0, 0x2008200001000000L, active1, 0x81L);
+      case 70:
+      case 102:
+         return jjMoveStringLiteralDfa4_1(active0, 0x1000000000000000L, active1, 0L);
       case 73:
       case 105:
-         return jjMoveStringLiteralDfa4_1(active0, 0x20000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x8800000000000000L, active1, 0L);
       case 76:
       case 108:
-         if ((active0 & 0x200000000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 45, 14);
-         else if ((active0 & 0x80000000000000L) != 0L)
+         if ((active0 & 0x2000000000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 49, 14);
+         else if ((active1 & 0x2L) != 0L)
          {
-            jjmatchedKind = 55;
+            jjmatchedKind = 65;
             jjmatchedPos = 3;
          }
-         else if ((active0 & 0x200000000000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 57, 14);
-         return jjMoveStringLiteralDfa4_1(active0, 0x10800000a000000L, active1, 0L);
+         else if ((active1 & 0x8L) != 0L)
+            return jjStartNfaWithStates_1(3, 67, 14);
+         return jjMoveStringLiteralDfa4_1(active0, 0x100000280000000L, active1, 0x4L);
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa4_1(active0, 0x800000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x20000000L, active1, 0L);
       case 79:
       case 111:
-         if ((active0 & 0x1000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 24, 14);
-         else if ((active0 & 0x80000000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 43, 14);
+         if ((active0 & 0x40000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 30, 14);
+         else if ((active0 & 0x800000000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 47, 14);
          break;
       case 83:
       case 115:
-         if ((active0 & 0x2000000000000L) != 0L)
-            return jjStartNfaWithStates_1(3, 49, 14);
-         return jjMoveStringLiteralDfa4_1(active0, 0x21000010000L, active1, 0L);
+         if ((active0 & 0x20000000000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 53, 14);
+         return jjMoveStringLiteralDfa4_1(active0, 0x480020000100000L, active1, 0L);
       case 84:
       case 116:
-         return jjMoveStringLiteralDfa4_1(active0, 0x1002040000000L, active1, 0L);
+         if ((active0 & 0x10000000L) != 0L)
+            return jjStartNfaWithStates_1(3, 28, 14);
+         return jjMoveStringLiteralDfa4_1(active0, 0x10041000000000L, active1, 0L);
       case 85:
       case 117:
-         return jjMoveStringLiteralDfa4_1(active0, 0x400014000000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x4000500000000L, active1, 0L);
       case 87:
       case 119:
-         return jjMoveStringLiteralDfa4_1(active0, 0x10000000000000L, active1, 0L);
+         return jjMoveStringLiteralDfa4_1(active0, 0x200000000000000L, active1, 0L);
       default :
          break;
    }
-   return jjStartNfa_1(2, active0, active1);
+   return jjStartNfa_1(2, active0, active1, 0L);
 }
 static private final int jjMoveStringLiteralDfa4_1(long old0, long active0, long old1, long active1)
 {
    if (((active0 &= old0) | (active1 &= old1)) == 0L)
-      return jjStartNfa_1(2, old0, old1); 
+      return jjStartNfa_1(2, old0, old1, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(3, active0, 0L);
+      jjStopStringLiteralDfa_1(3, active0, active1, 0L);
       return 4;
    }
    switch(curChar)
    {
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa5_1(active0, 0x20000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x2000000800000000L, active1, 0L);
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa5_1(active0, 0x41000000000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x10000000000000L, active1, 0x1L);
       case 69:
       case 101:
-         if ((active0 & 0x20000000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 41, 14);
-         else if ((active0 & 0x8000000000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 51, 14);
-         return jjMoveStringLiteralDfa5_1(active0, 0x100000000000000L);
+         if ((active0 & 0x80000000000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 55, 14);
+         else if ((active0 & 0x100000000000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 56, 14);
+         return jjMoveStringLiteralDfa5_1(active0, 0L, active1, 0x4L);
+      case 70:
+      case 102:
+         if ((active0 & 0x800000000000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 59, 14);
+         break;
       case 71:
       case 103:
-         return jjMoveStringLiteralDfa5_1(active0, 0x2000000000000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0L, active1, 0x80L);
       case 72:
       case 104:
-         return jjMoveStringLiteralDfa5_1(active0, 0x10000000000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x200000000000000L, active1, 0L);
       case 73:
       case 105:
-         return jjMoveStringLiteralDfa5_1(active0, 0x2054100000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x41501000000L, active1, 0L);
       case 75:
       case 107:
-         if ((active0 & 0x400000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 34, 14);
+         if ((active0 & 0x8000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 27, 14);
          break;
       case 76:
       case 108:
-         return jjMoveStringLiteralDfa5_1(active0, 0x400000000000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0L, active1, 0x10L);
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa5_1(active0, 0x20010000000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x8000200000000000L, active1, 0L);
+      case 79:
+      case 111:
+         return jjMoveStringLiteralDfa5_1(active0, 0x1000000000000000L, active1, 0L);
       case 82:
       case 114:
-         if ((active0 & 0x800000000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 47, 14);
-         return jjMoveStringLiteralDfa5_1(active0, 0x400000000000L);
+         if ((active0 & 0x8000000000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 51, 14);
+         return jjMoveStringLiteralDfa5_1(active0, 0x4000000000000L, active1, 0L);
       case 83:
       case 115:
-         if ((active0 & 0x10000L) != 0L)
-            return jjStartNfaWithStates_1(4, 16, 14);
+         if ((active0 & 0x100000L) != 0L)
+            return jjStartNfaWithStates_1(4, 20, 14);
          break;
       case 84:
       case 116:
-         if ((active0 & 0x800000L) != 0L)
-            return jjStartNfaWithStates_1(4, 23, 14);
-         else if ((active0 & 0x1000000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 36, 14);
-         else if ((active0 & 0x800000000000000L) != 0L)
-            return jjStartNfaWithStates_1(4, 59, 14);
-         return jjMoveStringLiteralDfa5_1(active0, 0x20000L);
+         if ((active0 & 0x20000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 29, 14);
+         else if ((active0 & 0x20000000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 41, 14);
+         else if ((active1 & 0x20L) != 0L)
+            return jjStartNfaWithStates_1(4, 69, 14);
+         return jjMoveStringLiteralDfa5_1(active0, 0x200000L, active1, 0L);
       case 85:
       case 117:
-         return jjMoveStringLiteralDfa5_1(active0, 0x400a000000L);
+         return jjMoveStringLiteralDfa5_1(active0, 0x80280000000L, active1, 0L);
+      case 87:
+      case 119:
+         return jjMoveStringLiteralDfa5_1(active0, 0x400000000000000L, active1, 0L);
       case 89:
       case 121:
-         if ((active0 & 0x400000L) != 0L)
-            return jjStartNfaWithStates_1(4, 22, 14);
+         if ((active0 & 0x4000000L) != 0L)
+            return jjStartNfaWithStates_1(4, 26, 14);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(3, active0, 0L);
+   return jjStartNfa_1(3, active0, active1, 0L);
 }
-static private final int jjMoveStringLiteralDfa5_1(long old0, long active0)
+static private final int jjMoveStringLiteralDfa5_1(long old0, long active0, long old1, long active1)
 {
-   if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(3, old0, 0L);
+   if (((active0 &= old0) | (active1 &= old1)) == 0L)
+      return jjStartNfa_1(3, old0, old1, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(4, active0, 0L);
+      jjStopStringLiteralDfa_1(4, active0, active1, 0L);
       return 5;
    }
    switch(curChar)
    {
       case 65:
       case 97:
-         return jjMoveStringLiteralDfa6_1(active0, 0x100000000000000L);
+         return jjMoveStringLiteralDfa6_1(active0, 0L, active1, 0x4L);
       case 67:
       case 99:
-         if ((active0 & 0x40000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 30, 14);
-         break;
+         if ((active0 & 0x1000000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 36, 14);
+         return jjMoveStringLiteralDfa6_1(active0, 0x2000000000000000L, active1, 0L);
       case 68:
       case 100:
-         return jjMoveStringLiteralDfa6_1(active0, 0x1000a000000L);
+         return jjMoveStringLiteralDfa6_1(active0, 0x200280000000L, active1, 0L);
       case 69:
       case 101:
-         if ((active0 & 0x400000000000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 58, 14);
-         return jjMoveStringLiteralDfa6_1(active0, 0x2000000000000000L);
+         if ((active1 & 0x10L) != 0L)
+            return jjStartNfaWithStates_1(5, 68, 14);
+         return jjMoveStringLiteralDfa6_1(active0, 0L, active1, 0x80L);
       case 70:
       case 102:
-         if ((active0 & 0x100000L) != 0L)
-            return jjStartNfaWithStates_1(5, 20, 14);
+         if ((active0 & 0x1000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 24, 14);
          break;
       case 71:
       case 103:
-         if ((active0 & 0x20000000000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 53, 14);
+         if ((active0 & 0x8000000000000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 63, 14);
          break;
       case 72:
       case 104:
-         if ((active0 & 0x1000000000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 48, 14);
+         if ((active0 & 0x10000000000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 52, 14);
          break;
       case 73:
       case 105:
-         return jjMoveStringLiteralDfa6_1(active0, 0x10000000020000L);
+         return jjMoveStringLiteralDfa6_1(active0, 0x600000000200000L, active1, 0L);
       case 76:
       case 108:
-         if ((active0 & 0x20000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 29, 14);
-         return jjMoveStringLiteralDfa6_1(active0, 0x4000000000L);
+         if ((active0 & 0x800000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 35, 14);
+         return jjMoveStringLiteralDfa6_1(active0, 0x80000000000L, active1, 0L);
       case 78:
       case 110:
-         if ((active0 & 0x400000000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 46, 14);
-         return jjMoveStringLiteralDfa6_1(active0, 0x2000000000L);
+         if ((active0 & 0x4000000000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 50, 14);
+         return jjMoveStringLiteralDfa6_1(active0, 0x40000000000L, active1, 0L);
       case 82:
       case 114:
-         return jjMoveStringLiteralDfa6_1(active0, 0x14000000L);
+         if ((active0 & 0x1000000000000000L) != 0L)
+            return jjStartNfaWithStates_1(5, 60, 14);
+         return jjMoveStringLiteralDfa6_1(active0, 0x500000000L, active1, 0L);
       case 84:
       case 116:
-         if ((active0 & 0x40000000000000L) != 0L)
-            return jjStartNfaWithStates_1(5, 54, 14);
+         if ((active1 & 0x1L) != 0L)
+            return jjStartNfaWithStates_1(5, 64, 14);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(4, active0, 0L);
+   return jjStartNfa_1(4, active0, active1, 0L);
 }
-static private final int jjMoveStringLiteralDfa6_1(long old0, long active0)
+static private final int jjMoveStringLiteralDfa6_1(long old0, long active0, long old1, long active1)
 {
-   if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(4, old0, 0L);
+   if (((active0 &= old0) | (active1 &= old1)) == 0L)
+      return jjStartNfa_1(4, old0, old1, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(5, active0, 0L);
+      jjStopStringLiteralDfa_1(5, active0, active1, 0L);
       return 6;
    }
    switch(curChar)
    {
       case 69:
       case 101:
-         if ((active0 & 0x2000000L) != 0L)
+         if ((active0 & 0x80000000L) != 0L)
          {
-            jjmatchedKind = 25;
+            jjmatchedKind = 31;
             jjmatchedPos = 6;
          }
-         else if ((active0 & 0x4000000L) != 0L)
+         else if ((active0 & 0x100000000L) != 0L)
          {
-            jjmatchedKind = 26;
+            jjmatchedKind = 32;
             jjmatchedPos = 6;
          }
-         return jjMoveStringLiteralDfa7_1(active0, 0x18000000L);
+         return jjMoveStringLiteralDfa7_1(active0, 0x600000000L, active1, 0L);
+      case 72:
+      case 104:
+         if ((active0 & 0x2000000000000000L) != 0L)
+            return jjStartNfaWithStates_1(6, 61, 14);
+         break;
       case 76:
       case 108:
-         return jjMoveStringLiteralDfa7_1(active0, 0x10000000000000L);
+         return jjMoveStringLiteralDfa7_1(active0, 0x200000000000000L, active1, 0L);
       case 78:
       case 110:
-         if ((active0 & 0x100000000000000L) != 0L)
-            return jjStartNfaWithStates_1(6, 56, 14);
+         if ((active1 & 0x4L) != 0L)
+            return jjStartNfaWithStates_1(6, 66, 14);
          break;
       case 79:
       case 111:
-         return jjMoveStringLiteralDfa7_1(active0, 0x20000L);
+         return jjMoveStringLiteralDfa7_1(active0, 0x200000L, active1, 0L);
       case 82:
       case 114:
-         if ((active0 & 0x2000000000000000L) != 0L)
-            return jjStartNfaWithStates_1(6, 61, 14);
+         if ((active1 & 0x80L) != 0L)
+            return jjStartNfaWithStates_1(6, 71, 14);
          break;
       case 83:
       case 115:
-         if ((active0 & 0x10000000000L) != 0L)
-            return jjStartNfaWithStates_1(6, 40, 14);
+         if ((active0 & 0x200000000000L) != 0L)
+            return jjStartNfaWithStates_1(6, 45, 14);
          break;
       case 84:
       case 116:
-         if ((active0 & 0x4000000000L) != 0L)
-            return jjStartNfaWithStates_1(6, 38, 14);
-         break;
+         if ((active0 & 0x80000000000L) != 0L)
+            return jjStartNfaWithStates_1(6, 43, 14);
+         return jjMoveStringLiteralDfa7_1(active0, 0x400000000000000L, active1, 0L);
       case 85:
       case 117:
-         return jjMoveStringLiteralDfa7_1(active0, 0x2000000000L);
+         return jjMoveStringLiteralDfa7_1(active0, 0x40000000000L, active1, 0L);
       default :
          break;
    }
-   return jjStartNfa_1(5, active0, 0L);
+   return jjStartNfa_1(5, active0, active1, 0L);
 }
-static private final int jjMoveStringLiteralDfa7_1(long old0, long active0)
+static private final int jjMoveStringLiteralDfa7_1(long old0, long active0, long old1, long active1)
 {
-   if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(5, old0, 0L);
+   if (((active0 &= old0) | (active1 &= old1)) == 0L)
+      return jjStartNfa_1(5, old0, old1, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(6, active0, 0L);
+      jjStopStringLiteralDfa_1(6, active0, 0L, 0L);
       return 7;
    }
    switch(curChar)
    {
       case 95:
-         return jjMoveStringLiteralDfa8_1(active0, 0x18000000L);
+         return jjMoveStringLiteralDfa8_1(active0, 0x600000000L);
+      case 67:
+      case 99:
+         return jjMoveStringLiteralDfa8_1(active0, 0x400000000000000L);
       case 69:
       case 101:
-         if ((active0 & 0x2000000000L) != 0L)
-            return jjStartNfaWithStates_1(7, 37, 14);
-         else if ((active0 & 0x10000000000000L) != 0L)
-            return jjStartNfaWithStates_1(7, 52, 14);
+         if ((active0 & 0x40000000000L) != 0L)
+            return jjStartNfaWithStates_1(7, 42, 14);
+         else if ((active0 & 0x200000000000000L) != 0L)
+            return jjStartNfaWithStates_1(7, 57, 14);
          break;
       case 78:
       case 110:
-         if ((active0 & 0x20000L) != 0L)
-            return jjStartNfaWithStates_1(7, 17, 14);
+         if ((active0 & 0x200000L) != 0L)
+            return jjStartNfaWithStates_1(7, 21, 14);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(6, active0, 0L);
+   return jjStartNfa_1(6, active0, 0L, 0L);
 }
 static private final int jjMoveStringLiteralDfa8_1(long old0, long active0)
 {
    if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(6, old0, 0L);
+      return jjStartNfa_1(6, old0, 0L, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(7, active0, 0L);
+      jjStopStringLiteralDfa_1(7, active0, 0L, 0L);
       return 8;
    }
    switch(curChar)
    {
+      case 72:
+      case 104:
+         if ((active0 & 0x400000000000000L) != 0L)
+            return jjStartNfaWithStates_1(8, 58, 14);
+         break;
       case 79:
       case 111:
-         return jjMoveStringLiteralDfa9_1(active0, 0x18000000L);
+         return jjMoveStringLiteralDfa9_1(active0, 0x600000000L);
       default :
          break;
    }
-   return jjStartNfa_1(7, active0, 0L);
+   return jjStartNfa_1(7, active0, 0L, 0L);
 }
 static private final int jjMoveStringLiteralDfa9_1(long old0, long active0)
 {
    if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(7, old0, 0L);
+      return jjStartNfa_1(7, old0, 0L, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(8, active0, 0L);
+      jjStopStringLiteralDfa_1(8, active0, 0L, 0L);
       return 9;
    }
    switch(curChar)
    {
       case 78:
       case 110:
-         return jjMoveStringLiteralDfa10_1(active0, 0x18000000L);
+         return jjMoveStringLiteralDfa10_1(active0, 0x600000000L);
       default :
          break;
    }
-   return jjStartNfa_1(8, active0, 0L);
+   return jjStartNfa_1(8, active0, 0L, 0L);
 }
 static private final int jjMoveStringLiteralDfa10_1(long old0, long active0)
 {
    if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(8, old0, 0L);
+      return jjStartNfa_1(8, old0, 0L, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(9, active0, 0L);
+      jjStopStringLiteralDfa_1(9, active0, 0L, 0L);
       return 10;
    }
    switch(curChar)
    {
       case 67:
       case 99:
-         return jjMoveStringLiteralDfa11_1(active0, 0x18000000L);
+         return jjMoveStringLiteralDfa11_1(active0, 0x600000000L);
       default :
          break;
    }
-   return jjStartNfa_1(9, active0, 0L);
+   return jjStartNfa_1(9, active0, 0L, 0L);
 }
 static private final int jjMoveStringLiteralDfa11_1(long old0, long active0)
 {
    if (((active0 &= old0)) == 0L)
-      return jjStartNfa_1(9, old0, 0L);
+      return jjStartNfa_1(9, old0, 0L, 0L);
    try { curChar = input_stream.readChar(); }
    catch(java.io.IOException e) {
-      jjStopStringLiteralDfa_1(10, active0, 0L);
+      jjStopStringLiteralDfa_1(10, active0, 0L, 0L);
       return 11;
    }
    switch(curChar)
    {
       case 69:
       case 101:
-         if ((active0 & 0x8000000L) != 0L)
-            return jjStartNfaWithStates_1(11, 27, 14);
-         else if ((active0 & 0x10000000L) != 0L)
-            return jjStartNfaWithStates_1(11, 28, 14);
+         if ((active0 & 0x200000000L) != 0L)
+            return jjStartNfaWithStates_1(11, 33, 14);
+         else if ((active0 & 0x400000000L) != 0L)
+            return jjStartNfaWithStates_1(11, 34, 14);
          break;
       default :
          break;
    }
-   return jjStartNfa_1(10, active0, 0L);
+   return jjStartNfa_1(10, active0, 0L, 0L);
 }
 static final long[] jjbitVec0 = {
    0x0L, 0x0L, 0xffffffffffffffffL, 0xffffffffffffffffL
@@ -1203,7 +1251,7 @@ static private final int jjMoveNfa_1(int startState, int curPos)
 {
    int[] nextStates;
    int startsAt = 0;
-   jjnewStateCnt = 64;
+   jjnewStateCnt = 70;
    int i = 1;
    jjstateSet[0] = startState;
    int j, kind = 0x7fffffff;
@@ -1220,11 +1268,11 @@ static private final int jjMoveNfa_1(int startState, int curPos)
             {
                case 3:
                   if ((0x3ff000000000000L & l) != 0L)
-                     jjCheckNAddStates(2, 8);
+                     jjCheckNAddStates(0, 6);
                   else if (curChar == 39)
-                     jjCheckNAddStates(9, 14);
+                     jjCheckNAddStates(7, 12);
                   else if (curChar == 34)
-                     jjCheckNAddStates(15, 20);
+                     jjCheckNAddStates(13, 20);
                   else if (curChar == 36)
                      jjstateSet[jjnewStateCnt++] = 16;
                   else if (curChar == 46)
@@ -1233,14 +1281,14 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                      jjstateSet[jjnewStateCnt++] = 2;
                   if ((0x3fe000000000000L & l) != 0L)
                   {
-                     if (kind > 64)
-                        kind = 64;
+                     if (kind > 74)
+                        kind = 74;
                      jjCheckNAddTwoStates(5, 6);
                   }
                   else if (curChar == 48)
                   {
-                     if (kind > 64)
-                        kind = 64;
+                     if (kind > 74)
+                        kind = 74;
                      jjCheckNAddStates(21, 23);
                   }
                   break;
@@ -1249,8 +1297,8 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                      jjstateSet[jjnewStateCnt++] = 1;
                   break;
                case 1:
-                  if ((0xffff7fffffffffffL & l) != 0L && kind > 10)
-                     kind = 10;
+                  if ((0xffff7fffffffffffL & l) != 0L && kind > 13)
+                     kind = 13;
                   break;
                case 2:
                   if (curChar == 42)
@@ -1259,15 +1307,15 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 4:
                   if ((0x3fe000000000000L & l) == 0L)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddTwoStates(5, 6);
                   break;
                case 5:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddTwoStates(5, 6);
                   break;
                case 7:
@@ -1277,8 +1325,8 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 8:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddStates(24, 26);
                   break;
                case 10:
@@ -1288,15 +1336,15 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 11:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddTwoStates(11, 12);
                   break;
                case 14:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 74)
-                     kind = 74;
+                  if (kind > 84)
+                     kind = 84;
                   jjstateSet[jjnewStateCnt++] = 14;
                   break;
                case 15:
@@ -1306,13 +1354,13 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 17:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 126)
-                     kind = 126;
+                  if (kind > 140)
+                     kind = 140;
                   jjstateSet[jjnewStateCnt++] = 17;
                   break;
                case 18:
                   if ((0x3ff000000000000L & l) != 0L)
-                     jjCheckNAddStates(2, 8);
+                     jjCheckNAddStates(0, 6);
                   break;
                case 19:
                   if ((0x3ff000000000000L & l) != 0L)
@@ -1321,15 +1369,15 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 20:
                   if (curChar != 46)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddStates(27, 29);
                   break;
                case 21:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddStates(27, 29);
                   break;
                case 23:
@@ -1339,8 +1387,8 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 24:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddTwoStates(24, 12);
                   break;
                case 25:
@@ -1354,8 +1402,8 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 28:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 68)
-                     kind = 68;
+                  if (kind > 78)
+                     kind = 78;
                   jjCheckNAddTwoStates(28, 12);
                   break;
                case 29:
@@ -1373,85 +1421,93 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 33:
                   if (curChar != 48)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddStates(21, 23);
                   break;
                case 35:
                   if ((0x3ff000000000000L & l) == 0L)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddTwoStates(35, 6);
                   break;
                case 36:
                   if ((0xff000000000000L & l) == 0L)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddTwoStates(36, 6);
                   break;
                case 37:
                   if (curChar == 34)
-                     jjCheckNAddStates(15, 20);
+                     jjCheckNAddStates(13, 20);
                   break;
                case 38:
                   if ((0xfffffffbffffffffL & l) != 0L)
-                     jjCheckNAddStates(33, 35);
+                     jjCheckNAddStates(33, 36);
                   break;
                case 39:
                   if (curChar == 34)
-                     jjCheckNAddStates(33, 35);
-                  break;
-               case 41:
-                  if (curChar == 34 && kind > 70)
-                     kind = 70;
+                     jjCheckNAddStates(33, 36);
                   break;
                case 42:
                   if ((0xfffffffbffffffffL & l) != 0L)
-                     jjCheckNAddStates(36, 38);
+                     jjstateSet[jjnewStateCnt++] = 43;
                   break;
-               case 43:
-                  if (curChar == 34)
-                     jjCheckNAddStates(36, 38);
+               case 44:
+                  if (curChar == 34 && kind > 80)
+                     kind = 80;
                   break;
                case 45:
-                  if (curChar == 34 && kind > 71)
-                     kind = 71;
+                  if ((0xfffffffbffffffffL & l) != 0L)
+                     jjCheckNAddStates(37, 40);
                   break;
                case 46:
+                  if (curChar == 34)
+                     jjCheckNAddStates(37, 40);
+                  break;
+               case 49:
+                  if ((0xfffffffbffffffffL & l) != 0L)
+                     jjstateSet[jjnewStateCnt++] = 50;
+                  break;
+               case 51:
+                  if (curChar == 34 && kind > 81)
+                     kind = 81;
+                  break;
+               case 52:
                   if (curChar == 39)
-                     jjCheckNAddStates(9, 14);
+                     jjCheckNAddStates(7, 12);
                   break;
-               case 47:
+               case 53:
                   if ((0xffffff7fffffffffL & l) != 0L)
-                     jjCheckNAddStates(39, 41);
+                     jjCheckNAddStates(41, 43);
                   break;
-               case 48:
+               case 54:
                   if (curChar == 39)
-                     jjCheckNAddStates(39, 41);
+                     jjCheckNAddStates(41, 43);
                   break;
-               case 50:
-                  if (curChar == 39 && kind > 70)
-                     kind = 70;
+               case 56:
+                  if (curChar == 39 && kind > 80)
+                     kind = 80;
                   break;
-               case 51:
+               case 57:
                   if ((0xffffff7fffffffffL & l) != 0L)
-                     jjCheckNAddStates(42, 44);
+                     jjCheckNAddStates(44, 46);
                   break;
-               case 52:
+               case 58:
                   if (curChar == 39)
-                     jjCheckNAddStates(42, 44);
+                     jjCheckNAddStates(44, 46);
                   break;
-               case 54:
-                  if (curChar == 39 && kind > 72)
-                     kind = 72;
+               case 60:
+                  if (curChar == 39 && kind > 82)
+                     kind = 82;
                   break;
-               case 56:
-                  jjAddStates(45, 47);
+               case 62:
+                  jjAddStates(47, 49);
                   break;
-               case 60:
-                  jjAddStates(48, 50);
+               case 66:
+                  jjAddStates(50, 52);
                   break;
                default : break;
             }
@@ -1465,58 +1521,58 @@ static private final int jjMoveNfa_1(int startState, int curPos)
             switch(jjstateSet[--i])
             {
                case 3:
-                  if ((0x7fffffe87fffffeL & l) != 0L)
+                  if ((0x87fffffe87fffffeL & l) != 0L)
                   {
-                     if (kind > 74)
-                        kind = 74;
+                     if (kind > 84)
+                        kind = 84;
                      jjCheckNAdd(14);
                   }
                   else if (curChar == 96)
-                     jjCheckNAddStates(51, 56);
+                     jjCheckNAddStates(53, 58);
                   break;
                case 1:
-                  if (kind > 10)
-                     kind = 10;
+                  if (kind > 13)
+                     kind = 13;
                   break;
                case 6:
-                  if ((0x100000001000L & l) != 0L && kind > 64)
-                     kind = 64;
+                  if ((0x100000001000L & l) != 0L && kind > 74)
+                     kind = 74;
                   break;
                case 9:
                   if ((0x2000000020L & l) != 0L)
-                     jjAddStates(57, 58);
+                     jjAddStates(59, 60);
                   break;
                case 12:
-                  if ((0x5000000050L & l) != 0L && kind > 68)
-                     kind = 68;
+                  if ((0x5000000050L & l) != 0L && kind > 78)
+                     kind = 78;
                   break;
                case 13:
                case 14:
-                  if ((0x7fffffe87fffffeL & l) == 0L)
+                  if ((0x87fffffe87fffffeL & l) == 0L)
                      break;
-                  if (kind > 74)
-                     kind = 74;
+                  if (kind > 84)
+                     kind = 84;
                   jjCheckNAdd(14);
                   break;
                case 16:
                case 17:
-                  if ((0x7fffffe87fffffeL & l) == 0L)
+                  if ((0x87fffffe87fffffeL & l) == 0L)
                      break;
-                  if (kind > 126)
-                     kind = 126;
+                  if (kind > 140)
+                     kind = 140;
                   jjCheckNAdd(17);
                   break;
                case 22:
                   if ((0x2000000020L & l) != 0L)
-                     jjAddStates(59, 60);
+                     jjAddStates(61, 62);
                   break;
                case 26:
                   if ((0x2000000020L & l) != 0L)
-                     jjAddStates(61, 62);
+                     jjAddStates(63, 64);
                   break;
                case 30:
                   if ((0x2000000020L & l) != 0L)
-                     jjAddStates(63, 64);
+                     jjAddStates(65, 66);
                   break;
                case 34:
                   if ((0x100000001000000L & l) != 0L)
@@ -1525,73 +1581,97 @@ static private final int jjMoveNfa_1(int startState, int curPos)
                case 35:
                   if ((0x7e0000007eL & l) == 0L)
                      break;
-                  if (kind > 64)
-                     kind = 64;
+                  if (kind > 74)
+                     kind = 74;
                   jjCheckNAddTwoStates(35, 6);
                   break;
                case 38:
-                  jjAddStates(33, 35);
+                  if ((0xd7ffffffffffffffL & l) != 0L)
+                     jjCheckNAddStates(33, 36);
                   break;
                case 40:
                   if (curChar == 92)
                      jjstateSet[jjnewStateCnt++] = 39;
                   break;
+               case 41:
+                  if (curChar == 123)
+                     jjstateSet[jjnewStateCnt++] = 42;
+                  break;
                case 42:
-                  jjAddStates(36, 38);
+                  jjstateSet[jjnewStateCnt++] = 43;
                   break;
-               case 44:
-                  if (curChar == 92)
-                     jjstateSet[jjnewStateCnt++] = 43;
+               case 43:
+                  if (curChar == 125)
+                     jjCheckNAddStates(33, 36);
+                  break;
+               case 45:
+                  if ((0xd7ffffffffffffffL & l) != 0L)
+                     jjCheckNAddStates(37, 40);
                   break;
                case 47:
-                  jjAddStates(39, 41);
+                  if (curChar == 92)
+                     jjstateSet[jjnewStateCnt++] = 46;
+                  break;
+               case 48:
+                  if (curChar == 123)
+                     jjstateSet[jjnewStateCnt++] = 49;
                   break;
                case 49:
-                  if (curChar == 92)
-                     jjstateSet[jjnewStateCnt++] = 48;
+                  jjstateSet[jjnewStateCnt++] = 50;
                   break;
-               case 51:
-                  jjAddStates(42, 44);
+               case 50:
+                  if (curChar == 125)
+                     jjCheckNAddStates(37, 40);
                   break;
                case 53:
-                  if (curChar == 92)
-                     jjstateSet[jjnewStateCnt++] = 52;
+                  jjAddStates(41, 43);
                   break;
                case 55:
+                  if (curChar == 92)
+                     jjstateSet[jjnewStateCnt++] = 54;
+                  break;
+               case 57:
+                  jjAddStates(44, 46);
+                  break;
+               case 59:
+                  if (curChar == 92)
+                     jjstateSet[jjnewStateCnt++] = 58;
+                  break;
+               case 61:
                   if (curChar == 96)
-                     jjCheckNAddStates(51, 56);
+                     jjCheckNAddStates(53, 58);
                   break;
-               case 56:
+               case 62:
                   if ((0xfffffffeffffffffL & l) != 0L)
-                     jjCheckNAddStates(45, 47);
+                     jjCheckNAddStates(47, 49);
                   break;
-               case 57:
+               case 63:
                   if (curChar == 96)
-                     jjCheckNAddStates(45, 47);
+                     jjCheckNAddStates(47, 49);
                   break;
-               case 58:
+               case 64:
                   if (curChar == 92)
-                     jjstateSet[jjnewStateCnt++] = 57;
+                     jjstateSet[jjnewStateCnt++] = 63;
                   break;
-               case 59:
-                  if (curChar == 96 && kind > 70)
-                     kind = 70;
+               case 65:
+                  if (curChar == 96 && kind > 80)
+                     kind = 80;
                   break;
-               case 60:
+               case 66:
                   if ((0xfffffffeffffffffL & l) != 0L)
-                     jjCheckNAddStates(48, 50);
+                     jjCheckNAddStates(50, 52);
                   break;
-               case 61:
+               case 67:
                   if (curChar == 96)
-                     jjCheckNAddStates(48, 50);
+                     jjCheckNAddStates(50, 52);
                   break;
-               case 62:
+               case 68:
                   if (curChar == 92)
-                     jjstateSet[jjnewStateCnt++] = 61;
+                     jjstateSet[jjnewStateCnt++] = 67;
                   break;
-               case 63:
-                  if (curChar == 96 && kind > 73)
-                     kind = 73;
+               case 69:
+                  if (curChar == 96 && kind > 83)
+                     kind = 83;
                   break;
                default : break;
             }
@@ -1605,33 +1685,57 @@ static private final int jjMoveNfa_1(int startState, int curPos)
          {
             switch(jjstateSet[--i])
             {
+               case 3:
+               case 14:
+                  if ((jjbitVec0[i2] & l2) == 0L)
+                     break;
+                  if (kind > 84)
+                     kind = 84;
+                  jjCheckNAdd(14);
+                  break;
                case 1:
-                  if ((jjbitVec0[i2] & l2) != 0L && kind > 10)
-                     kind = 10;
+                  if ((jjbitVec0[i2] & l2) != 0L && kind > 13)
+                     kind = 13;
+                  break;
+               case 16:
+               case 17:
+                  if ((jjbitVec0[i2] & l2) == 0L)
+                     break;
+                  if (kind > 140)
+                     kind = 140;
+                  jjCheckNAdd(17);
                   break;
                case 38:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(33, 35);
+                     jjAddStates(33, 36);
                   break;
                case 42:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(36, 38);
+                     jjstateSet[jjnewStateCnt++] = 43;
                   break;
-               case 47:
+               case 45:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(39, 41);
+                     jjAddStates(37, 40);
                   break;
-               case 51:
+               case 49:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(42, 44);
+                     jjstateSet[jjnewStateCnt++] = 50;
                   break;
-               case 56:
+               case 53:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(45, 47);
+                     jjAddStates(41, 43);
                   break;
-               case 60:
+               case 57:
                   if ((jjbitVec0[i2] & l2) != 0L)
-                     jjAddStates(48, 50);
+                     jjAddStates(44, 46);
+                  break;
+               case 62:
+                  if ((jjbitVec0[i2] & l2) != 0L)
+                     jjAddStates(47, 49);
+                  break;
+               case 66:
+                  if ((jjbitVec0[i2] & l2) != 0L)
+                     jjAddStates(50, 52);
                   break;
                default : break;
             }
@@ -1644,7 +1748,7 @@ static private final int jjMoveNfa_1(int startState, int curPos)
          kind = 0x7fffffff;
       }
       ++curPos;
-      if ((i = jjnewStateCnt) == (startsAt = 64 - (jjnewStateCnt = startsAt)))
+      if ((i = jjnewStateCnt) == (startsAt = 70 - (jjnewStateCnt = startsAt)))
          return curPos;
       try { curChar = input_stream.readChar(); }
       catch(java.io.IOException e) { return curPos; }
@@ -1655,7 +1759,7 @@ static private final int jjMoveStringLiteralDfa0_3()
    switch(curChar)
    {
       case 42:
-         return jjMoveStringLiteralDfa1_3(0x2000L);
+         return jjMoveStringLiteralDfa1_3(0x20000L);
       default :
          return 1;
    }
@@ -1669,8 +1773,8 @@ static private final int jjMoveStringLiteralDfa1_3(long active0)
    switch(curChar)
    {
       case 47:
-         if ((active0 & 0x2000L) != 0L)
-            return jjStopAtPos(1, 13);
+         if ((active0 & 0x20000L) != 0L)
+            return jjStopAtPos(1, 17);
          break;
       default :
          return 2;
@@ -1678,25 +1782,26 @@ static private final int jjMoveStringLiteralDfa1_3(long active0)
    return 2;
 }
 static final int[] jjnextStates = {
-   4, 5, 19, 20, 25, 26, 29, 30, 12, 47, 49, 50, 51, 53, 54, 38, 
-   40, 41, 42, 44, 45, 34, 36, 6, 8, 9, 12, 21, 22, 12, 29, 30, 
-   12, 38, 40, 41, 42, 44, 45, 47, 49, 50, 51, 53, 54, 56, 58, 59, 
-   60, 62, 63, 56, 58, 59, 60, 62, 63, 10, 11, 23, 24, 27, 28, 31, 
-   32, 
+   19, 20, 25, 26, 29, 30, 12, 53, 55, 56, 57, 59, 60, 38, 40, 41, 
+   44, 45, 47, 48, 51, 34, 36, 6, 8, 9, 12, 21, 22, 12, 29, 30, 
+   12, 38, 40, 41, 44, 45, 47, 48, 51, 53, 55, 56, 57, 59, 60, 62, 
+   64, 65, 66, 68, 69, 62, 64, 65, 66, 68, 69, 10, 11, 23, 24, 27, 
+   28, 31, 32, 
 };
 public static final String[] jjstrLiteralImages = {
-"", null, "\77\76", null, null, null, null, null, null, null, null, null, null, 
+"", "\74\77", null, "\74\77\75", "\77\76", null, null, null, null, null, null, 
 null, null, null, null, null, null, null, null, null, null, null, null, null, null, 
-null, null, null, null, "\55\76", "\72\72", "\75\76", null, null, null, null, null, 
+null, null, null, null, null, null, null, null, null, null, null, null, "\55\76", 
+"\72\72", "\75\76", null, null, null, null, null, null, null, null, null, null, null, 
 null, null, null, null, null, null, null, null, null, null, null, null, null, null, 
 null, null, null, null, null, null, null, null, null, null, null, null, null, null, 
-null, null, null, null, null, null, null, null, null, null, null, "\50", "\51", 
-"\173", "\175", "\133", "\135", "\73", "\54", "\56", "\100", "\44", "\75", "\76", 
-"\74", "\41", "\77", "\72", "\75\75", "\74\75", "\76\75", "\41\75", "\174\174", 
-"\46\46", "\53\53", "\55\55", "\53", "\55", "\52", "\57", "\46", "\174", "\136", "\45", 
-"\74\74", "\76\76", "\76\76\76", "\53\75", "\55\75", "\52\75", "\57\75", "\46\75", 
-"\174\75", "\136\75", "\56\75", "\45\75", "\74\74\75", "\76\76\75", "\76\76\76\75", null, 
-"\77\76", };
+null, null, null, null, null, null, null, null, null, "\50", "\51", "\173", "\175", 
+"\133", "\135", "\73", "\54", "\56", "\76", "\74", "\75\75", "\74\75", "\76\75", 
+"\41\75", "\74\76", "\41\75\75", "\75\75\75", "\75", "\53\75", "\55\75", "\52\75", 
+"\57\75", "\46\75", "\174\75", "\136\75", "\56\75", "\45\75", "\176\75", "\100", "\44", 
+"\41", "\176", "\77", "\72", "\174\174", "\46\46", "\53\53", "\55\55", "\53", "\55", 
+"\52", "\57", "\46", "\174", "\136", "\45", "\74\74", "\76\76", "\76\76\76", 
+"\74\74\75", "\76\76\75", null, };
 public static final String[] lexStateNames = {
    "DEFAULT", 
    "PHPPARSING", 
@@ -1705,28 +1810,28 @@ public static final String[] lexStateNames = {
    "IN_MULTI_LINE_COMMENT", 
 };
 public static final int[] jjnewLexState = {
-   -1, 1, 0, -1, -1, -1, -1, -1, -1, 2, 3, 4, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
+   -1, 1, 1, 1, 0, -1, -1, -1, -1, -1, -1, 2, 2, 3, 4, 1, 0, 1, 1, -1, -1, -1, -1, -1, -1, 
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
    -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
-   -1, -1, -1, 
+   -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 
 };
 static final long[] jjtoToken = {
-   0xffffffffffff0007L, 0xffffffffffffc7d1L, 0x0L, 
+   0xfffffffffff0001fL, 0xffffffffff1f47ffL, 0x1fffL, 
 };
 static final long[] jjtoSkip = {
-   0x71f8L, 0x0L, 0x0L, 
+   0x7ffe0L, 0x0L, 0x0L, 
 };
 static final long[] jjtoSpecial = {
-   0x7000L, 0x0L, 0x0L, 
+   0x7f800L, 0x0L, 0x0L, 
 };
 static final long[] jjtoMore = {
-   0x8e00L, 0x0L, 0x0L, 
+   0x80000L, 0x0L, 0x0L, 
 };
 static protected SimpleCharStream input_stream;
-static private final int[] jjrounds = new int[64];
-static private final int[] jjstateSet = new int[128];
+static private final int[] jjrounds = new int[70];
+static private final int[] jjstateSet = new int[140];
 static StringBuffer image;
 static int jjimageLen;
 static int lengthOfMatch;
@@ -1753,7 +1858,7 @@ static private final void ReInitRounds()
 {
    int i;
    jjround = 0x80000001;
-   for (i = 64; i-- > 0;)
+   for (i = 70; i-- > 0;)
       jjrounds[i] = 0x80000000;
 }
 static public void ReInit(SimpleCharStream stream, int lexState)
@@ -1821,9 +1926,9 @@ public static Token getNextToken()
          jjmatchedKind = 0x7fffffff;
          jjmatchedPos = 0;
          curPos = jjMoveStringLiteralDfa0_0();
-         if (jjmatchedPos == 0 && jjmatchedKind > 3)
+         if (jjmatchedPos == 0 && jjmatchedKind > 5)
          {
-            jjmatchedKind = 3;
+            jjmatchedKind = 5;
          }
          break;
        case 1:
@@ -1840,27 +1945,27 @@ public static Token getNextToken()
          jjmatchedKind = 0x7fffffff;
          jjmatchedPos = 0;
          curPos = jjMoveStringLiteralDfa0_2();
-         if (jjmatchedPos == 0 && jjmatchedKind > 15)
+         if (jjmatchedPos == 0 && jjmatchedKind > 19)
          {
-            jjmatchedKind = 15;
+            jjmatchedKind = 19;
          }
          break;
        case 3:
          jjmatchedKind = 0x7fffffff;
          jjmatchedPos = 0;
          curPos = jjMoveStringLiteralDfa0_3();
-         if (jjmatchedPos == 0 && jjmatchedKind > 15)
+         if (jjmatchedPos == 0 && jjmatchedKind > 19)
          {
-            jjmatchedKind = 15;
+            jjmatchedKind = 19;
          }
          break;
        case 4:
          jjmatchedKind = 0x7fffffff;
          jjmatchedPos = 0;
          curPos = jjMoveStringLiteralDfa0_4();
-         if (jjmatchedPos == 0 && jjmatchedKind > 15)
+         if (jjmatchedPos == 0 && jjmatchedKind > 19)
          {
-            jjmatchedKind = 15;
+            jjmatchedKind = 19;
          }
          break;
      }
@@ -1896,7 +2001,7 @@ public static Token getNextToken()
            curLexState = jjnewLexState[jjmatchedKind];
            continue EOFLoop;
         }
-        MoreLexicalActions();
+        jjimageLen += jjmatchedPos + 1;
       if (jjnewLexState[jjmatchedKind] != -1)
         curLexState = jjnewLexState[jjmatchedKind];
         curPos = 0;
@@ -1935,24 +2040,14 @@ static void SkipLexicalActions(Token matchedToken)
 {
    switch(jjmatchedKind)
    {
-      default :
-         break;
-   }
-}
-static void MoreLexicalActions()
-{
-   jjimageLen += (lengthOfMatch = jjmatchedPos + 1);
-   switch(jjmatchedKind)
-   {
-      case 10 :
+      case 13 :
          if (image == null)
-              image = new StringBuffer(new String(input_stream.GetSuffix(jjimageLen)));
+            image = new StringBuffer(new String(input_stream.GetSuffix(jjimageLen + (lengthOfMatch = jjmatchedPos + 1))));
          else
-            image.append(new String(input_stream.GetSuffix(jjimageLen)));
-         jjimageLen = 0;
+            image.append(new String(input_stream.GetSuffix(jjimageLen + (lengthOfMatch = jjmatchedPos + 1))));
                    input_stream.backup(1);
          break;
-      default : 
+      default :
          break;
    }
 }