2012-08-15 4 views
9

Betrachten Sie den folgenden Code ein:Können Sie ein variadisches Vorlagenpaket aus einer Größe und deren Inhalt generieren?

template<unsigned int... TSIZE> 
struct Base {}; 
template<unsigned int TORDER, unsigned int TDIM> 
struct Derived : public Base</* TDIM, TDIM, ... TDIM (TORDER times) */> {}; 

Glauben Sie, dass ein Trick, um die Template-Parameter von Base auf der zweiten Zeile dieses Beispiels korrekt erzeugen existiert? Zum Beispiel möchte ich Derived<3, 5> erben von Base<5, 5, 5>. Wie geht das ?

Antwort

10

Mit etwas TMP, das ist nicht so schwer, nachdem alle:

template<unsigned ToGo, class T, T Arg, template<T...> class Target, T... Args> 
struct generate_pack 
    : generate_pack<ToGo-1, T, Arg, Target, Args..., Arg> 
{ // build up the 'Args' pack by appending 'Arg' ... 
}; 

template<class T, T Arg, template<T...> class Target, T... Args> 
struct generate_pack<0, T, Arg, Target, Args...> 
{ // until there are no more appends to do 
    using type = Target<Args...>; 
}; 

template<unsigned Num, class T, T Arg, template<T...> class Target> 
using GeneratePack = typename generate_pack<Num, T, Arg, Target>::type; 

template<unsigned int... TSIZE> 
struct Base{}; 

template<unsigned int TORDER, unsigned int TDIM> 
struct Derived 
    : GeneratePack<TORDER, unsigned, TDIM, Base> 
{ 
}; 

Live example.

+0

Oh, Sie können rekursiv ableiten? Das ist cool. – jrok

+1

es heißt Vorlage Metafunktion Weiterleitung von den Boost.MPL Autoren. – TemplateRex

Verwandte Themen