Chris@16
|
1 /*=============================================================================
|
Chris@16
|
2 Copyright (c) 2001-2011 Joel de Guzman
|
Chris@16
|
3 Copyright (c) 2001-2011 Hartmut Kaiser
|
Chris@16
|
4
|
Chris@16
|
5 Distributed under the Boost Software License, Version 1.0. (See accompanying
|
Chris@16
|
6 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
7 =============================================================================*/
|
Chris@16
|
8 #if !defined(SPIRIT_EXPECT_APRIL_29_2007_0445PM)
|
Chris@16
|
9 #define SPIRIT_EXPECT_APRIL_29_2007_0445PM
|
Chris@16
|
10
|
Chris@16
|
11 #if defined(_MSC_VER)
|
Chris@16
|
12 #pragma once
|
Chris@16
|
13 #endif
|
Chris@16
|
14
|
Chris@16
|
15 #include <boost/spirit/home/qi/operator/sequence_base.hpp>
|
Chris@16
|
16 #include <boost/spirit/home/qi/detail/expect_function.hpp>
|
Chris@16
|
17 #include <boost/spirit/home/qi/meta_compiler.hpp>
|
Chris@16
|
18 #include <boost/spirit/home/support/has_semantic_action.hpp>
|
Chris@16
|
19 #include <boost/spirit/home/support/handles_container.hpp>
|
Chris@16
|
20 #include <boost/spirit/home/support/info.hpp>
|
Chris@16
|
21 #include <stdexcept>
|
Chris@16
|
22
|
Chris@16
|
23 namespace boost { namespace spirit
|
Chris@16
|
24 {
|
Chris@16
|
25 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
26 // Enablers
|
Chris@16
|
27 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
28 template <>
|
Chris@16
|
29 struct use_operator<qi::domain, proto::tag::greater> // enables >
|
Chris@16
|
30 : mpl::true_ {};
|
Chris@16
|
31
|
Chris@16
|
32 template <>
|
Chris@16
|
33 struct flatten_tree<qi::domain, proto::tag::greater> // flattens >
|
Chris@16
|
34 : mpl::true_ {};
|
Chris@16
|
35 }}
|
Chris@16
|
36
|
Chris@16
|
37 namespace boost { namespace spirit { namespace qi
|
Chris@16
|
38 {
|
Chris@16
|
39 template <typename Iterator>
|
Chris@16
|
40 struct expectation_failure : std::runtime_error
|
Chris@16
|
41 {
|
Chris@16
|
42 expectation_failure(Iterator first_, Iterator last_, info const& what)
|
Chris@16
|
43 : std::runtime_error("boost::spirit::qi::expectation_failure")
|
Chris@16
|
44 , first(first_), last(last_), what_(what)
|
Chris@16
|
45 {}
|
Chris@16
|
46 ~expectation_failure() throw() {}
|
Chris@16
|
47
|
Chris@16
|
48 Iterator first;
|
Chris@16
|
49 Iterator last;
|
Chris@16
|
50 info what_;
|
Chris@16
|
51 };
|
Chris@16
|
52
|
Chris@16
|
53 template <typename Elements>
|
Chris@16
|
54 struct expect : sequence_base<expect<Elements>, Elements>
|
Chris@16
|
55 {
|
Chris@16
|
56 friend struct sequence_base<expect<Elements>, Elements>;
|
Chris@16
|
57
|
Chris@16
|
58 expect(Elements const& elements)
|
Chris@16
|
59 : sequence_base<expect<Elements>, Elements>(elements) {}
|
Chris@16
|
60
|
Chris@16
|
61 private:
|
Chris@16
|
62
|
Chris@16
|
63 template <typename Iterator, typename Context, typename Skipper>
|
Chris@16
|
64 static detail::expect_function<
|
Chris@16
|
65 Iterator, Context, Skipper
|
Chris@16
|
66 , expectation_failure<Iterator> >
|
Chris@16
|
67 fail_function(
|
Chris@16
|
68 Iterator& first, Iterator const& last
|
Chris@16
|
69 , Context& context, Skipper const& skipper)
|
Chris@16
|
70 {
|
Chris@16
|
71 return detail::expect_function<
|
Chris@16
|
72 Iterator, Context, Skipper, expectation_failure<Iterator> >
|
Chris@16
|
73 (first, last, context, skipper);
|
Chris@16
|
74 }
|
Chris@16
|
75
|
Chris@16
|
76 std::string id() const { return "expect"; }
|
Chris@16
|
77 };
|
Chris@16
|
78
|
Chris@16
|
79 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
80 // Parser generators: make_xxx function (objects)
|
Chris@16
|
81 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
82 template <typename Elements, typename Modifiers>
|
Chris@16
|
83 struct make_composite<proto::tag::greater, Elements, Modifiers>
|
Chris@16
|
84 : make_nary_composite<Elements, expect>
|
Chris@16
|
85 {};
|
Chris@16
|
86 }}}
|
Chris@16
|
87
|
Chris@16
|
88 namespace boost { namespace spirit { namespace traits
|
Chris@16
|
89 {
|
Chris@16
|
90 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
91 template <typename Elements>
|
Chris@16
|
92 struct has_semantic_action<qi::expect<Elements> >
|
Chris@16
|
93 : nary_has_semantic_action<Elements> {};
|
Chris@16
|
94
|
Chris@16
|
95 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
96 template <typename Elements, typename Attribute, typename Context
|
Chris@16
|
97 , typename Iterator>
|
Chris@16
|
98 struct handles_container<qi::expect<Elements>, Attribute, Context
|
Chris@16
|
99 , Iterator>
|
Chris@16
|
100 : mpl::true_ {};
|
Chris@16
|
101 }}}
|
Chris@16
|
102
|
Chris@16
|
103 #endif
|