From 76dc15d4539e501051e446382de43f3e876e49f2 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek <jakub@redhat.com> Date: Mon, 2 Jul 2007 14:59:49 +0200 Subject: [PATCH] re PR c++/31748 (bad diagnostic for invalid private clause) PR c++/31748 * semantics.c (finish_omp_clauses): Use %qD instead of %qE for DECL_P in not a variable and appears more than once error messages. * g++.dg/gomp/pr31748.C: New test. From-SVN: r126201 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/semantics.c | 7 +++++-- gcc/testsuite/ChangeLog | 3 +++ gcc/testsuite/g++.dg/gomp/pr31748.C | 10 ++++++++++ 4 files changed, 24 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/g++.dg/gomp/pr31748.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index aeb0e5c720a1..b25e051187ba 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2007-07-02 Jakub Jelinek <jakub@redhat.com> + + PR c++/31748 + * semantics.c (finish_omp_clauses): Use %qD instead of %qE for + DECL_P in not a variable and appears more than once error messages. + 2007-07-01 Ollie Wild <aaw@google.com> * name-lookup.c (ambiguous_decl): Fix case when new->value is hidden. diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index dc4a9f7a9f93..6b0d4073b0ad 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -3377,14 +3377,17 @@ finish_omp_clauses (tree clauses) { if (processing_template_decl) break; - error ("%qE is not a variable in clause %qs", t, name); + if (DECL_P (t)) + error ("%qD is not a variable in clause %qs", t, name); + else + error ("%qE is not a variable in clause %qs", t, name); remove = true; } else if (bitmap_bit_p (&generic_head, DECL_UID (t)) || bitmap_bit_p (&firstprivate_head, DECL_UID (t)) || bitmap_bit_p (&lastprivate_head, DECL_UID (t))) { - error ("%qE appears more than once in data clauses", t); + error ("%qD appears more than once in data clauses", t); remove = true; } else diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index fee89cf8df61..a4cfc1f017a8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -3,6 +3,9 @@ * g++.dg/opt/nrv12.C: New test. * gcc.target/i386/nrv1.c: New test. + PR c++/31748 + * g++.dg/gomp/pr31748.C: New test. + 2007-07-02 Ira Rosen <irar@il.ibm.com> PR tree-optimization/32230 diff --git a/gcc/testsuite/g++.dg/gomp/pr31748.C b/gcc/testsuite/g++.dg/gomp/pr31748.C new file mode 100644 index 000000000000..516978d2860d --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr31748.C @@ -0,0 +1,10 @@ +// PR c++/31748 + +struct A; + +void +foo () +{ +#pragma omp parallel private(A) // { dg-error "struct A.*is not a variable" } + ; +} -- GitLab