Chris@16
|
1 /*=============================================================================
|
Chris@16
|
2 Copyright (c) 2001-2011 Joel de Guzman
|
Chris@16
|
3
|
Chris@16
|
4 Distributed under the Boost Software License, Version 1.0. (See accompanying
|
Chris@16
|
5 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
6 ==============================================================================*/
|
Chris@16
|
7 #if !defined(FUSION_COPY_02162011_2308)
|
Chris@16
|
8 #define FUSION_COPY_02162011_2308
|
Chris@16
|
9
|
Chris@101
|
10 #include <boost/fusion/support/config.hpp>
|
Chris@16
|
11 #include <boost/fusion/sequence/intrinsic/begin.hpp>
|
Chris@16
|
12 #include <boost/fusion/sequence/intrinsic/end.hpp>
|
Chris@16
|
13 #include <boost/fusion/sequence/intrinsic/size.hpp>
|
Chris@16
|
14 #include <boost/fusion/sequence/comparison/detail/equal_to.hpp>
|
Chris@16
|
15 #include <boost/fusion/support/is_sequence.hpp>
|
Chris@16
|
16 #include <boost/config.hpp>
|
Chris@16
|
17 #include <boost/static_assert.hpp>
|
Chris@16
|
18 #include <boost/utility/enable_if.hpp>
|
Chris@101
|
19 #include <boost/mpl/and.hpp>
|
Chris@16
|
20
|
Chris@16
|
21 #if defined (BOOST_MSVC)
|
Chris@16
|
22 # pragma warning(push)
|
Chris@16
|
23 # pragma warning (disable: 4100) // unreferenced formal parameter
|
Chris@16
|
24 #endif
|
Chris@16
|
25
|
Chris@16
|
26 namespace boost { namespace fusion
|
Chris@16
|
27 {
|
Chris@16
|
28 namespace detail
|
Chris@16
|
29 {
|
Chris@16
|
30 template <typename Seq1, typename Seq2>
|
Chris@16
|
31 struct sequence_copy
|
Chris@16
|
32 {
|
Chris@16
|
33 typedef typename result_of::end<Seq1>::type end1_type;
|
Chris@16
|
34 typedef typename result_of::end<Seq2>::type end2_type;
|
Chris@16
|
35
|
Chris@16
|
36 template <typename I1, typename I2>
|
Chris@101
|
37 BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
|
Chris@16
|
38 static void
|
Chris@16
|
39 call(I1 const&, I2 const&, mpl::true_)
|
Chris@16
|
40 {
|
Chris@16
|
41 }
|
Chris@16
|
42
|
Chris@16
|
43 template <typename I1, typename I2>
|
Chris@101
|
44 BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
|
Chris@16
|
45 static void
|
Chris@16
|
46 call(I1 const& src, I2 const& dest, mpl::false_)
|
Chris@16
|
47 {
|
Chris@16
|
48 *dest = *src;
|
Chris@16
|
49 call(fusion::next(src), fusion::next(dest));
|
Chris@16
|
50 }
|
Chris@16
|
51
|
Chris@16
|
52 template <typename I1, typename I2>
|
Chris@101
|
53 BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
|
Chris@16
|
54 static void
|
Chris@16
|
55 call(I1 const& src, I2 const& dest)
|
Chris@16
|
56 {
|
Chris@16
|
57 typename result_of::equal_to<I1, end1_type>::type eq;
|
Chris@16
|
58 return call(src, dest, eq);
|
Chris@16
|
59 }
|
Chris@16
|
60 };
|
Chris@16
|
61 }
|
Chris@16
|
62
|
Chris@101
|
63 namespace result_of
|
Chris@101
|
64 {
|
Chris@101
|
65 template <typename Seq1, typename Seq2>
|
Chris@101
|
66 struct copy
|
Chris@101
|
67 : enable_if<mpl::and_<
|
Chris@101
|
68 traits::is_sequence<Seq1>,
|
Chris@101
|
69 traits::is_sequence<Seq2>
|
Chris@101
|
70 > > {};
|
Chris@101
|
71 }
|
Chris@101
|
72
|
Chris@16
|
73 template <typename Seq1, typename Seq2>
|
Chris@101
|
74 BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
|
Chris@101
|
75 inline typename result_of::copy<Seq1 const, Seq2>::type
|
Chris@16
|
76 copy(Seq1 const& src, Seq2& dest)
|
Chris@16
|
77 {
|
Chris@16
|
78 BOOST_STATIC_ASSERT(
|
Chris@16
|
79 result_of::size<Seq1>::value <= result_of::size<Seq2>::value);
|
Chris@16
|
80
|
Chris@16
|
81 detail::sequence_copy<
|
Chris@16
|
82 Seq1 const, Seq2>::
|
Chris@16
|
83 call(fusion::begin(src), fusion::begin(dest));
|
Chris@16
|
84 }
|
Chris@16
|
85 }}
|
Chris@16
|
86
|
Chris@16
|
87 #if defined (BOOST_MSVC)
|
Chris@16
|
88 # pragma warning(pop)
|
Chris@16
|
89 #endif
|
Chris@16
|
90
|
Chris@16
|
91 #endif
|