Chris@102
|
1 /*=============================================================================
|
Chris@102
|
2 Copyright (c) 2001-2014 Joel de Guzman
|
Chris@102
|
3 Copyright (c) 2001-2011 Hartmut Kaiser
|
Chris@102
|
4 Copyright (c) 2013 Agustin Berge
|
Chris@102
|
5
|
Chris@102
|
6 Distributed under the Boost Software License, Version 1.0. (See accompanying
|
Chris@102
|
7 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@102
|
8 =============================================================================*/
|
Chris@102
|
9 #if !defined(SPIRIT_NO_SKIP_JAN_16_2010_0802PM)
|
Chris@102
|
10 #define SPIRIT_NO_SKIP_JAN_16_2010_0802PM
|
Chris@102
|
11
|
Chris@102
|
12 #if defined(_MSC_VER)
|
Chris@102
|
13 #pragma once
|
Chris@102
|
14 #endif
|
Chris@102
|
15
|
Chris@102
|
16 #include <boost/spirit/home/x3/support/context.hpp>
|
Chris@102
|
17 #include <boost/spirit/home/x3/support/unused.hpp>
|
Chris@102
|
18 #include <boost/spirit/home/x3/core/skip_over.hpp>
|
Chris@102
|
19 #include <boost/spirit/home/x3/core/parser.hpp>
|
Chris@102
|
20 #include <boost/type_traits/remove_reference.hpp>
|
Chris@102
|
21 #include <boost/utility/enable_if.hpp>
|
Chris@102
|
22
|
Chris@102
|
23 namespace boost { namespace spirit { namespace x3
|
Chris@102
|
24 {
|
Chris@102
|
25 // same as lexeme[], but does not pre-skip
|
Chris@102
|
26 template <typename Subject>
|
Chris@102
|
27 struct no_skip_directive : unary_parser<Subject, no_skip_directive<Subject>>
|
Chris@102
|
28 {
|
Chris@102
|
29 typedef unary_parser<Subject, no_skip_directive<Subject> > base_type;
|
Chris@102
|
30 static bool const is_pass_through_unary = true;
|
Chris@102
|
31 static bool const handles_container = Subject::handles_container;
|
Chris@102
|
32
|
Chris@102
|
33 no_skip_directive(Subject const& subject)
|
Chris@102
|
34 : base_type(subject) {}
|
Chris@102
|
35
|
Chris@102
|
36 template <typename Iterator, typename Context
|
Chris@102
|
37 , typename RContext, typename Attribute>
|
Chris@102
|
38 typename enable_if<has_skipper<Context>, bool>::type
|
Chris@102
|
39 parse(Iterator& first, Iterator const& last
|
Chris@102
|
40 , Context const& context, RContext& rcontext, Attribute& attr) const
|
Chris@102
|
41 {
|
Chris@102
|
42 auto const& skipper = x3::get<skipper_tag>(context);
|
Chris@102
|
43
|
Chris@102
|
44 typedef unused_skipper<
|
Chris@102
|
45 typename remove_reference<decltype(skipper)>::type>
|
Chris@102
|
46 unused_skipper_type;
|
Chris@102
|
47 unused_skipper_type unused_skipper(skipper);
|
Chris@102
|
48
|
Chris@102
|
49 return this->subject.parse(
|
Chris@102
|
50 first, last
|
Chris@102
|
51 , make_context<skipper_tag>(unused_skipper, context)
|
Chris@102
|
52 , rcontext
|
Chris@102
|
53 , attr);
|
Chris@102
|
54 }
|
Chris@102
|
55 template <typename Iterator, typename Context
|
Chris@102
|
56 , typename RContext, typename Attribute>
|
Chris@102
|
57 typename disable_if<has_skipper<Context>, bool>::type
|
Chris@102
|
58 parse(Iterator& first, Iterator const& last
|
Chris@102
|
59 , Context const& context, RContext& rcontext, Attribute& attr) const
|
Chris@102
|
60 {
|
Chris@102
|
61 return this->subject.parse(
|
Chris@102
|
62 first, last
|
Chris@102
|
63 , context
|
Chris@102
|
64 , rcontext
|
Chris@102
|
65 , attr);
|
Chris@102
|
66 }
|
Chris@102
|
67 };
|
Chris@102
|
68
|
Chris@102
|
69 struct no_skip_gen
|
Chris@102
|
70 {
|
Chris@102
|
71 template <typename Subject>
|
Chris@102
|
72 no_skip_directive<typename extension::as_parser<Subject>::value_type>
|
Chris@102
|
73 operator[](Subject const& subject) const
|
Chris@102
|
74 {
|
Chris@102
|
75 return {as_parser(subject)};
|
Chris@102
|
76 }
|
Chris@102
|
77 };
|
Chris@102
|
78
|
Chris@102
|
79 no_skip_gen const no_skip = no_skip_gen();
|
Chris@102
|
80 }}}
|
Chris@102
|
81
|
Chris@102
|
82 #endif
|