Chris@16
|
1 /*=============================================================================
|
Chris@16
|
2 Copyright (c) 1999-2003 Jaakko Jarvi
|
Chris@16
|
3 Copyright (c) 1999-2003 Jeremiah Willcock
|
Chris@16
|
4 Copyright (c) 2001-2011 Joel de Guzman
|
Chris@16
|
5
|
Chris@16
|
6 Distributed under the Boost Software License, Version 1.0. (See accompanying
|
Chris@16
|
7 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
8 ==============================================================================*/
|
Chris@16
|
9 #if !defined(FUSION_IN_05052005_0121)
|
Chris@16
|
10 #define FUSION_IN_05052005_0121
|
Chris@16
|
11
|
Chris@16
|
12 #include <istream>
|
Chris@16
|
13 #include <boost/fusion/sequence/io/detail/manip.hpp>
|
Chris@16
|
14
|
Chris@16
|
15 #include <boost/mpl/bool.hpp>
|
Chris@16
|
16 #include <boost/fusion/sequence/intrinsic/begin.hpp>
|
Chris@16
|
17 #include <boost/fusion/sequence/intrinsic/end.hpp>
|
Chris@16
|
18 #include <boost/fusion/iterator/deref.hpp>
|
Chris@16
|
19 #include <boost/fusion/iterator/next.hpp>
|
Chris@16
|
20 #include <boost/fusion/iterator/equal_to.hpp>
|
Chris@16
|
21
|
Chris@16
|
22 namespace boost { namespace fusion { namespace detail
|
Chris@16
|
23 {
|
Chris@16
|
24 template <typename Tag>
|
Chris@16
|
25 struct delimiter_in
|
Chris@16
|
26 {
|
Chris@16
|
27 // read a delimiter
|
Chris@16
|
28 template <typename IS>
|
Chris@16
|
29 static void
|
Chris@16
|
30 read(IS& is, char const* delim, mpl::false_ = mpl::false_())
|
Chris@16
|
31 {
|
Chris@16
|
32 detail::string_ios_manip<Tag, IS> manip(is);
|
Chris@16
|
33 manip.read(delim);
|
Chris@16
|
34 }
|
Chris@16
|
35
|
Chris@16
|
36 template <typename IS>
|
Chris@16
|
37 static void
|
Chris@16
|
38 read(IS&, char const*, mpl::true_)
|
Chris@16
|
39 {
|
Chris@16
|
40 }
|
Chris@16
|
41 };
|
Chris@16
|
42
|
Chris@16
|
43 struct read_sequence_loop
|
Chris@16
|
44 {
|
Chris@16
|
45 template <typename IS, typename First, typename Last>
|
Chris@16
|
46 static void
|
Chris@16
|
47 call(IS&, First const&, Last const&, mpl::true_)
|
Chris@16
|
48 {
|
Chris@16
|
49 }
|
Chris@16
|
50
|
Chris@16
|
51 template <typename IS, typename First, typename Last>
|
Chris@16
|
52 static void
|
Chris@16
|
53 call(IS& is, First const& first, Last const& last, mpl::false_)
|
Chris@16
|
54 {
|
Chris@16
|
55 result_of::equal_to<
|
Chris@16
|
56 typename result_of::next<First>::type
|
Chris@16
|
57 , Last
|
Chris@16
|
58 >
|
Chris@16
|
59 is_last;
|
Chris@16
|
60
|
Chris@16
|
61 is >> *first;
|
Chris@16
|
62 delimiter_in<tuple_delimiter_tag>::read(is, " ", is_last);
|
Chris@16
|
63 call(is, fusion::next(first), last, is_last);
|
Chris@16
|
64 }
|
Chris@16
|
65
|
Chris@16
|
66 template <typename IS, typename First, typename Last>
|
Chris@16
|
67 static void
|
Chris@16
|
68 call(IS& is, First const& first, Last const& last)
|
Chris@16
|
69 {
|
Chris@16
|
70 result_of::equal_to<First, Last> eq;
|
Chris@16
|
71 call(is, first, last, eq);
|
Chris@16
|
72 }
|
Chris@16
|
73 };
|
Chris@16
|
74
|
Chris@16
|
75 template <typename IS, typename Sequence>
|
Chris@16
|
76 inline void
|
Chris@16
|
77 read_sequence(IS& is, Sequence& seq)
|
Chris@16
|
78 {
|
Chris@16
|
79 delimiter_in<tuple_open_tag>::read(is, "(");
|
Chris@16
|
80 read_sequence_loop::call(is, fusion::begin(seq), fusion::end(seq));
|
Chris@16
|
81 delimiter_in<tuple_close_tag>::read(is, ")");
|
Chris@16
|
82 }
|
Chris@16
|
83 }}}
|
Chris@16
|
84
|
Chris@16
|
85 #endif
|