diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 106dfe556f7fd7c9ff2af2cbfbf7f9254316b3cf..59df79484bfd826e3d70fb098c558e940aa39558 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -6584,6 +6584,10 @@ get_underlying_template (tree tmpl) != num_innermost_template_parms (underlying))) break; + /* Does the alias add cv-quals? */ + if (TYPE_QUALS (TREE_TYPE (underlying)) != TYPE_QUALS (TREE_TYPE (tmpl))) + break; + tree alias_args = INNERMOST_TEMPLATE_ARGS (generic_targs_for (tmpl)); if (!comp_template_args (TI_ARGS (tinfo), alias_args)) break; diff --git a/gcc/testsuite/g++.dg/cpp0x/alias-decl-equiv1.C b/gcc/testsuite/g++.dg/cpp0x/alias-decl-equiv1.C new file mode 100644 index 0000000000000000000000000000000000000000..ae27c43bc0a03e62486b40c7fdb3c7e19a7d03df --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/alias-decl-equiv1.C @@ -0,0 +1,13 @@ +// PR c++/100032 +// { dg-do compile { target c++11 } } + +template <template<class> class> struct X { }; +template <class> struct Y { }; +template <class T> using Z = const Y<T>; + +template <class T> using W = Z<T>; +using U = X<Z>; +using U = X<W>; + +using T = X<Y>; +using T = X<Z>; // { dg-error "conflicting declaration" }