Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Identity of template aliases

Let's consider a set of template aliases:

template<class T> using foo = T*;
template<class T> using bar = T*;
template<class T> using buz = foo<T>;

template< template<class>class TT > struct id {};

using id_foo = id<foo>;
using id_bar = id<bar>;
using id_buz = id<buz>;

Are id_foo, id_bar, id_buz same or different types? Are foo, bar, buz same or different templates?

Various compilers have different opinions on that. Particularly,

  • MSVC 2015 and clang 3.5 treat they all are different
  • gcc 4.9 treats buz is same as foo

Standard C++11 in the chapter 14.5.7 "Alias templates" is unclear.

like image 366
Nickolay Merkin Avatar asked Mar 16 '15 15:03

Nickolay Merkin


1 Answers

As T.C. pointed out in his comment to the question, this is a known hole of the standard.

The current wording of 14.5.7 [temp.alias] deals only with the equivalence of a specialization of an alias template with the type-id after substitution. Wording needs to be added specifying under what circumstances an alias template itself is equivalent to a class template.

That is: any specialization of foo, bar and buz will represent the same type. But there is no guarantee that, when used as a template parameter, foo, bar and buz are interchangeable.

like image 152
Paolo M Avatar answered Oct 20 '22 02:10

Paolo M