⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 serqlparsertokenmanager.java

📁 这是外国一个开源推理机
💻 JAVA
📖 第 1 页 / 共 4 页
字号:
         int hiByte = (int)(curChar >> 8);         int i1 = hiByte >> 6;         long l1 = 1L << (hiByte & 077);         int i2 = (curChar & 0xff) >> 6;         long l2 = 1L << (curChar & 077);         MatchLoop: do         {            switch(jjstateSet[--i])            {               case 0:                  if (!jjCanMove_2(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 72)                     kind = 72;                  jjCheckNAddStates(15, 17);                  break;               case 72:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(64, 65);                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                  {                     if (kind > 72)                        kind = 72;                     jjCheckNAdd(67);                  }                  break;               case 51:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(69, 65);                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                  {                     if (kind > 72)                        kind = 72;                     jjCheckNAdd(70);                  }                  break;               case 1:                  if (!jjCanMove_0(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 5)                     kind = 5;                  jjAddStates(6, 8);                  break;               case 6:                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))                     jjAddStates(3, 5);                  break;               case 15:                  if (jjCanMove_1(hiByte, i1, i2, l1, l2))                     jjAddStates(11, 12);                  break;               case 17:                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))                     jjAddStates(21, 22);                  break;               case 19:                  if (jjCanMove_2(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(20, 21);                  break;               case 20:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(20, 21);                  break;               case 22:                  if (!jjCanMove_3(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 56)                     kind = 56;                  jjstateSet[jjnewStateCnt++] = 22;                  break;               case 24:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(24, 21);                  break;               case 47:                  if (jjCanMove_1(hiByte, i1, i2, l1, l2))                     jjAddStates(13, 14);                  break;               case 49:                  if (jjCanMove_0(hiByte, i1, i2, l1, l2))                     jjAddStates(30, 31);                  break;               case 52:                  if (!jjCanMove_2(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 70)                     kind = 70;                  jjCheckNAdd(53);                  break;               case 53:                  if (!jjCanMove_3(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 70)                     kind = 70;                  jjCheckNAdd(53);                  break;               case 64:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(64, 65);                  break;               case 66:                  if (!jjCanMove_3(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 71)                     kind = 71;                  jjstateSet[jjnewStateCnt++] = 66;                  break;               case 67:                  if (!jjCanMove_3(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 72)                     kind = 72;                  jjCheckNAdd(67);                  break;               case 69:                  if (jjCanMove_3(hiByte, i1, i2, l1, l2))                     jjCheckNAddTwoStates(69, 65);                  break;               case 70:                  if (!jjCanMove_3(hiByte, i1, i2, l1, l2))                     break;                  if (kind > 72)                     kind = 72;                  jjCheckNAdd(70);                  break;               default : break;            }         } while(i != startsAt);      }      if (kind != 0x7fffffff)      {         jjmatchedKind = kind;         jjmatchedPos = curPos;         kind = 0x7fffffff;      }      ++curPos;      if ((i = jjnewStateCnt) == (startsAt = 72 - (jjnewStateCnt = startsAt)))         return curPos;      try { curChar = input_stream.readChar(); }      catch(java.io.IOException e) { return curPos; }   }}static final int[] jjnextStates = {   56, 60, 61, 6, 7, 26, 1, 2, 4, 8, 25, 15, 16, 47, 48, 64,    65, 67, 13, 19, 23, 17, 18, 27, 28, 29, 30, 31, 32, 41, 49, 50, };private static final boolean jjCanMove_0(int hiByte, int i1, int i2, long l1, long l2){   switch(hiByte)   {      case 0:         return ((jjbitVec2[i2] & l2) != 0L);      default :          if ((jjbitVec0[i1] & l1) != 0L)            return true;         return false;   }}private static final boolean jjCanMove_1(int hiByte, int i1, int i2, long l1, long l2){   switch(hiByte)   {      case 6:         return ((jjbitVec5[i2] & l2) != 0L);      case 11:         return ((jjbitVec6[i2] & l2) != 0L);      case 13:         return ((jjbitVec7[i2] & l2) != 0L);      case 14:         return ((jjbitVec8[i2] & l2) != 0L);      case 15:         return ((jjbitVec9[i2] & l2) != 0L);      default :          if ((jjbitVec3[i1] & l1) != 0L)            if ((jjbitVec4[i2] & l2) == 0L)               return false;            else            return true;         return false;   }}private static final boolean jjCanMove_2(int hiByte, int i1, int i2, long l1, long l2){   switch(hiByte)   {      case 0:         return ((jjbitVec11[i2] & l2) != 0L);      case 1:         return ((jjbitVec12[i2] & l2) != 0L);      case 2:         return ((jjbitVec13[i2] & l2) != 0L);      case 3:         return ((jjbitVec14[i2] & l2) != 0L);      case 4:         return ((jjbitVec15[i2] & l2) != 0L);      case 5:         return ((jjbitVec16[i2] & l2) != 0L);      case 6:         return ((jjbitVec17[i2] & l2) != 0L);      case 9:         return ((jjbitVec18[i2] & l2) != 0L);      case 10:         return ((jjbitVec19[i2] & l2) != 0L);      case 11:         return ((jjbitVec20[i2] & l2) != 0L);      case 12:         return ((jjbitVec21[i2] & l2) != 0L);      case 13:         return ((jjbitVec22[i2] & l2) != 0L);      case 14:         return ((jjbitVec23[i2] & l2) != 0L);      case 15:         return ((jjbitVec24[i2] & l2) != 0L);      case 16:         return ((jjbitVec25[i2] & l2) != 0L);      case 17:         return ((jjbitVec26[i2] & l2) != 0L);      case 30:         return ((jjbitVec27[i2] & l2) != 0L);      case 31:         return ((jjbitVec28[i2] & l2) != 0L);      case 33:         return ((jjbitVec29[i2] & l2) != 0L);      case 48:         return ((jjbitVec30[i2] & l2) != 0L);      case 49:         return ((jjbitVec31[i2] & l2) != 0L);      case 159:         return ((jjbitVec32[i2] & l2) != 0L);      case 215:         return ((jjbitVec33[i2] & l2) != 0L);      default :          if ((jjbitVec10[i1] & l1) != 0L)            return true;         return false;   }}private static final boolean jjCanMove_3(int hiByte, int i1, int i2, long l1, long l2){   switch(hiByte)   {      case 0:         return ((jjbitVec34[i2] & l2) != 0L);      case 1:         return ((jjbitVec12[i2] & l2) != 0L);      case 2:         return ((jjbitVec35[i2] & l2) != 0L);      case 3:         return ((jjbitVec36[i2] & l2) != 0L);      case 4:         return ((jjbitVec37[i2] & l2) != 0L);      case 5:         return ((jjbitVec38[i2] & l2) != 0L);      case 6:         return ((jjbitVec39[i2] & l2) != 0L);      case 9:         return ((jjbitVec40[i2] & l2) != 0L);      case 10:         return ((jjbitVec41[i2] & l2) != 0L);      case 11:         return ((jjbitVec42[i2] & l2) != 0L);      case 12:         return ((jjbitVec43[i2] & l2) != 0L);      case 13:         return ((jjbitVec44[i2] & l2) != 0L);      case 14:         return ((jjbitVec45[i2] & l2) != 0L);      case 15:         return ((jjbitVec46[i2] & l2) != 0L);      case 16:         return ((jjbitVec25[i2] & l2) != 0L);      case 17:         return ((jjbitVec26[i2] & l2) != 0L);      case 30:         return ((jjbitVec27[i2] & l2) != 0L);      case 31:         return ((jjbitVec28[i2] & l2) != 0L);      case 32:         return ((jjbitVec47[i2] & l2) != 0L);      case 33:         return ((jjbitVec29[i2] & l2) != 0L);      case 48:         return ((jjbitVec48[i2] & l2) != 0L);      case 49:         return ((jjbitVec31[i2] & l2) != 0L);      case 159:         return ((jjbitVec32[i2] & l2) != 0L);      case 215:         return ((jjbitVec33[i2] & l2) != 0L);      default :          if ((jjbitVec10[i1] & l1) != 0L)            return true;         return false;   }}public static final String[] jjstrLiteralImages = {"", null, null, null, null, null, "\75", "\41\75", "\74", "\74\75", "\76\75", "\76", "\52", "\54", "\73", "\173", "\175", "\50", "\51", "\133", "\135", "\137", 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, null, null, null, null, null, null, null, null, null, null, null, null, };public static final String[] lexStateNames = {   "DEFAULT", };static final long[] jjtoToken = {   0x1ffffffffffffc1L, 0xe01d0L, };static final long[] jjtoSkip = {   0x3eL, 0x0L, };static final long[] jjtoSpecial = {   0x20L, 0x0L, };protected SimpleCharStream input_stream;private final int[] jjrounds = new int[72];private final int[] jjstateSet = new int[144];protected char curChar;public SerqlParserTokenManager(SimpleCharStream stream){   if (SimpleCharStream.staticFlag)      throw new Error("ERROR: Cannot use a static CharStream class with a non-static lexical analyzer.");   input_stream = stream;}public SerqlParserTokenManager(SimpleCharStream stream, int lexState){   this(stream);   SwitchTo(lexState);}public void ReInit(SimpleCharStream stream){   jjmatchedPos = jjnewStateCnt = 0;   curLexState = defaultLexState;   input_stream = stream;   ReInitRounds();}private final void ReInitRounds(){   int i;   jjround = 0x80000001;   for (i = 72; i-- > 0;)      jjrounds[i] = 0x80000000;}public void ReInit(SimpleCharStream stream, int lexState){   ReInit(stream);   SwitchTo(lexState);}public void SwitchTo(int lexState){   if (lexState >= 1 || lexState < 0)      throw new TokenMgrError("Error: Ignoring invalid lexical state : " + lexState + ". State unchanged.", TokenMgrError.INVALID_LEXICAL_STATE);   else      curLexState = lexState;}protected Token jjFillToken(){   Token t = Token.newToken(jjmatchedKind);   t.kind = jjmatchedKind;   String im = jjstrLiteralImages[jjmatchedKind];   t.image = (im == null) ? input_stream.GetImage() : im;   t.beginLine = input_stream.getBeginLine();   t.beginColumn = input_stream.getBeginColumn();   t.endLine = input_stream.getEndLine();   t.endColumn = input_stream.getEndColumn();   return t;}int curLexState = 0;int defaultLexState = 0;int jjnewStateCnt;int jjround;int jjmatchedPos;int jjmatchedKind;public Token getNextToken() {  int kind;  Token specialToken = null;  Token matchedToken;  int curPos = 0;  EOFLoop :  for (;;)  {      try      {           curChar = input_stream.BeginToken();   }        catch(java.io.IOException e)   {              jjmatchedKind = 0;      matchedToken = jjFillToken();      matchedToken.specialToken = specialToken;      return matchedToken;   }   try { input_stream.backup(0);      while (curChar <= 32 && (0x100002600L & (1L << curChar)) != 0L)         curChar = input_stream.BeginToken();   }   catch (java.io.IOException e1) { continue EOFLoop; }   jjmatchedKind = 0x7fffffff;   jjmatchedPos = 0;   curPos = jjMoveStringLiteralDfa0_0();   if (jjmatchedKind != 0x7fffffff)   {      if (jjmatchedPos + 1 < curPos)         input_stream.backup(curPos - jjmatchedPos - 1);      if ((jjtoToken[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)      {         matchedToken = jjFillToken();         matchedToken.specialToken = specialToken;         return matchedToken;      }      else      {         if ((jjtoSpecial[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)         {            matchedToken = jjFillToken();            if (specialToken == null)               specialToken = matchedToken;            else            {               matchedToken.specialToken = specialToken;               specialToken = (specialToken.next = matchedToken);            }         }         continue EOFLoop;      }   }   int error_line = input_stream.getEndLine();   int error_column = input_stream.getEndColumn();   String error_after = null;   boolean EOFSeen = false;   try { input_stream.readChar(); input_stream.backup(1); }   catch (java.io.IOException e1) {      EOFSeen = true;      error_after = curPos <= 1 ? "" : input_stream.GetImage();      if (curChar == '\n' || curChar == '\r') {         error_line++;         error_column = 0;      }      else         error_column++;   }   if (!EOFSeen) {      input_stream.backup(1);      error_after = curPos <= 1 ? "" : input_stream.GetImage();   }   throw new TokenMgrError(EOFSeen, curLexState, error_line, error_column, error_after, curChar, TokenMgrError.LEXICAL_ERROR);  }}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -