vc7.1 bugfix (ICE)

[SVN r36918]
This commit is contained in:
Joel de Guzman
2007-02-09 12:16:39 +00:00
parent 693200182f
commit 94c2c0e526
7 changed files with 128 additions and 71 deletions

View File

@ -22,6 +22,7 @@
#include <boost/type_traits/add_reference.hpp>
#include <boost/type_traits/add_const.hpp>
#include <boost/fusion/sequence/container/deque/deque_fwd.hpp>
#include <boost/fusion/sequence/container/deque/detail/value_at_impl.hpp>
#include <boost/fusion/sequence/container/deque/detail/at_impl.hpp>
#include <boost/fusion/sequence/container/deque/detail/begin_impl.hpp>
@ -35,9 +36,6 @@ namespace boost { namespace fusion {
struct deque_tag;
struct void_;
template<BOOST_PP_ENUM_PARAMS_WITH_A_DEFAULT(FUSION_MAX_DEQUE_SIZE, typename T, void_)>
struct deque;
template<BOOST_PP_ENUM_PARAMS(FUSION_MAX_DEQUE_SIZE, typename T)>
struct deque
:

View File

@ -0,0 +1,25 @@
/*=============================================================================
Copyright (c) 2005-2007 Joel de Guzman
Copyright (c) 2005-2007 Dan Marsden
Use, modification and distribution is subject to 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_DEQUE_FORWARD_02092007_0749)
#define FUSION_DEQUE_FORWARD_02092007_0749
#include <boost/fusion/sequence/container/deque/limits.hpp>
#include <boost/preprocessor/repetition/enum_params_with_a_default.hpp>
namespace boost { namespace fusion
{
struct void_;
template<
BOOST_PP_ENUM_PARAMS_WITH_A_DEFAULT(
FUSION_MAX_DEQUE_SIZE, typename T, void_)>
struct deque;
}}
#endif

View File

@ -8,10 +8,28 @@
#if !defined(FUSION_AS_10022005_1442)
#define FUSION_AS_10022005_1442
#include <boost/fusion/sequence/conversion.hpp>
namespace boost { namespace fusion { namespace detail
namespace boost { namespace fusion
{
namespace result_of
{
template <typename Sequence>
struct as_list;
template <typename Sequence>
struct as_map;
template <typename Sequence>
struct as_set;
template <typename Sequence>
struct as_vector;
template <typename Sequence>
struct as_deque;
}
namespace detail
{
template <typename Tag>
struct as_impl;
@ -57,7 +75,7 @@ namespace boost { namespace fusion { namespace detail
as_impl<Tag>::template apply<Sequence>::type
type;
};
}}}
}
}}
#endif

View File

@ -8,10 +8,22 @@
#if !defined(FUSION_CLEAR_10022005_1442)
#define FUSION_CLEAR_10022005_1442
#include <boost/fusion/sequence/container.hpp>
#include <boost/fusion/sequence/container/vector/vector_fwd.hpp>
#include <boost/fusion/sequence/container/list/list_fwd.hpp>
#include <boost/fusion/sequence/container/map/map_fwd.hpp>
#include <boost/fusion/sequence/container/set/set_fwd.hpp>
#include <boost/fusion/sequence/container/deque/deque_fwd.hpp>
namespace boost { namespace fusion { namespace detail
namespace boost { namespace fusion
{
struct cons_tag;
struct map_tag;
struct set_tag;
struct vector_tag;
struct deque_tag;
namespace detail
{
template <typename Tag>
struct clear;
@ -27,6 +39,9 @@ namespace boost { namespace fusion { namespace detail
template <>
struct clear<vector_tag> : mpl::identity<vector<> > {};
}}}
template <>
struct clear<deque_tag> : mpl::identity<deque<> > {};
}
}}
#endif

View File

@ -68,7 +68,8 @@ namespace boost { namespace fusion
return i.f(*i.first1, *i.first2);
}
};
}; }
};
}
}}
#endif

View File

@ -62,7 +62,7 @@ namespace boost { namespace fusion
{
template <typename T>
struct category_of
: extension::category_of_impl<typename detail::tag_of<T>::type>::
: extension::category_of_impl<typename fusion::detail::tag_of<T>::type>::
template apply<T>
{};

View File

@ -55,7 +55,7 @@ namespace boost { namespace fusion
{
template <typename T>
struct is_view :
extension::is_view_impl<typename detail::tag_of<T>::type>::
extension::is_view_impl<typename fusion::detail::tag_of<T>::type>::
template apply<T>::type
{};
}