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
|
// Copyright (c) 2001-2011 Hartmut Kaiser
//
// 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 "auto.hpp"
///////////////////////////////////////////////////////////////////////////////
int main()
{
{
BOOST_TEST((!traits::meta_create_exists<karma::domain, my_type>::value));
}
{
// test primitive types
BOOST_TEST(test_create_generator("true", true));
BOOST_TEST(test_create_generator("1", 1));
BOOST_TEST(test_create_generator("1.1", 1.1));
BOOST_TEST(test_create_generator("test", std::string("test")));
BOOST_TEST(test_create_generator("a", 'a'));
BOOST_TEST(test_create_generator(L"a", L'a'));
// test containers
std::vector<int> v;
v.push_back(0);
v.push_back(1);
v.push_back(2);
BOOST_TEST(test_create_generator("012", v));
std::list<int> l;
l.push_back(0);
l.push_back(1);
l.push_back(2);
BOOST_TEST(test_create_generator("012", l));
// test optional
boost::optional<int> o;
BOOST_TEST(test_create_generator("", o));
o = 1;
BOOST_TEST(test_create_generator("1", o));
// test alternative
boost::variant<int, double, float, std::string> vv;
vv = 1;
BOOST_TEST(test_create_generator("1", vv));
vv = 1.0;
BOOST_TEST(test_create_generator("1.0", vv));
vv = 1.0f;
BOOST_TEST(test_create_generator("1.0", vv));
vv = "some string";
BOOST_TEST(test_create_generator("some string", vv));
// test fusion sequence
std::pair<int, double> p (1, 2.0);
BOOST_TEST(test_create_generator("12.0", p));
}
{
// test primitive types
// BOOST_TEST(test_create_generator_auto("true", true));
// BOOST_TEST(test_create_generator_auto("1", 1));
// BOOST_TEST(test_create_generator_auto("1.1", 1.1));
// BOOST_TEST(test_create_generator_auto("test", std::string("test")));
// BOOST_TEST(test_create_generator_auto("a", 'a'));
// BOOST_TEST(test_create_generator_auto(L"a", L'a'));
// test containers
std::vector<int> v;
v.push_back(0);
v.push_back(1);
v.push_back(2);
BOOST_TEST(test_create_generator_auto("012", v));
std::list<int> l;
l.push_back(0);
l.push_back(1);
l.push_back(2);
BOOST_TEST(test_create_generator_auto("012", l));
// test optional
boost::optional<int> o;
BOOST_TEST(test_create_generator_auto("", o));
o = 1;
BOOST_TEST(test_create_generator_auto("1", o));
// test alternative
boost::variant<int, double, float, std::string> vv;
vv = 1;
BOOST_TEST(test_create_generator_auto("1", vv));
vv = 1.0;
BOOST_TEST(test_create_generator_auto("1.0", vv));
vv = 1.0f;
BOOST_TEST(test_create_generator_auto("1.0", vv));
vv = "some string";
BOOST_TEST(test_create_generator_auto("some string", vv));
// test fusion sequence
std::pair<int, double> p (1, 2.0);
BOOST_TEST(test_create_generator_auto("12.0", p));
}
return boost::report_errors();
}
|