]> git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/spirit/test/karma/case_handling2.cpp
import new upstream nautilus stable release 14.2.8
[ceph.git] / ceph / src / boost / libs / spirit / test / karma / case_handling2.cpp
1 // Copyright (c) 2001-2010 Hartmut Kaiser
2 //
3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
5
6 #include <boost/config/warning_disable.hpp>
7 #include <boost/detail/lightweight_test.hpp>
8 #include <boost/detail/workaround.hpp>
9
10 #include <boost/spirit/include/karma_char.hpp>
11 #include <boost/spirit/include/karma_string.hpp>
12 #include <boost/spirit/include/karma_generate.hpp>
13 #include <boost/spirit/include/karma_directive.hpp>
14
15 #include "test.hpp"
16
17 using namespace spirit_test;
18
19 ///////////////////////////////////////////////////////////////////////////////
20 int
21 main()
22 {
23 using namespace boost::spirit;
24
25 {
26 using namespace boost::spirit::standard_wide;
27
28 BOOST_TEST(test(L"x", lower[L'X']));
29 BOOST_TEST(test(L"x", lower[L'x']));
30
31 BOOST_TEST(test(L"x", lower[char_], L'X'));
32 BOOST_TEST(test(L"x", lower[char_], L'x'));
33 BOOST_TEST(test(L"x", lower[char_(L'X')]));
34 BOOST_TEST(test(L"x", lower[char_(L'x')]));
35
36 BOOST_TEST(test(L" ", lower[space]));
37 BOOST_TEST(test(L"\t", lower[space], L'\t'));
38
39 BOOST_TEST(test(L"x", lower[lower[L'X']]));
40 BOOST_TEST(test(L"x", lower[lower[L'x']]));
41
42 BOOST_TEST(test(L"x", lower[lower[char_]], L'X'));
43 BOOST_TEST(test(L"x", lower[lower[char_]], L'x'));
44 BOOST_TEST(test(L"x", lower[lower[char_(L'X')]]));
45 BOOST_TEST(test(L"x", lower[lower[char_(L'x')]]));
46
47 BOOST_TEST(test(L" ", lower[lower[space]]));
48 BOOST_TEST(test(L"\t", lower[lower[space]], L'\t'));
49
50 BOOST_TEST(test(L"X", upper[lower[L'X']]));
51 BOOST_TEST(test(L"X", upper[lower[L'x']]));
52
53 BOOST_TEST(test(L"X", upper[lower[char_]], L'X'));
54 BOOST_TEST(test(L"X", upper[lower[char_]], L'x'));
55 BOOST_TEST(test(L"X", upper[lower[char_(L'X')]]));
56 BOOST_TEST(test(L"X", upper[lower[char_(L'x')]]));
57
58 BOOST_TEST(test(L" ", upper[lower[space]]));
59 BOOST_TEST(test(L"\t", upper[lower[space]], L'\t'));
60
61 BOOST_TEST(test(L"X", upper[L'X']));
62 BOOST_TEST(test(L"X", upper[L'x']));
63
64 BOOST_TEST(test(L"X", upper[char_], L'X'));
65 BOOST_TEST(test(L"X", upper[char_], L'x'));
66 BOOST_TEST(test(L"X", upper[char_(L'X')]));
67 BOOST_TEST(test(L"X", upper[char_(L'x')]));
68
69 BOOST_TEST(test(L" ", upper[space]));
70 BOOST_TEST(test(L"\t", upper[space], L'\t'));
71
72 BOOST_TEST(test(L"x", lower[upper[L'X']]));
73 BOOST_TEST(test(L"x", lower[upper[L'x']]));
74
75 BOOST_TEST(test(L"x", lower[upper[char_]], L'X'));
76 BOOST_TEST(test(L"x", lower[upper[char_]], L'x'));
77 BOOST_TEST(test(L"x", lower[upper[char_(L'X')]]));
78 BOOST_TEST(test(L"x", lower[upper[char_(L'x')]]));
79
80 BOOST_TEST(test(L" ", lower[upper[space]]));
81 BOOST_TEST(test(L"\t", lower[upper[space]], L'\t'));
82
83 BOOST_TEST(test(L"X", upper[upper[L'X']]));
84 BOOST_TEST(test(L"X", upper[upper[L'x']]));
85
86 BOOST_TEST(test(L"X", upper[upper[char_]], L'X'));
87 BOOST_TEST(test(L"X", upper[upper[char_]], L'x'));
88 BOOST_TEST(test(L"X", upper[upper[char_(L'X')]]));
89 BOOST_TEST(test(L"X", upper[upper[char_(L'x')]]));
90
91 BOOST_TEST(test(L" ", upper[upper[space]]));
92 BOOST_TEST(test(L"\t", upper[upper[space]], L'\t'));
93 }
94
95 { // test extended ASCII characters
96 using namespace boost::spirit::iso8859_1;
97
98 BOOST_TEST(test("\xE4\xE4", lower["\xC4\xE4"]));
99 BOOST_TEST(test("\xE4\xE4", lower["\xC4\xE4"]));
100
101 BOOST_TEST(test("\xC4\xC4", upper["\xC4\xE4"]));
102 BOOST_TEST(test("\xC4\xC4", upper["\xC4\xE4"]));
103 }
104
105 {
106 using namespace boost::spirit::ascii;
107 using boost::phoenix::val;
108
109 BOOST_TEST(test("x", lower[val('X')]));
110 BOOST_TEST(test("x", lower[val('x')]));
111 }
112
113 return boost::report_errors();
114 }