Verwenden eines Vorlagenalias anstelle einer Vorlage in einer Vorlage
Aus einer früheren Frage:
Durch Ausführen eines static_assert, dass ein Vorlagentyp eine andere Vorlage ist
Andy Prowl hat mir diesen Code zur Verfügung gestellt, mit dem ich das kannstatic_assert
dass ein Vorlagentyp ein anderer Vorlagentyp ist:
template<template<typename...> class TT, typename... Ts>
struct is_instantiation_of : public std::false_type { };
template<template<typename...> class TT, typename... Ts>
struct is_instantiation_of<TT, TT<Ts...>> : public std::true_type { };
template<typename T>
struct foo {};
template<typename FooType>
struct bar {
static_assert(is_instantiation_of<foo,FooType>::value, ""); //success
};
int main(int,char**)
{
bar<foo<int>> b; //success
return 0;
}
Das funktioniert super.
Aber wenn ich den Code so ändere, benutze ich einen Alias vonfoo
Dinge gehen schlecht:
template<template<typename...> class TT, typename... Ts>
struct is_instantiation_of : public std::false_type { };
template<template<typename...> class TT, typename... Ts>
struct is_instantiation_of<TT, TT<Ts...>> : public std::true_type { };
template<typename T>
struct foo {};
//Added: alias for foo
template<typename T>
using foo_alt = foo<T>;
template<typename FooType>
struct bar {
//Changed: want to use foo_alt instead of foo here
static_assert(is_instantiation_of<foo_alt,FooType>::value, ""); //fail
};
int main(int,char**) {
//both of these fail:
bar<foo<int>> b;
bar<foo_alt<int>> b2;
return 0;
}
Kann das gelöst werden?