summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/xpressive/test/test4.hpp
blob: 98c17df4a0cbfc957141e769962c9a19a70757b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
///////////////////////////////////////////////////////////////////////////////
// test4.hpp
//
//  Copyright 2008 Eric Niebler. Distributed under the Boost
//  Software License, Version 1.0. (See accompanying file
//  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

#include "./test.hpp"

///////////////////////////////////////////////////////////////////////////////
// get_test_cases
//
template<typename BidiIterT>
boost::iterator_range<xpr_test_case<BidiIterT> const *> get_test_cases()
{
    typedef typename boost::iterator_value<BidiIterT>::type char_type;
    typedef xpr_test_case<BidiIterT> xpr_test_case;
    typedef basic_regex<BidiIterT> regex_type;

    // for testing recursive static regexes
    //regex_type parens = L('(') >> *( keep( +~(set=L('('),L(')')) ) | self ) >> L(')');

    regex_type parens;
    parens = L('(') >> *( keep( +~(set=L('('),L(')')) ) | by_ref(parens) ) >> L(')');

    static char_type const *nilbr = 0;
    static xpr_test_case const test_cases[] =
    {
        xpr_test_case
        (
            "test61"
          , L("this is sublist(now(is(the(time),for(all),good(men))to(come)))ok?")
          , regex_type(_b >> L("sublist") >> parens)
          , backrefs(L("sublist(now(is(the(time),for(all),good(men))to(come)))"), nilbr)
        )
      , xpr_test_case
        (
            "test62"
          , L("this is sublist(now(is(the(time),for(all),good(men))to(come))ok?")
          , regex_type(_b >> L("sublist") >> parens)
          , no_match
        )
      , xpr_test_case
        (
            "test63"
          , L("foobar")
          , regex_type(bos >> L("baz") | L("bar"))
          , backrefs(L("bar"), nilbr)
        )
      , xpr_test_case
        (
            "test69"
          , L("FooBarfoobar")
          , regex_type(icase(*_ >> L("foo")))
          , backrefs(L("FooBarfoo"), nilbr)
        )
      , xpr_test_case
        (
            "test70"
          , L("FooBarfoobar")
          , regex_type(icase(*_ >> L("boo")))
          , no_match
        )
      , xpr_test_case
        (
            "test71"
          , L("FooBarfoobar")
          , regex_type(icase(*_ >> L("boo") | L("bar")))
          , backrefs(L("Bar"), nilbr)
        )
      , xpr_test_case
        (
            "test72"
          , L("FooBarfoobar")
          , regex_type(icase(L("bar")))
          , backrefs(L("Bar"), nilbr)
        )
      , xpr_test_case
        (
            "test75"
          , L("fooooo")
          , regex_type(L('f') >> repeat<1,repeat_max>(L('o')))
          , backrefs(L("fooooo"), nilbr)
        )
      , xpr_test_case
        (
            "test78"
          , L("This (has) parens")
          , regex_type(L("This ") >> (s1= L("(has)")) >> L(' ') >> (s2= L("parens")))
          , backrefs(L("This (has) parens"), L("(has)"), L("parens"), nilbr)
        )
      , xpr_test_case
        (
            "test79"
          , L("This (has) parens")
          , regex_type(as_xpr(L("This (has) parens")))
          , backrefs(L("This (has) parens"), nilbr)
        )
      , xpr_test_case
        (
            "test80"
          , L("This (has) parens")
          , regex_type(as_xpr(L("This (has) parens")))
          , backrefs(L("This (has) parens"), nilbr)
        )
    };

    return boost::make_iterator_range(test_cases);
}