📄 serqlparsertokenmanager.java
字号:
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 + -