From: Jason Merrill Date: Thu, 25 Feb 2016 14:09:18 +0000 (-0500) Subject: re PR c++/68049 (template instantiation involving may_alias defines symbol twice) X-Git-Tag: basepoints/gcc-7~756 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6284a979dba8e74efe6c36b33311f1b4bac10f44;p=thirdparty%2Fgcc.git re PR c++/68049 (template instantiation involving may_alias defines symbol twice) PR c++/68049 * tree.c (strip_typedefs): Use DECL_ORIGINAL_TYPE. From-SVN: r233715 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 3ae4daf86125..eb5cfe6b5664 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2016-02-25 Jason Merrill + + PR c++/68049 + * tree.c (strip_typedefs): Use DECL_ORIGINAL_TYPE. + 2016-02-25 Patrick Palka PR c++/69736 diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index 0f7287ab0d76..ac38ce3fe116 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -1447,7 +1447,15 @@ strip_typedefs (tree t, bool *remove_attributes) } if (!result) - result = TYPE_MAIN_VARIANT (t); + { + if (typedef_variant_p (t)) + /* Explicitly get the underlying type, as TYPE_MAIN_VARIANT doesn't + strip typedefs with attributes. */ + result = TYPE_MAIN_VARIANT (DECL_ORIGINAL_TYPE (TYPE_NAME (t))); + else + result = TYPE_MAIN_VARIANT (t); + } + gcc_assert (!typedef_variant_p (result)); if (TYPE_USER_ALIGN (t) != TYPE_USER_ALIGN (result) || TYPE_ALIGN (t) != TYPE_ALIGN (result)) { diff --git a/gcc/testsuite/g++.dg/ext/attribute-may-alias-3.C b/gcc/testsuite/g++.dg/ext/attribute-may-alias-3.C new file mode 100644 index 000000000000..ba6091b6d722 --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/attribute-may-alias-3.C @@ -0,0 +1,22 @@ +// PR c++/68049 +// { dg-do compile { target c++11 } } + +template struct Bar +{ + using type = T; +}; +template struct Foo +{ + typedef typename Bar::type alias_type [[gnu::may_alias]]; + + alias_type operator()() { return {}; } +}; + +template void print(T) {} + +int main() +{ + print(Foo()()); + print(0); + return 0; +}