Boost logo

Boost-Commit :

From: joel_at_[hidden]
Date: 2008-08-20 04:20:41


Author: djowel
Date: 2008-08-20 04:20:40 EDT (Wed, 20 Aug 2008)
New Revision: 48244
URL: http://svn.boost.org/trac/boost/changeset/48244

Log:
conform to TR1 to the letter
Added:
   trunk/boost/fusion/tuple/detail/tuple_expand.hpp
      - copied, changed from r48193, /trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp
Removed:
   trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp
Text files modified:
   trunk/boost/fusion/tuple/detail/tuple_expand.hpp | 24 ++++++++++++++++++++----
   trunk/boost/fusion/tuple/tuple.hpp | 36 +++++++++++++++++++++++++++---------
   2 files changed, 47 insertions(+), 13 deletions(-)

Copied: trunk/boost/fusion/tuple/detail/tuple_expand.hpp (from r48193, /trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp)
==============================================================================
--- /trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp (original)
+++ trunk/boost/fusion/tuple/detail/tuple_expand.hpp 2008-08-20 04:20:40 EDT (Wed, 20 Aug 2008)
@@ -1,19 +1,19 @@
 /*=============================================================================
     Copyright (c) 2001-2006 Joel de Guzman
 
- Distributed under the Boost Software License, Version 1.0. (See accompanying
+ 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)
 ==============================================================================*/
 #ifndef BOOST_PP_IS_ITERATING
-#if !defined(FUSION_TUPLE_FORWARD_CTOR_10032005_0815)
-#define FUSION_TUPLE_FORWARD_CTOR_10032005_0815
+#if !defined(FUSION_TUPLE_EXPAND_10032005_0815)
+#define FUSION_TUPLE_EXPAND_10032005_0815
 
 #include <boost/preprocessor/iterate.hpp>
 #include <boost/preprocessor/repetition/enum_params.hpp>
 #include <boost/preprocessor/repetition/enum_binary_params.hpp>
 
 #define BOOST_PP_FILENAME_1 \
- <boost/fusion/tuple/detail/tuple_forward_ctor.hpp>
+ <boost/fusion/tuple/detail/tuple_expand.hpp>
 #define BOOST_PP_ITERATION_LIMITS (1, FUSION_MAX_VECTOR_SIZE)
 #include BOOST_PP_ITERATE()
 
@@ -34,6 +34,22 @@
         N, typename detail::call_param<T, >::type _))
         : base_type(BOOST_PP_ENUM_PARAMS(N, _)) {}
 
+ template <BOOST_PP_ENUM_PARAMS(N, typename U)>
+ tuple(BOOST_PP_ENUM_BINARY_PARAMS(
+ N, typename detail::call_param<U, >::type _))
+ : base_type(BOOST_PP_ENUM_PARAMS(N, _)) {}
+
+ template <BOOST_PP_ENUM_PARAMS(N, typename U)>
+ tuple(tuple<BOOST_PP_ENUM_PARAMS(N, U)> const& rhs)
+ : base_type(rhs) {}
+
+ template <BOOST_PP_ENUM_PARAMS(N, typename U)>
+ tuple& operator=(tuple<BOOST_PP_ENUM_PARAMS(N, U)> const& rhs)
+ {
+ base_type::operator=(rhs);
+ return *this;
+ }
+
 #undef N
 #endif // defined(BOOST_PP_IS_ITERATING)
 

