亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? recompiler.java

?? jakarta-regexp-1.5 正則表達式的源代碼
?? JAVA
?? 第 1 頁 / 共 4 頁
字號:
                {                    case '{':                    case '?':                    case '*':                    case '+':                        // If the next character is a closure operator and our atom is non-empty, the                        // current character should bind to the closure operator rather than the atom                        if (lenAtom != 0)                        {                            break atomLoop;                        }                }            }            // Switch on current char            switch (pattern.charAt(idx))            {                case ']':                case '^':                case '$':                case '.':                case '[':                case '(':                case ')':                case '|':                    break atomLoop;                case '{':                case '?':                case '*':                case '+':                    // We should have an atom by now                    if (lenAtom == 0)                    {                        // No atom before closure                        syntaxError("Missing operand to closure");                    }                    break atomLoop;                case '\\':                    {                        // Get the escaped character (advances input automatically)                        int idxBeforeEscape = idx;                        int c = escape();                        // Check if it's a simple escape (as opposed to, say, a backreference)                        if ((c & ESC_MASK) == ESC_MASK)                        {                            // Not a simple escape, so backup to where we were before the escape.                            idx = idxBeforeEscape;                            break atomLoop;                        }                        // Add escaped char to atom                        emit((char) c);                        lenAtom++;                    }                    break;                default:                    // Add normal character to atom                    emit(pattern.charAt(idx++));                    lenAtom++;                    break;            }        }        // This "shouldn't" happen        if (lenAtom == 0)        {            internalError();        }        // Emit the atom length into the program        instruction[ret + RE.offsetOpdata] = (char)lenAtom;        return ret;    }    /**     * Match a terminal node.     * @param flags Flags     * @return Index of terminal node (closeable)     * @exception RESyntaxException Thrown if the regular expression has invalid syntax.     */    int terminal(int[] flags) throws RESyntaxException    {        switch (pattern.charAt(idx))        {        case RE.OP_EOL:        case RE.OP_BOL:        case RE.OP_ANY:            return node(pattern.charAt(idx++), 0);        case '[':            return characterClass();        case '(':            return expr(flags);        case ')':            syntaxError("Unexpected close paren");        case '|':            internalError();        case ']':            syntaxError("Mismatched class");        case 0:            syntaxError("Unexpected end of input");        case '?':        case '+':        case '{':        case '*':            syntaxError("Missing operand to closure");        case '\\':            {                // Don't forget, escape() advances the input stream!                int idxBeforeEscape = idx;                // Switch on escaped character                switch (escape())                {                    case ESC_CLASS:                    case ESC_COMPLEX:                        flags[0] &= ~NODE_NULLABLE;                        return node(RE.OP_ESCAPE, pattern.charAt(idx - 1));                    case ESC_BACKREF:                        {                            char backreference = (char)(pattern.charAt(idx - 1) - '0');                            if (parens <= backreference)                            {                                syntaxError("Bad backreference");                            }                            flags[0] |= NODE_NULLABLE;                            return node(RE.OP_BACKREF, backreference);                        }                    default:                        // We had a simple escape and we want to have it end up in                        // an atom, so we back up and fall though to the default handling                        idx = idxBeforeEscape;                        flags[0] &= ~NODE_NULLABLE;                        break;                }            }        }        // Everything above either fails or returns.        // If it wasn't one of the above, it must be the start of an atom.        flags[0] &= ~NODE_NULLABLE;        return atom();    }    /**     * Compile a possibly closured terminal     * @param flags Flags passed by reference     * @return Index of closured node     * @exception RESyntaxException Thrown if the regular expression has invalid syntax.     */    int closure(int[] flags) throws RESyntaxException    {        // Before terminal        int idxBeforeTerminal = idx;        // Values to pass by reference to terminal()        int[] terminalFlags = { NODE_NORMAL };        // Get terminal symbol        int ret = terminal(terminalFlags);        // Or in flags from terminal symbol        flags[0] |= terminalFlags[0];        // Advance input, set NODE_NULLABLE flag and do sanity checks        if (idx >= len)        {            return ret;        }        boolean greedy = true;        char closureType = pattern.charAt(idx);        switch (closureType)        {            case '?':            case '*':                // The current node can be null                flags[0] |= NODE_NULLABLE;                // Drop through            case '+':                // Eat closure character                idx++;                // Drop through            case '{':                // Don't allow blantant stupidity                int opcode = instruction[ret /* + RE.offsetOpcode */];                if (opcode == RE.OP_BOL || opcode == RE.OP_EOL)                {                    syntaxError("Bad closure operand");                }                if ((terminalFlags[0] & NODE_NULLABLE) != 0)                {                    syntaxError("Closure operand can't be nullable");                }        }        // If the next character is a '?', make the closure non-greedy (reluctant)        if (idx < len && pattern.charAt(idx) == '?')        {            idx++;            greedy = false;        }        if (greedy)        {            // Actually do the closure now            switch (closureType)            {                case '{':                {                    bracket();                    int bracketEnd = idx;                    int bracketMin = this.bracketMin;                    int bracketOpt = this.bracketOpt;                    // Pointer to the last terminal                    int pos = ret;                    // Process min first                    for (int c = 0; c < bracketMin; c++)                    {                        // Rewind stream and run it through again - more matchers coming                        idx = idxBeforeTerminal;                        setNextOfEnd(pos, pos = terminal(terminalFlags));                    }                    // Do the right thing for maximum ({m,})                    if (bracketOpt == bracketUnbounded)                    {                        // Drop through now and closure expression.                        // We are done with the {m,} expr, so skip rest                        idx = bracketEnd;                        nodeInsert(RE.OP_STAR, 0, pos);                        setNextOfEnd(pos + RE.nodeSize, pos);                        break;                    }                    else if (bracketOpt > 0)                    {                        int opt[] = new int[bracketOpt + 1];                        // Surround first optional terminal with MAYBE                        nodeInsert(RE.OP_MAYBE, 0, pos);                        opt[0] = pos;                        // Add all the rest optional terminals with preceeding MAYBEs                        for (int c = 1; c < bracketOpt; c++)                        {                            opt[c] = node(RE.OP_MAYBE, 0);                            // Rewind stream and run it through again - more matchers coming                            idx = idxBeforeTerminal;                            terminal(terminalFlags);                        }                        // Tie ends together                        int end = opt[bracketOpt] = node(RE.OP_NOTHING, 0);                        for (int c = 0; c < bracketOpt; c++)                        {                            setNextOfEnd(opt[c], end);                            setNextOfEnd(opt[c] + RE.nodeSize, opt[c + 1]);                        }                    }                    else                    {                        // Rollback terminal - no opt matchers present                        lenInstruction = pos;                        node(RE.OP_NOTHING, 0);                    }                    // We are done. skip the reminder of {m,n} expr                    idx = bracketEnd;                    break;                }                case '?':                {                    nodeInsert(RE.OP_MAYBE, 0, ret);                    int n = node(RE.OP_NOTHING, 0);                    setNextOfEnd(ret, n);                    setNextOfEnd(ret + RE.nodeSize, n);                    break;                }                case '*':                {                    nodeInsert(RE.OP_STAR, 0, ret);                    setNextOfEnd(ret + RE.nodeSize, ret);                    break;                }                case '+':                {                    nodeInsert(RE.OP_CONTINUE, 0, ret);                    int n = node(RE.OP_PLUS, 0);                    setNextOfEnd(ret + RE.nodeSize, n);                    setNextOfEnd(n, ret);                    break;                }            }        }        else        {            // Actually do the closure now            switch (closureType)            {                case '?':                {                    nodeInsert(RE.OP_RELUCTANTMAYBE, 0, ret);                    int n = node(RE.OP_NOTHING, 0);                    setNextOfEnd(ret, n);                    setNextOfEnd(ret + RE.nodeSize, n);                    break;                }                case '*':                {                    nodeInsert(RE.OP_RELUCTANTSTAR, 0, ret);                    setNextOfEnd(ret + RE.nodeSize, ret);                    break;                }                case '+':                {                    nodeInsert(RE.OP_CONTINUE, 0, ret);                    int n = node(RE.OP_RELUCTANTPLUS, 0);                    setNextOfEnd(n, ret);                    setNextOfEnd(ret + RE.nodeSize, n);                    break;                }            }        }        return ret;    }    /**     * Compile body of one branch of an or operator (implements concatenation)     *     * @param flags Flags passed by reference     * @return Pointer to first node in the branch     * @exception RESyntaxException Thrown if the regular expression has invalid syntax.     */    int branch(int[] flags) throws RESyntaxException    {        // Get each possibly closured piece and concat

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合色综合88| 国产精品麻豆一区二区| 成人国产视频在线观看| 天天做天天摸天天爽国产一区| 久久综合国产精品| 欧美色偷偷大香| 国产91精品一区二区麻豆网站| 五月天网站亚洲| 亚洲免费资源在线播放| 国产亚洲欧美激情| 51精品秘密在线观看| 色哟哟欧美精品| 国产精品69毛片高清亚洲| 婷婷丁香激情综合| 亚洲小少妇裸体bbw| 中日韩av电影| 久久久国产精华| 欧美成人国产一区二区| 欧美日韩国产系列| 欧美亚一区二区| 成人性生交大片免费看中文 | 国产a视频精品免费观看| 婷婷开心激情综合| 亚洲国产综合色| 亚洲私人黄色宅男| 综合自拍亚洲综合图不卡区| 国产欧美日韩中文久久| 久久久www成人免费毛片麻豆| 这里是久久伊人| 宅男在线国产精品| 欧美一区二区日韩| 精品日韩99亚洲| 亚洲精品一区二区三区香蕉| 日韩欧美精品在线| 日韩视频在线一区二区| 日韩免费性生活视频播放| 51精品国自产在线| 欧美精品1区2区3区| 欧美肥大bbwbbw高潮| 欧美精品一卡两卡| 欧美一区二区三区免费大片| 欧美一区二区私人影院日本| 欧美一区二区三区不卡| 欧美大片在线观看一区| 精品成人一区二区| 国产欧美久久久精品影院 | 日本欧美一区二区| 麻豆国产精品一区二区三区 | 国产精品久久久久久久岛一牛影视 | 麻豆精品在线看| 久久99精品久久久久婷婷| 国内成人自拍视频| 国产99久久精品| 97超碰欧美中文字幕| 欧美影院午夜播放| 91精品国产综合久久香蕉麻豆| 日韩一级二级三级精品视频| 精品国产麻豆免费人成网站| 久久久精品免费免费| 国产精品久久久久桃色tv| 亚洲人成精品久久久久久| 亚洲成人动漫av| 美女www一区二区| 国产成人av资源| 99精品久久免费看蜜臀剧情介绍| 欧美伊人精品成人久久综合97| 欧美日韩另类一区| 精品国产一区二区在线观看| 国产精品日产欧美久久久久| 一二三区精品视频| 美女尤物国产一区| 成人午夜在线免费| 欧美丰满嫩嫩电影| 国产欧美日韩三级| 亚洲一区二区三区影院| 极品尤物av久久免费看| www.成人网.com| 91精品国产综合久久国产大片| 精品国产伦一区二区三区观看方式| 国产精品视频在线看| 亚洲一卡二卡三卡四卡| 国产自产2019最新不卡| 色婷婷亚洲综合| 26uuu久久天堂性欧美| 亚洲码国产岛国毛片在线| 精品一区二区影视| 欧美亚洲日本一区| 国产亚洲va综合人人澡精品| 亚洲一区二区欧美| 国产成人啪午夜精品网站男同| 欧美色综合网站| 国产丝袜欧美中文另类| 香蕉乱码成人久久天堂爱免费| 国产 日韩 欧美大片| 91精品国产入口| √…a在线天堂一区| 国产乱码精品一区二区三区忘忧草 | 国产精品美女久久久久久久久| 日韩福利视频网| 色呦呦国产精品| 国产欧美视频在线观看| 精东粉嫩av免费一区二区三区| 欧美亚洲一区二区在线观看| 国产日产欧美一区二区三区| 三级成人在线视频| 色哟哟一区二区在线观看| 国产校园另类小说区| 激情综合色综合久久| 欧美高清激情brazzers| 一区二区三区产品免费精品久久75| 国产美女在线观看一区| 日韩欧美国产精品| 日韩电影免费一区| 欧美三级韩国三级日本一级| 亚洲精品写真福利| 成人av在线看| 中文字幕精品三区| 国产精品一区二区久久不卡| 日韩欧美电影在线| 日韩vs国产vs欧美| 7777精品伊人久久久大香线蕉| 亚洲综合免费观看高清完整版| 成人97人人超碰人人99| 日本一区二区三区四区| 国产乱子轮精品视频| 日韩欧美国产一二三区| 久久精品国产99国产精品| 日韩亚洲欧美在线观看| 日韩高清一级片| 欧美一二区视频| 精品一区二区三区在线观看| 日韩一区二区视频| 看电影不卡的网站| 日韩欧美成人一区| 国产在线观看免费一区| 久久久国产精品麻豆| 成人午夜免费av| 1000精品久久久久久久久| 色哟哟在线观看一区二区三区| 一区二区免费在线播放| 欧美日韩综合在线| 男人的j进女人的j一区| 欧美一区二区三区影视| 激情综合五月婷婷| 国产无遮挡一区二区三区毛片日本| 国产精品18久久久久久久网站| 久久久噜噜噜久久人人看 | 2021国产精品久久精品| 国产乱妇无码大片在线观看| 久久久精品日韩欧美| aaa亚洲精品一二三区| 亚洲激情网站免费观看| 正在播放亚洲一区| 国产一区二区三区香蕉| 国产精品久久久久影院色老大| jizzjizzjizz欧美| 天堂蜜桃91精品| 久久久久久久性| 91久久久免费一区二区| 日日夜夜精品视频免费| xf在线a精品一区二区视频网站| 国产精品88av| 亚洲激情图片qvod| 欧美一区二区三区婷婷月色| 国产福利不卡视频| 一区二区在线观看视频 | 精品少妇一区二区三区日产乱码 | 99国产精品国产精品毛片| 一区二区三区欧美在线观看| 538在线一区二区精品国产| 国产九九视频一区二区三区| 国产精品入口麻豆原神| 欧美精品乱人伦久久久久久| 国产一区在线观看麻豆| 亚洲精品国产成人久久av盗摄| 欧美一级理论片| 97久久精品人人澡人人爽| 免费高清成人在线| 亚洲国产激情av| 欧美一区日韩一区| 一本到不卡精品视频在线观看 | 日韩成人午夜精品| 专区另类欧美日韩| 精品播放一区二区| 日本精品一区二区三区四区的功能| 美美哒免费高清在线观看视频一区二区| 国产日韩精品一区二区三区| 欧美日韩国产精品自在自线| 国产精品白丝jk黑袜喷水| 一区二区在线观看av| 亚洲精品一区二区三区四区高清 | 樱桃视频在线观看一区| 欧美大黄免费观看| 欧美综合天天夜夜久久| 国产成人综合亚洲网站| 日韩va亚洲va欧美va久久| 亚洲精品一卡二卡| 国产精品传媒视频| 久久午夜免费电影| 91精品国产一区二区三区蜜臀|