aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2020-03-18 08:53:23 +0100
committerJakub Jelinek <jakub@redhat.com>2020-03-18 08:53:23 +0100
commitaf8656be8df68ac26840f7844430fd595255ebd2 (patch)
treecad0e122dc2aa53b77ae439efa2921fa06c2a681 /gcc/cp
parent52b3aa8be18938486065f5f2a23553b134a10a81 (diff)
downloadgcc-af8656be8df68ac26840f7844430fd595255ebd2.zip
gcc-af8656be8df68ac26840f7844430fd595255ebd2.tar.gz
gcc-af8656be8df68ac26840f7844430fd595255ebd2.tar.bz2
c++: Diagnose a deduction guide in a wrong scope [PR91759]
The following testcase is accepts-invalid since r7-6608-ga56c0ac08242269b. Before that change we had this "deduction guide %qD must be declared in the same scope as %qT" diagnostics for it, after the change it is expected to be diagnosed in set_decl_namespace at the not_found: label in there. On this testcase nothing is diagnosed though, because set_decl_namespace isn't called at all, as in_namespace is NULL. The following patch restores the old warning but does it only in case we don't call set_decl_namespace. 2020-03-18 Jakub Jelinek <jakub@redhat.com> PR c++/91759 * decl.c (grokfndecl): Restore old diagnostics about deduction guide declared in different scope if in_namespace is NULL_TREE. * g++.dg/cpp1z/class-deduction72.C: New test.
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/decl.c9
2 files changed, 15 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 1db1e09..9aaa81a 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2020-03-18 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91759
+ * decl.c (grokfndecl): Restore old diagnostics about deduction
+ guide declared in different scope if in_namespace is NULL_TREE.
+
2020-03-17 Jakub Jelinek <jakub@redhat.com>
PR c++/90995
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index d240436..319b7ee 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -9644,6 +9644,15 @@ grokfndecl (tree ctype,
"namespace scope", decl);
return NULL_TREE;
}
+ tree type = TREE_TYPE (DECL_NAME (decl));
+ if (in_namespace == NULL_TREE
+ && CP_DECL_CONTEXT (decl) != CP_TYPE_CONTEXT (type))
+ {
+ error_at (location, "deduction guide %qD must be declared in the "
+ "same scope as %qT", decl, type);
+ inform (location_of (type), " declared here");
+ return NULL_TREE;
+ }
if (funcdef_flag)
error_at (location,
"deduction guide %qD must not have a function body", decl);