liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
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
/*=============================================================================
    Boost.Wave: A Standard compliant C++ preprocessor library
 
    http://www.boost.org/
 
    Copyright (c) 2001-2012 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)
=============================================================================*/
 
#if !defined(BOOST_CPP_DEFINED_GRAMMAR_GEN_HPP_825BE9F5_98A3_400D_A97C_AD76B3B08632_INCLUDED)
#define BOOST_CPP_DEFINED_GRAMMAR_GEN_HPP_825BE9F5_98A3_400D_A97C_AD76B3B08632_INCLUDED
 
#include <boost/wave/wave_config.hpp>
 
#include <list>
 
#include <boost/spirit/include/classic_parser.hpp>
#include <boost/pool/pool_alloc.hpp>
 
#include <boost/wave/util/unput_queue_iterator.hpp>
 
// this must occur after all of the includes and before any code appears
#ifdef BOOST_HAS_ABI_HEADERS
#include BOOST_ABI_PREFIX
#endif
 
// suppress warnings about dependent classes not being exported from the dll
#ifdef BOOST_MSVC
#pragma warning(push)
#pragma warning(disable : 4251 4231 4660)
#endif
 
///////////////////////////////////////////////////////////////////////////////
namespace boost {
namespace wave {
namespace grammars {
 
template <typename LexIteratorT>
struct BOOST_WAVE_DECL defined_grammar_gen
{
    typedef typename LexIteratorT::token_type token_type;
    typedef std::list<token_type, boost::fast_pool_allocator<token_type> >
        token_sequence_type;
 
    //  The parse_operator_defined function is instantiated manually twice to
    //  simplify the explicit specialization of this template. This way the user
    //  has only to specify one template parameter (the lexer iterator type) to
    //  correctly formulate the required explicit specialization.
    //  This results in no code overhead, because otherwise the function would be
    //  generated by the compiler twice anyway.
 
    typedef boost::wave::util::unput_queue_iterator<
            typename token_sequence_type::iterator, token_type, token_sequence_type>
        iterator1_type;
 
    typedef boost::wave::util::unput_queue_iterator<
            LexIteratorT, token_type, token_sequence_type>
        iterator2_type;
 
    //  parse the operator defined and return the found qualified name
    static boost::spirit::classic::parse_info<iterator1_type>
    parse_operator_defined (iterator1_type const &first,
        iterator1_type const &last, token_sequence_type &found_qualified_name);
 
    static boost::spirit::classic::parse_info<iterator2_type>
    parse_operator_defined (iterator2_type const &first,
        iterator2_type const &last, token_sequence_type &found_qualified_name);
};
 
///////////////////////////////////////////////////////////////////////////////
}   // namespace grammars
}   // namespace wave
}   // namespace boost
 
#ifdef BOOST_MSVC
#pragma warning(pop)
#endif
 
// the suffix header occurs after all of the code
#ifdef BOOST_HAS_ABI_HEADERS
#include BOOST_ABI_SUFFIX
#endif
 
#endif // !defined(BOOST_CPP_DEFINED_GRAMMAR_GEN_HPP_825BE9F5_98A3_400D_A97C_AD76B3B08632_INCLUDED)