• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*=============================================================================
2     Copyright (c) 2001-2011 Hartmut Kaiser
3     Copyright (c) 2011 Brian O'Kennedy
4 
5     Distributed under the Boost Software License, Version 1.0. (See accompanying
6     file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7 =============================================================================*/
8 
9 #include <boost/config/warning_disable.hpp>
10 #include <boost/detail/lightweight_test.hpp>
11 
12 #include <boost/spirit/include/qi_char.hpp>
13 #include <boost/spirit/include/qi_numeric.hpp>
14 #include <boost/spirit/include/qi_stream.hpp>
15 #include <boost/spirit/include/qi_operator.hpp>
16 
17 #include "test.hpp"
18 
19 struct complex
20 {
complexcomplex21     complex (double a = 0.0, double b = 0.0) : a(a), b(b) {}
22     double a, b;
23 };
24 
operator >>(std::istream & is,complex & z)25 std::istream& operator>> (std::istream& is, complex& z)
26 {
27     char lbrace = '\0', comma = '\0', rbrace = '\0';
28     is >> lbrace >> z.a >> comma >> z.b >> rbrace;
29     if (lbrace != '{' || comma != ',' || rbrace != '}')
30         is.setstate(std::ios_base::failbit);
31 
32     return is;
33 }
34 
main()35 int main()
36 {
37     using spirit_test::test_attr;
38 
39     {
40         using boost::spirit::qi::blank;
41         using boost::spirit::qi::double_;
42         using boost::spirit::qi::stream;
43         using boost::spirit::qi::stream_parser;
44         using boost::fusion::at_c;
45 
46         complex c;
47         BOOST_TEST(test_attr("{1.0,2.5}",
48                 stream_parser<char, complex>(), c, blank) &&
49             c.a == 1.0 && c.b == 2.5);
50 
51         boost::variant<complex, double> cd;
52         BOOST_TEST(test_attr("{1.0",
53                 stream_parser<char, complex>() | "{" >> double_, cd, blank) &&
54             boost::get<double>(cd) == 1.0);
55 
56         boost::fusion::vector<complex, double> d;
57         BOOST_TEST(test_attr("{1.0,2.5},123.456",
58                 stream >> ',' >> double_, d, blank) &&
59             at_c<0>(d).a == 1.0 && at_c<0>(d).b == 2.5 && at_c<1>(d) == 123.456);
60     }
61 
62     return boost::report_errors();
63 }
64 
65 
66