Erreur du compilateur C2766: «Spécialisation explicite; La «spécialisation» a déjà été définie »lors de l'utilisation de boost :: Disable_If

StackOverflow https://stackoverflow.com/questions/8924325

Question

J'essaye de construire une classe de modèle Fod

template<typename S0 = aux::EmptyType, typename S1 = aux::EmptyType, typename S2 = aux::EmptyType, typename S3 = aux::EmptyType, typename S4 = aux::EmptyType, typename S5 = aux::EmptyType, typename S6 = aux::EmptyType, typename S7 = aux::EmptyType, typename S8 = aux::EmptyType, typename S9 = aux::EmptyType>
class Fod { ... };

qui contiendra une classe intérieure avec un static const int value indiquant l'index de l'argument du modèle (0 pour S0, 1 pour S1 et ainsi de suite). Peu de temps, il devrait satisfaire la condition:

struct Type0 {}; struct Type1 {};
BOOST_STATIC_ASSERT( (Fod<Type0>::At<Type0>::value == 0) );
BOOST_STATIC_ASSERT( (Fod<Type0, Type1>::At<Type0>::value == 0) );
BOOST_STATIC_ASSERT( (Fod<Type0, Type1>::At<Type1>::value == 1) );

J'ai essayé d'utiliser boost::disable_if comme suit:

template<class T, class Enable = void>
class At; // undefined

template<>
struct At<S0, typename boost::disable_if<boost::is_same<S0, aux::EmptyType> >::type > {
    static const int value = 0;
};

template<>
struct At<S1, typename boost::disable_if<boost::is_same<S1, aux::EmptyType> >::type > {
    static const int value = 1;
};

template<>
struct At<S2, typename boost::disable_if<boost::is_same<S2, aux::EmptyType> >::type > {
    static const int value = 2;
};

template<>
struct At<S3, typename boost::disable_if<boost::is_same<S3, aux::EmptyType> >::type > {
    static const int value = 3;
};

// and so on for S4...S9

Mais cela entraîne une erreur lorsque je définis la spécialisation pour S3 et les deux S2, S3 sont du même type aux::EmptyType (ou: je définis la spécialisation pour S2 et les deux S1, S2 sont du même type).

4>C:\phd\cpp\src\boost/dst/fod.hpp(144): error C2766: explicit specialization ; 'boost::dst::fod<S0>::At<boost::dst::aux::EmptyType,boost::mpl::s_item<T,Base>>' has already been defined
4>          with
4>          [
4>              S0=Type0
4>          ]
4>          and
4>          [
4>              T=Type0,
4>              Base=boost::mpl::set0<>::item_
4>          ]

Des idées comment résoudre le problème? Et si je voulais une méthode size_t at<S0>() pour donner 0, size_t at<S1>() donner 1 ...?

Veuillez vous demander si vous avez besoin de plus d'informations.

Pas de solution correcte

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top