From 85b20612e78772cce5700f4e6e5afcef072d4703 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 10 Mar 2008 20:43:16 +0100 Subject: [PATCH] re PR c++/35337 (Broken diagnostic for firstprivate clause) PR c++/35337 * 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/pr35337.C: New test. From-SVN: r133086 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/semantics.c | 14 ++++++++++---- gcc/testsuite/ChangeLog | 3 +++ gcc/testsuite/g++.dg/gomp/pr35337.C | 20 ++++++++++++++++++++ 4 files changed, 39 insertions(+), 4 deletions(-) create mode 100644 gcc/testsuite/g++.dg/gomp/pr35337.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6415063aa79..4ae8f17330f 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2008-03-10 Jakub Jelinek + + PR c++/35337 + * semantics.c (finish_omp_clauses): Use %qD instead of %qE for + DECL_P in not a variable and appears more than once error messages. + 2008-03-07 Paolo Bonzini Revert: diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 472c5cc72f2..2ee67cbf4dc 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -3400,13 +3400,16 @@ finish_omp_clauses (tree clauses) { if (processing_template_decl) break; - error ("%qE is not a variable in clause %", t); + if (DECL_P (t)) + error ("%qD is not a variable in clause %", t); + else + error ("%qE is not a variable in clause %", t); remove = true; } else if (bitmap_bit_p (&generic_head, DECL_UID (t)) || bitmap_bit_p (&firstprivate_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 @@ -3419,13 +3422,16 @@ finish_omp_clauses (tree clauses) { if (processing_template_decl) break; - error ("%qE is not a variable in clause %", t); + if (DECL_P (t)) + error ("%qD is not a variable in clause %", t); + else + error ("%qE is not a variable in clause %", t); remove = true; } else if (bitmap_bit_p (&generic_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 1427ceaae92..22c6ee81639 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2008-03-10 Jakub Jelinek + PR c++/35337 + * g++.dg/gomp/pr35337.C: New test. + PR c/35438 PR c/35439 * gcc.dg/gomp/pr35438.c: New test. diff --git a/gcc/testsuite/g++.dg/gomp/pr35337.C b/gcc/testsuite/g++.dg/gomp/pr35337.C new file mode 100644 index 00000000000..2e9ca6b207f --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr35337.C @@ -0,0 +1,20 @@ +// PR c++/35337 +// { dg-do compile } +// { dg-options "-fopenmp" } + +struct A { }; + +void +foo () +{ +#pragma omp parallel firstprivate(A) // { dg-error "struct A\[^\n\]*is not a variable" } + ; +} + +void +bar () +{ +#pragma omp for lastprivate(A) // { dg-error "struct A\[^\n\]*is not a variable" } + for (int i = 0; i < 10; i++) + ; +}