mirror of
https://github.com/boostorg/fusion.git
synced 2025-07-29 12:07:36 +02:00
+ Fixes Ticket #6016 using a two-level specialization such that specialization is preferred over SFINAE.
+ Removes tag_of_fallback. It's not needed anymore. The proper way is to specialize tag_of. [SVN r74934]
This commit is contained in:
@ -46,28 +46,29 @@ namespace boost { namespace fusion
|
|||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
BOOST_MPL_HAS_XXX_TRAIT_DEF(fusion_tag)
|
BOOST_MPL_HAS_XXX_TRAIT_DEF(fusion_tag)
|
||||||
|
|
||||||
|
template <typename Sequence, typename Active>
|
||||||
|
struct tag_of_impl
|
||||||
|
: mpl::if_<fusion::detail::is_mpl_sequence<Sequence>,
|
||||||
|
mpl::identity<mpl_sequence_tag>,
|
||||||
|
mpl::identity<non_fusion_tag> >::type
|
||||||
|
{};
|
||||||
|
|
||||||
|
template <typename Sequence>
|
||||||
|
struct tag_of_impl<
|
||||||
|
Sequence
|
||||||
|
, typename boost::enable_if<detail::has_fusion_tag<Sequence> >::type>
|
||||||
|
{
|
||||||
|
typedef typename Sequence::fusion_tag type;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace traits
|
namespace traits
|
||||||
{
|
{
|
||||||
template <typename Sequence, typename Active>
|
|
||||||
struct tag_of_fallback
|
|
||||||
{
|
|
||||||
typedef non_fusion_tag type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename Sequence, typename Active>
|
template <typename Sequence, typename Active>
|
||||||
struct tag_of
|
struct tag_of
|
||||||
: mpl::if_< fusion::detail::is_mpl_sequence<Sequence>,
|
: boost::fusion::detail::tag_of_impl<Sequence, Active>
|
||||||
mpl::identity<mpl_sequence_tag>,
|
|
||||||
tag_of_fallback<Sequence> >::type
|
|
||||||
{};
|
{};
|
||||||
|
|
||||||
template <typename Sequence>
|
|
||||||
struct tag_of<Sequence, typename boost::enable_if<detail::has_fusion_tag<Sequence> >::type>
|
|
||||||
{
|
|
||||||
typedef typename Sequence::fusion_tag type;
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
|
@ -12,9 +12,6 @@ namespace boost { namespace fusion
|
|||||||
{
|
{
|
||||||
namespace traits
|
namespace traits
|
||||||
{
|
{
|
||||||
template <typename Sequence, typename Active = void>
|
|
||||||
struct tag_of_fallback;
|
|
||||||
|
|
||||||
template<typename T, typename Active = void>
|
template<typename T, typename Active = void>
|
||||||
struct tag_of;
|
struct tag_of;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user