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

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

?? reimpl2.h

?? 用于正則表達式的C++庫. 現在的版本那是2.6.4
?? H
?? 第 1 頁 / 共 4 頁
字號:

    static bool _do_match_recursive_s
    (
        sub_expr_base<IterT> const * expr,
        match_param<IterT> & param,
        IterT icur
    );

    static bool _do_match_recursive_c
    (
        sub_expr_base<IterT> const * expr,
        match_param<IterT> & param,
        IterT icur
    );

    static bool _do_match_impl
    (
        rpattern_type const & pat,
        match_param<IterT> & param,
        bool const use_null
    );

    static bool _do_match_with_stack
    (
        rpattern_type const & pat,
        match_param<IterT> & param,
        bool const use_null
    );

    template< typename Alloc1T, typename Alloc2T >
    static void _fixup_backrefs
    (
        std::vector<backref_type,Alloc1T> & rgbackrefs,
        std::list<size_t,Alloc2T> const & invisible
    )
    {
        typedef typename std::list<size_t,Alloc2T>::const_iterator iter_type;

        // Remove information about the "invisible" groups
        if( rgbackrefs[0].matched )
        {
            size_t dropped = 0;
            iter_type const end = invisible.end();
            iter_type curr = invisible.begin(), next = invisible.begin();

            for( ; end != curr; curr = next, ++dropped )
            {
                if( end == ++next )
                {
                    std::copy(
                        rgbackrefs.begin() + *curr + 1,
                        rgbackrefs.end(),
                        rgbackrefs.begin() + *curr - dropped );
                }
                else
                {
                    std::copy(
                        rgbackrefs.begin() + *curr + 1,
                        rgbackrefs.begin() + *next,
                        rgbackrefs.begin() + *curr - dropped );
                }
            }

            rgbackrefs.resize( rgbackrefs.size() - dropped );
        }
        else
        {
            rgbackrefs.resize( rgbackrefs.size() - invisible.size() );
        }
    }

    template< typename AllocT >
    static bool _do_try_match
    (
        rpattern_type const & pat,
        match_param<IterT> & param,
        std::vector<backref_type,AllocT> & rgbackrefs,
        bool const use_null
    )
    {
        bool success;
        rgbackrefs.resize( pat._cgroups_total() );
        param.m_prgbackrefs = & rgbackrefs[0];
        param.m_cbackrefs = rgbackrefs.size();

        REGEX_SEH_TRY
        {
            if( pat._ok_to_recurse() )
            {
                success = _do_match_impl( pat, param, use_null );
            }
            else
            {
                success = _do_match_with_stack( pat, param, use_null );
            }
        }
        REGEX_SEH_EXCEPT( REGEX_SEH_STACK_OVERFLOW == _exception_code() )
        {
            // we have overflowed the stack. reset the guard page.
            REGEX_RESET_STK_OFLW();

            // This match fails silently.
            for( size_t i=0; i < param.m_cbackrefs; ++i )
            {
                param.m_prgbackrefs[i] = static_init<backref_type>::value;
            }

            success = false;
        }

        _fixup_backrefs( rgbackrefs, pat.m_invisible_groups );
        return success;
    }

    template< typename AllocT >
    static bool _do_match
    (
        rpattern_type const & pat,
        basic_match_results<IterT,AllocT> & results,
        IterT ibegin,
        IterT iend,
        bool use_null
    )
    {
        typedef typename basic_match_results<IterT,AllocT>::backref_vector backref_vector;

        results.m_ibegin = ibegin;
        match_param<IterT> param( ibegin, ibegin, iend, 0, 0 );

        if( GLOBAL & pat.flags() ) // do a global find
        {
            // The NOBACKREFS flag is ignored in the match method.
            bool const fAll   = ( ALLBACKREFS   == ( ALLBACKREFS   & pat.flags() ) );
            bool const fFirst = ( FIRSTBACKREFS == ( FIRSTBACKREFS & pat.flags() ) );

            backref_vector rgtempbackrefs( results.m_rgbackrefs.get_allocator() );

            while( _do_try_match( pat, param, results.m_rgbackrefs, use_null ) )
            {
                backref_type const & br = param.m_prgbackrefs[0];

                // Handle specially the backref flags
                if( fFirst )
                {
                    rgtempbackrefs.push_back( br );
                }
                else if( fAll )
                {
                    rgtempbackrefs.insert(
                        rgtempbackrefs.end(),
                        results.m_rgbackrefs.begin(),
                        results.m_rgbackrefs.end() );
                }
                else
                {
                    rgtempbackrefs.swap( results.m_rgbackrefs );
                }

                param.m_imatchbegin = br.second;
                param.m_no0len = ( br.first == br.second );
            }

            // restore the backref vectors
            results.m_rgbackrefs.swap( rgtempbackrefs );
            return ! results.m_rgbackrefs.empty();
        }
        else
        {
            return _do_try_match( pat, param, results.m_rgbackrefs, use_null );
        }
    }

    template< typename AllocT >
    static bool _do_match_c
    (
        rpattern_type const & pat,
        basic_match_results<IterT,AllocT> & results,
        char_type const * szbegin
    )
    {
        if( RIGHTMOST & pat.flags() )
        {
            // We need to know the end of the string if we're doing a
            // RIGHTMOST match.
            char_type const * szend = szbegin;
            std::advance( szend, traits_type::length( szbegin ) );
            return _do_match( pat, results, szbegin, szend, false );
        }
        else
        {
            return _do_match( pat, results, szbegin, 0, true );
        }
    }

    static size_t _do_count
    (
        rpattern_type const & pat,
        IterT ibegin,
        IterT iend,
        bool use_null
    )
    {
        size_t cmatches = 0;
        std::vector<backref_type> rgbackrefs;

        // If your compile breaks here, it is because CharT const * is not
        // convertible to type IterT. Check the declaration of your rpattern object.
        match_param<IterT> param( ibegin, ibegin, iend, 0, 0 );

        while( _do_try_match( pat, param, rgbackrefs, use_null ) )
        {
            backref_type const & br = param.m_prgbackrefs[0];
            ++cmatches;
            param.m_imatchbegin = br.second;

            param.m_no0len = ( br.first == br.second );
        }

        return cmatches;
    }

    template< typename CharT, typename TraitsT, typename AllocT >
    static size_t _do_split
    (
        rpattern_type const & pat,
        basic_split_results<CharT, TraitsT, AllocT> & results,
        IterT ibegin,
        IterT iend,
        int limit,
        bool use_null
    )
    {
        typedef typename basic_split_results<CharT, TraitsT, AllocT>::string_type   string_type;
        typedef typename rebind<AllocT, backref_type>::type                         backref_allocator;

        std::vector<backref_type,backref_allocator> rgbackrefs( 
            convert_allocator<backref_type>( results.strings().get_allocator(), 0 ) );
            
        typedef typename rebind<AllocT, CharT>::type                                char_allocator_type;
        char_allocator_type char_allocator = 
            convert_allocator<CharT>( results.strings().get_allocator(), 0 );

        // reserve some initial space
        results.strings().clear();
        results.strings().reserve( 10 );

        match_param<IterT> param( ibegin, ibegin, iend, 0, 0 );

        while( 1 != limit && _do_try_match( pat, param, rgbackrefs, use_null ) )
        {
            backref_type const & br = param.m_prgbackrefs[0];
            param.m_no0len = ( br.first == br.second );

            // discard zero-width matches at the beginning and end of the buffer
            if( param.m_no0len )
            {
                // if we're at the beginning, skip
                if( br.first == param.m_ibufferbegin )
                    continue;

                // if we're at the end, break
                if( use_null ? 0 == *param.m_imatchbegin : param.m_imatchbegin == param.m_iend )
                    break;
            }

            string_type tmp( param.m_imatchbegin, br.first, char_allocator );
            results.strings().push_back( tmp );
            param.m_imatchbegin = br.second;

            // add any groups
            for( size_t i = 1; i < rgbackrefs.size(); ++i )
            {
                backref_type const & br = rgbackrefs[i];
                string_type tmp( br.first, br.second, char_allocator );
                results.strings().push_back( tmp );
            }

            if( limit > 0 )
                --limit;
        }

        // append the last string, unless it's empty and limit is 0
        if( use_null )
        {
            if( *param.m_imatchbegin || 0 != limit )
                results.strings().push_back( string_type( &*param.m_imatchbegin, char_allocator ) );
        }
        else
        {
            if( param.m_imatchbegin != param.m_iend || 0 != limit )
                results.strings().push_back( string_type( param.m_imatchbegin, param.m_iend, char_allocator ) );
        }

        // remove trailing empty fields
        if( 0 == limit )
        {
            while( results.size() && results.back().empty() )
            {
                results.strings().pop_back();
            }
        }

        return results.size();
    }

    template< typename CharT, typename TraitsT, typename AllocT >
    static size_t _do_subst_internal
    (
        std::basic_string<CharT, TraitsT, AllocT> & str,
        basic_subst_results<CharT, TraitsT, AllocT> const & results,
        rpattern_type const & pat,
        size_type strpos,
        size_type strlen
    )
    {
        typedef subst_list_type::const_iterator iter_type;
        enum { UPPER = -1, NIL, LOWER } next = NIL, rest = NIL;
        bool first = true;
        size_t old_strpos = strpos;
        typename std::basic_string<CharT, TraitsT, AllocT>::iterator itstrlen = str.begin();
        std::advance( itstrlen, strpos + strlen );
        std::basic_string<char_type> const & subst = pat.get_subst();

        for( iter_type isubst = pat.m_subst_list.begin(); pat.m_subst_list.end() != isubst; ++isubst )
        {
            size_t sublen = 0;
            typename std::basic_string<CharT, TraitsT, AllocT>::const_iterator itsubpos1; // iter into str
            typename std::basic_string<CharT, TraitsT, AllocT>::const_iterator itsublen1;
            typename std::basic_string<char_type>::const_iterator              itsubpos2; // iter into subst string
            typename std::basic_string<char_type>::const_iterator              itsublen2;
            typename std::basic_string<CharT, TraitsT, AllocT>::iterator       itstrpos = str.begin();
            std::advance( itstrpos, strpos );

            switch( isubst->m_stype )
            {
            case subst_node::SUBST_STRING:
                itsubpos2 = subst.begin();
                std::advance( itsubpos2, isubst->m_subst_string.m_rstart );
                itsublen2 = itsubpos2;
                std::advance( itsublen2, isubst->m_subst_string.m_rlength );

                if( first )
                    str.replace( itstrpos, itstrlen, itsubpos2, itsublen2 );
                else
                    str.insert( itstrpos, itsubpos2, itsublen2 );
                sublen = std::distance( itsubpos2, itsublen2 );
                break;

            case subst_node::SUBST_BACKREF:
                switch( isubst->m_subst_backref )
                {
                case subst_node::PREMATCH:
                    itsubpos1 = results.backref_str().begin();
                    itsublen1 = itsubpos1;
                    std::advance( itsublen1, sublen = results.rstart() );
                    break;
                case subst_node::POSTMATCH:
                    itsubpos1 = results.backref_str().begin();
                    std::advance( itsubpos1, results.rstart() + results.rlength() );
                    itsublen1 = results.backref_str().end();
                    break;
                default:
                    itsubpos1 = results.backref_str().begin();
                    std::advance( itsubpos1, results.rstart( isubst->m_subst_backref ) );
                    itsublen1 = itsubpos1;
                    std::advance( itsublen1, results.rlength( isubst->m_subst_backref ) );
                    break;
                }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区三区四区视频| 一区二区三区四区高清精品免费观看 | 色偷偷成人一区二区三区91| 国产91丝袜在线播放九色| 精品在线免费视频| 免费不卡在线视频| 蜜臀av一区二区| 日韩制服丝袜av| 久久国产欧美日韩精品| 美国欧美日韩国产在线播放| 久久66热偷产精品| 极品少妇一区二区三区精品视频| 极品少妇一区二区| 国产成人精品综合在线观看 | 26uuu亚洲| 欧美国产综合色视频| 中国av一区二区三区| 1024亚洲合集| 亚洲成人动漫在线观看| 日韩一区欧美二区| 美女在线一区二区| 国产精品一区二区免费不卡 | 久久九九久精品国产免费直播| 久久综合成人精品亚洲另类欧美| 国产日韩av一区| 亚洲欧美色图小说| 视频一区二区三区中文字幕| 激情都市一区二区| 成人av在线观| 欧美午夜电影在线播放| 欧美不卡一区二区三区四区| 国产精品无圣光一区二区| 亚洲精品中文字幕在线观看| 午夜精品久久久| 久久99精品久久久久久| 成人一区二区三区视频在线观看 | 久久久久久电影| 亚洲视频香蕉人妖| 日韩国产一区二| 懂色av一区二区夜夜嗨| 日本电影亚洲天堂一区| 欧美成人猛片aaaaaaa| 国产精品久久免费看| 亚欧色一区w666天堂| 国产精品亚洲成人| 欧美日韩一区不卡| 国产婷婷一区二区| 亚洲国产精品久久久男人的天堂 | 日韩精品一区二区在线| 成人欧美一区二区三区| 美腿丝袜在线亚洲一区| 99国内精品久久| 欧美电影免费提供在线观看| 最新国产の精品合集bt伙计| 麻豆成人91精品二区三区| 91视视频在线直接观看在线看网页在线看| 91精品在线免费| 中文字幕综合网| 韩国女主播一区二区三区| 欧美在线观看视频一区二区| 久久精品视频在线免费观看| 亚洲高清免费视频| 成人免费电影视频| 日韩欧美一级二级三级久久久| 亚洲三级久久久| 国产乱人伦偷精品视频免下载 | 久久久久久黄色| 丝袜美腿一区二区三区| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美一卡2卡3卡4卡| 亚洲免费av在线| 丰满少妇在线播放bd日韩电影| 91精品久久久久久蜜臀| 一区二区三区在线视频观看| 国产成人一区在线| 精品精品国产高清一毛片一天堂| 亚洲一区二区高清| 99视频精品全部免费在线| 久久久蜜桃精品| 免费成人在线视频观看| 欧美亚洲动漫制服丝袜| 亚洲精选一二三| 99re热这里只有精品视频| 久久人人超碰精品| 韩国成人福利片在线播放| 欧美一区二区三区性视频| 亚洲一区二区不卡免费| 日本精品一区二区三区四区的功能| 国产免费久久精品| 国产精品原创巨作av| 精品国产伦一区二区三区观看方式 | 99视频精品在线| 中文字幕av一区 二区| 国产麻豆精品在线| 亚洲精品一区在线观看| 美女视频网站久久| 欧美一区二区三区免费视频| 午夜精品一区二区三区免费视频 | 欧美一二三区在线| 视频一区二区不卡| 91精品国产综合久久久蜜臀图片 | 色国产综合视频| 亚洲人被黑人高潮完整版| 高清在线观看日韩| 国产女人aaa级久久久级| 丁香激情综合五月| 中文在线免费一区三区高中清不卡| 国产一区二区按摩在线观看| 精品国偷自产国产一区| 国产麻豆一精品一av一免费 | 香蕉成人伊视频在线观看| 欧美视频在线观看一区| 亚洲国产中文字幕在线视频综合| 日本韩国欧美一区二区三区| 亚洲一区二区三区四区五区黄| 欧洲亚洲国产日韩| 午夜精品久久久久影视| 欧美电影免费观看高清完整版在线观看 | 亚洲成人高清在线| 日韩欧美美女一区二区三区| 黑人巨大精品欧美一区| 中文字幕的久久| 91成人网在线| 免费在线欧美视频| 久久噜噜亚洲综合| 91首页免费视频| 日韩高清在线一区| 国产丝袜欧美中文另类| 色综合色狠狠天天综合色| 亚洲成年人影院| 精品女同一区二区| eeuss影院一区二区三区| 亚洲国产另类av| 26uuu精品一区二区| 成人av资源在线观看| 亚洲一区在线视频观看| 欧美一区二区三区四区五区| 国产一区 二区 三区一级| 国产精品高潮呻吟| 51午夜精品国产| 国产乱理伦片在线观看夜一区 | 国产精品一区一区| 一区二区在线看| 精品日韩一区二区三区| eeuss国产一区二区三区| 午夜成人免费电影| 国产精品乱码久久久久久| 欧美三级日韩三级国产三级| 激情五月激情综合网| 亚洲精选视频免费看| 26uuu欧美| 欧美丝袜自拍制服另类| 国产成人免费视频网站高清观看视频| 亚洲综合在线视频| 久久精品夜色噜噜亚洲aⅴ| 欧美午夜一区二区三区| 国产精品亚洲第一| 日韩黄色片在线观看| 国产目拍亚洲精品99久久精品| 欧美精品自拍偷拍| 99在线精品观看| 韩国精品一区二区| 天天综合网天天综合色| 亚洲视频小说图片| 久久久久久日产精品| 欧美日韩不卡视频| bt欧美亚洲午夜电影天堂| 蜜桃久久久久久| 亚洲午夜精品网| 国产精品久线观看视频| 日韩欧美成人一区二区| 欧洲av在线精品| 国产91富婆露脸刺激对白| 另类小说色综合网站| 亚洲综合色成人| 国产精品污www在线观看| 精品福利av导航| 91精选在线观看| 欧美性猛交xxxxxxxx| 成人aa视频在线观看| 国产一区二区按摩在线观看| 蜜臀久久99精品久久久久久9| 亚洲综合丝袜美腿| 亚洲美女区一区| 国产精品久久久久久久久久久免费看| 欧美va亚洲va香蕉在线| 欧美日韩成人综合天天影院 | 国产日韩精品一区二区三区| 亚洲国产精品尤物yw在线观看| 国产精品免费看片| 欧美韩日一区二区三区四区| 2019国产精品| 日韩三级精品电影久久久| 欧美日韩成人综合天天影院 | 91.麻豆视频| 欧美日韩在线三区| 在线观看精品一区| 一本到不卡免费一区二区| 99久久综合精品| 91在线观看污|