aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2021-05-31 12:56:34 -0400
committerJason Merrill <jason@redhat.com>2021-06-07 23:54:52 -0400
commita1b3484a8e6c53c8084723e3f1738d402374198e (patch)
tree012a47256adb80641208470421db8d6c6b31546d /gcc
parent438aac594e1c5ad32b787e8753b3893044ecf26f (diff)
downloadgcc-a1b3484a8e6c53c8084723e3f1738d402374198e.zip
gcc-a1b3484a8e6c53c8084723e3f1738d402374198e.tar.gz
gcc-a1b3484a8e6c53c8084723e3f1738d402374198e.tar.bz2
c++: alias member template [PR100102]
Patrick already fixed the primary cause of this bug. But while I was looking at this testcase I noticed that with the qualified name k::o we ended up with a plain FUNCTION_DECL, whereas without the k:: we got a BASELINK. There seems to be no good reason not to return the BASELINK in this case as well. PR c++/100102 gcc/cp/ChangeLog: * init.c (build_offset_ref): Return the BASELINK for a static member function. gcc/testsuite/ChangeLog: * g++.dg/cpp0x/alias-decl-73.C: New test.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/init.c2
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/alias-decl-73.C9
2 files changed, 10 insertions, 1 deletions
diff --git a/gcc/cp/init.c b/gcc/cp/init.c
index b112328..1b161d5 100644
--- a/gcc/cp/init.c
+++ b/gcc/cp/init.c
@@ -2214,7 +2214,7 @@ build_offset_ref (tree type, tree member, bool address_p,
if (!ok)
return error_mark_node;
if (DECL_STATIC_FUNCTION_P (t))
- return t;
+ return member;
member = t;
}
else
diff --git a/gcc/testsuite/g++.dg/cpp0x/alias-decl-73.C b/gcc/testsuite/g++.dg/cpp0x/alias-decl-73.C
new file mode 100644
index 0000000..aae7786
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/alias-decl-73.C
@@ -0,0 +1,9 @@
+// PR c++/100102
+// { dg-do compile { target c++11 } }
+
+template <bool B1> using a = int;
+template <class T3, class T4> struct k {
+ static long o();
+ template <class T5> using n = a<bool(k::o)>;
+ n<int> q;
+};