Deleted: trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp
==============================================================================
--- trunk/boost/fusion/tuple/detail/tuple_forward_ctor.hpp 2008-08-20 04:20:40 EDT (Wed, 20 Aug 2008)
+++ (empty file)
@@ -1,39 +0,0 @@
-/*=============================================================================
- Copyright (c) 2001-2006 Joel de Guzman
-
- 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)
-==============================================================================*/
-#ifndef BOOST_PP_IS_ITERATING
-#if !defined(FUSION_TUPLE_FORWARD_CTOR_10032005_0815)
-#define FUSION_TUPLE_FORWARD_CTOR_10032005_0815
-
-#include <boost/preprocessor/iterate.hpp>
-#include <boost/preprocessor/repetition/enum_params.hpp>
-#include <boost/preprocessor/repetition/enum_binary_params.hpp>
-
-#define BOOST_PP_FILENAME_1 \
- <boost/fusion/tuple/detail/tuple_forward_ctor.hpp>
-#define BOOST_PP_ITERATION_LIMITS (1, FUSION_MAX_VECTOR_SIZE)
-#include BOOST_PP_ITERATE()
-
-#endif
-#else // defined(BOOST_PP_IS_ITERATING)
-///////////////////////////////////////////////////////////////////////////////
-//
-// Preprocessor vertical repetition code
-//
-///////////////////////////////////////////////////////////////////////////////
-
-#define N BOOST_PP_ITERATION()
-
-#if N == 1
- explicit
-#endif
- tuple(BOOST_PP_ENUM_BINARY_PARAMS(
- N, typename detail::call_param<T, >::type _))
- : base_type(BOOST_PP_ENUM_PARAMS(N, _)) {}
-
-#undef N
-#endif // defined(BOOST_PP_IS_ITERATING)
-

Modified: trunk/boost/fusion/tuple/tuple.hpp
==============================================================================
--- trunk/boost/fusion/tuple/tuple.hpp (original)
+++ trunk/boost/fusion/tuple/tuple.hpp 2008-08-20 04:20:40 EDT (Wed, 20 Aug 2008)
@@ -1,7 +1,7 @@
 /*=============================================================================
     Copyright (c) 2005 Joel de Guzman
 
- Distributed under the Boost Software License, Version 1.0. (See accompanying
+ 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(FUSION_TUPLE_10032005_0810)
@@ -16,6 +16,7 @@
 #include <boost/fusion/sequence/io.hpp>
 #include <boost/utility/enable_if.hpp>
 #include <boost/type_traits/is_const.hpp>
+#include <utility>
 
 namespace boost { namespace fusion
 {
@@ -23,17 +24,20 @@
     struct tuple : vector<BOOST_PP_ENUM_PARAMS(FUSION_MAX_VECTOR_SIZE, T)>
     {
         typedef vector<
- BOOST_PP_ENUM_PARAMS(FUSION_MAX_VECTOR_SIZE, T)>
+ BOOST_PP_ENUM_PARAMS(FUSION_MAX_VECTOR_SIZE, T)>
         base_type;
 
         tuple()
             : base_type() {}
-
- template <typename Sequence>
- tuple(Sequence const& rhs)
+
+ tuple(tuple const& rhs)
+ : base_type(rhs) {}
+
+ template <typename U1, typename U2>
+ tuple(std::pair<U1, U2> const& rhs)
             : base_type(rhs) {}
 
- #include <boost/fusion/tuple/detail/tuple_forward_ctor.hpp>
+ #include <boost/fusion/tuple/detail/tuple_expand.hpp>
 
         template <typename T>
         tuple&
@@ -42,16 +46,30 @@
             base_type::operator=(rhs);
             return *this;
         }
+
+ tuple&
+ operator=(tuple const& rhs)
+ {
+ base_type::operator=(rhs);
+ return *this;
+ }
+
+ template <typename U1, typename U2>
+ operator=(std::pair<U1, U2> const& rhs)
+ {
+ base_type::operator=(rhs);
+ return *this;
+ }
     };
 
- template <typename Tuple>
+ template <typename Tuple>
     struct tuple_size : result_of::size<Tuple> {};
 
- template <int N, typename Tuple>
+ template <int N, typename Tuple>
     struct tuple_element : result_of::value_at_c<Tuple, N> {};
 
     template <int N, typename Tuple>
- inline typename
+ inline typename
         lazy_disable_if<
             is_const<Tuple>
           , result_of::at_c<Tuple, N>


Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk