Chris@16
|
1 // Copyright (c) 2001-2011 Hartmut Kaiser
|
Chris@16
|
2 //
|
Chris@16
|
3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
|
Chris@16
|
4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
5
|
Chris@16
|
6 #if !defined(BOOST_SPIRIT_KARMA_PADDING_MAY_06_2008_0436PM)
|
Chris@16
|
7 #define BOOST_SPIRIT_KARMA_PADDING_MAY_06_2008_0436PM
|
Chris@16
|
8
|
Chris@16
|
9 #if defined(_MSC_VER)
|
Chris@16
|
10 #pragma once
|
Chris@16
|
11 #endif
|
Chris@16
|
12
|
Chris@16
|
13 #include <boost/spirit/home/support/common_terminals.hpp>
|
Chris@16
|
14 #include <boost/spirit/home/support/info.hpp>
|
Chris@16
|
15
|
Chris@16
|
16 #include <boost/spirit/home/karma/domain.hpp>
|
Chris@16
|
17 #include <boost/spirit/home/karma/meta_compiler.hpp>
|
Chris@16
|
18 #include <boost/spirit/home/karma/delimit_out.hpp>
|
Chris@16
|
19 #include <boost/spirit/home/karma/auxiliary/lazy.hpp>
|
Chris@16
|
20 #include <boost/spirit/home/karma/detail/generate_to.hpp>
|
Chris@16
|
21 #include <boost/spirit/home/support/unused.hpp>
|
Chris@16
|
22 #include <boost/fusion/include/at.hpp>
|
Chris@16
|
23 #include <boost/fusion/include/vector.hpp>
|
Chris@16
|
24
|
Chris@16
|
25 ///////////////////////////////////////////////////////////////////////////////
|
Chris@16
|
26 namespace boost { namespace spirit
|
Chris@16
|
27 {
|
Chris@16
|
28 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
29 // Enablers
|
Chris@16
|
30 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
31
|
Chris@16
|
32 // enables pad(...)
|
Chris@16
|
33 template <typename A0>
|
Chris@16
|
34 struct use_terminal<karma::domain
|
Chris@16
|
35 , terminal_ex<tag::pad, fusion::vector1<A0> > >
|
Chris@16
|
36 : mpl::true_ {};
|
Chris@16
|
37
|
Chris@16
|
38 // enables lazy pad(...)
|
Chris@16
|
39 template <>
|
Chris@16
|
40 struct use_lazy_terminal<karma::domain, tag::pad, 1>
|
Chris@16
|
41 : mpl::true_ {};
|
Chris@16
|
42
|
Chris@16
|
43 }}
|
Chris@16
|
44
|
Chris@16
|
45 ///////////////////////////////////////////////////////////////////////////////
|
Chris@16
|
46 namespace boost { namespace spirit { namespace karma
|
Chris@16
|
47 {
|
Chris@16
|
48 #ifndef BOOST_SPIRIT_NO_PREDEFINED_TERMINALS
|
Chris@16
|
49 using boost::spirit::pad;
|
Chris@16
|
50 #endif
|
Chris@16
|
51 using boost::spirit::pad_type;
|
Chris@16
|
52
|
Chris@16
|
53 struct binary_padding_generator
|
Chris@16
|
54 : primitive_generator<binary_padding_generator>
|
Chris@16
|
55 {
|
Chris@16
|
56 typedef mpl::int_<generator_properties::tracking> properties;
|
Chris@16
|
57
|
Chris@16
|
58 template <typename Context, typename Unused>
|
Chris@16
|
59 struct attribute
|
Chris@16
|
60 {
|
Chris@16
|
61 typedef unused_type type;
|
Chris@16
|
62 };
|
Chris@16
|
63
|
Chris@16
|
64 binary_padding_generator(int numpadbytes)
|
Chris@16
|
65 : numpadbytes_(numpadbytes)
|
Chris@16
|
66 {}
|
Chris@16
|
67
|
Chris@16
|
68 template <
|
Chris@16
|
69 typename OutputIterator, typename Context, typename Delimiter
|
Chris@16
|
70 , typename Attribute>
|
Chris@16
|
71 bool generate(OutputIterator& sink, Context&, Delimiter const& d
|
Chris@16
|
72 , Attribute const& /*attr*/) const
|
Chris@16
|
73 {
|
Chris@16
|
74 std::size_t count = sink.get_out_count() % numpadbytes_;
|
Chris@16
|
75 if (count)
|
Chris@16
|
76 count = numpadbytes_ - count;
|
Chris@16
|
77
|
Chris@16
|
78 bool result = true;
|
Chris@16
|
79 while (result && count-- != 0)
|
Chris@16
|
80 result = detail::generate_to(sink, '\0');
|
Chris@16
|
81
|
Chris@16
|
82 if (result)
|
Chris@16
|
83 result = karma::delimit_out(sink, d); // always do post-delimiting
|
Chris@16
|
84 return result;
|
Chris@16
|
85 }
|
Chris@16
|
86
|
Chris@16
|
87 template <typename Context>
|
Chris@16
|
88 static info what(Context const&)
|
Chris@16
|
89 {
|
Chris@16
|
90 return info("pad");
|
Chris@16
|
91 }
|
Chris@16
|
92
|
Chris@16
|
93 int numpadbytes_;
|
Chris@16
|
94 };
|
Chris@16
|
95
|
Chris@16
|
96 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
97 // Generator generators: make_xxx function (objects)
|
Chris@16
|
98 ///////////////////////////////////////////////////////////////////////////
|
Chris@16
|
99 template <typename Modifiers, typename A0>
|
Chris@16
|
100 struct make_primitive<
|
Chris@16
|
101 terminal_ex<tag::pad, fusion::vector1<A0> >
|
Chris@16
|
102 , Modifiers>
|
Chris@16
|
103 {
|
Chris@16
|
104 typedef binary_padding_generator result_type;
|
Chris@16
|
105
|
Chris@16
|
106 template <typename Terminal>
|
Chris@16
|
107 result_type operator()(Terminal const& term, unused_type) const
|
Chris@16
|
108 {
|
Chris@16
|
109 return result_type(fusion::at_c<0>(term.args));
|
Chris@16
|
110 }
|
Chris@16
|
111 };
|
Chris@16
|
112
|
Chris@16
|
113 }}}
|
Chris@16
|
114
|
Chris@16
|
115 #endif
|