diff options
author | Paolo Carlini <paolo.carlini@oracle.com> | 2019-10-30 11:49:21 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2019-10-30 11:49:21 +0000 |
commit | 0f92815326da137187fdf8841f48f6013a6022ed (patch) | |
tree | d08265e58d236c3f977a4634fafd1cc8d20de227 | |
parent | c425e66b27eb0aa79f1100a6da87f65731ecd8b5 (diff) | |
download | gcc-0f92815326da137187fdf8841f48f6013a6022ed.zip gcc-0f92815326da137187fdf8841f48f6013a6022ed.tar.gz gcc-0f92815326da137187fdf8841f48f6013a6022ed.tar.bz2 |
typeck.c (cp_build_modify_expr): Prefer error + inform to error + error in one place.
/cp
2019-10-30 Paolo Carlini <paolo.carlini@oracle.com>
* typeck.c (cp_build_modify_expr): Prefer error + inform to
error + error in one place.
(get_delta_difference_1): Likewise.
(get_delta_difference): Likewise, in two places.
/testsuite
2019-10-30 Paolo Carlini <paolo.carlini@oracle.com>
* g++.dg/conversion/ptrmem2.C: Adjust for error + inform.
* g++.dg/gomp/tpl-atomic-2.C: Likewise.
From-SVN: r277610
-rw-r--r-- | gcc/cp/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/cp/typeck.c | 10 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/conversion/ptrmem2.C | 20 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/gomp/tpl-atomic-2.C | 4 |
5 files changed, 31 insertions, 15 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index bc2b48e..87a78f2 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,10 @@ +2019-10-30 Paolo Carlini <paolo.carlini@oracle.com> + + * typeck.c (cp_build_modify_expr): Prefer error + inform to + error + error in one place. + (get_delta_difference_1): Likewise. + (get_delta_difference): Likewise, in two places. + 2019-10-29 Paolo Carlini <paolo.carlini@oracle.com> * typeck.c (build_x_unary_op): Use the location_t argument in diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index ad46d42..477c6a3 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -8358,8 +8358,8 @@ cp_build_modify_expr (location_t loc, tree lhs, enum tree_code modifycode, if (newrhs == error_mark_node) { if (complain & tf_error) - error (" in evaluation of %<%Q(%#T, %#T)%>", modifycode, - TREE_TYPE (lhs), TREE_TYPE (rhs)); + inform (loc, " in evaluation of %<%Q(%#T, %#T)%>", + modifycode, TREE_TYPE (lhs), TREE_TYPE (rhs)); return error_mark_node; } @@ -8594,7 +8594,7 @@ get_delta_difference_1 (tree from, tree to, bool c_cast_p, if (!(complain & tf_error)) return error_mark_node; - error (" in pointer to member function conversion"); + inform (input_location, " in pointer to member function conversion"); return size_zero_node; } else if (binfo) @@ -8655,7 +8655,7 @@ get_delta_difference (tree from, tree to, return error_mark_node; error_not_base_type (from, to); - error (" in pointer to member conversion"); + inform (input_location, " in pointer to member conversion"); result = size_zero_node; } else @@ -8674,7 +8674,7 @@ get_delta_difference (tree from, tree to, return error_mark_node; error_not_base_type (from, to); - error (" in pointer to member conversion"); + inform (input_location, " in pointer to member conversion"); result = size_zero_node; } } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 6572962..bac4d00 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-10-30 Paolo Carlini <paolo.carlini@oracle.com> + + * g++.dg/conversion/ptrmem2.C: Adjust for error + inform. + * g++.dg/gomp/tpl-atomic-2.C: Likewise. + 2019-10-30 Martin Liska <mliska@suse.cz> PR lto/91393 diff --git a/gcc/testsuite/g++.dg/conversion/ptrmem2.C b/gcc/testsuite/g++.dg/conversion/ptrmem2.C index d46113d..1dec36b 100644 --- a/gcc/testsuite/g++.dg/conversion/ptrmem2.C +++ b/gcc/testsuite/g++.dg/conversion/ptrmem2.C @@ -15,16 +15,20 @@ int B::*p1 = static_cast<int B::*>(&D::x); int D::*p2 = static_cast<int D::*>(&B::x); // Virtual base class. -int V::*p3 = static_cast<int V::*>(&D::x); // { dg-error "" } -int D::*p4 = static_cast<int D::*>(&V::x); // { dg-error "" } +int V::*p3 = static_cast<int V::*>(&D::x); // { dg-error "virtual base" } +int D::*p4 = static_cast<int D::*>(&V::x); // { dg-error "virtual base" } // Inaccessible base class. -int P::*p5 = static_cast<int P::*>(&D::x); // { dg-error "" } -int D::*p6 = static_cast<int D::*>(&P::x); // { dg-error "" } +int P::*p5 = static_cast<int P::*>(&D::x); // { dg-error "inaccessible base" } +// { dg-message "pointer to member function" "" { target *-*-* } .-1 } +int D::*p6 = static_cast<int D::*>(&P::x); // { dg-error "inaccessible base" } +// { dg-message "pointer to member function" "" { target *-*-* } .-1 } // Ambiguous base class. -int A::*p7 = static_cast<int A::*>(&D::x); // { dg-error "" } -int D::*p8 = static_cast<int D::*>(&A::x); // { dg-error "" } +int A::*p7 = static_cast<int A::*>(&D::x); // { dg-error "ambiguous base" } +// { dg-message "pointer to member function" "" { target *-*-* } .-1 } +int D::*p8 = static_cast<int D::*>(&A::x); // { dg-error "ambiguous base" } +// { dg-message "pointer to member function" "" { target *-*-* } .-1 } // Valid conversions which increase cv-qualification. const int B::*p9 = static_cast<const int B::*>(&D::x); @@ -35,5 +39,5 @@ int B::*p11 = static_cast<int B::*>(p10); // { dg-error "casts away qualifiers" int D::*p12 = static_cast<int D::*>(p9); // { dg-error "casts away qualifiers" } // Attempts to change member type. -float B::*p13 = static_cast<float B::*>(&D::x); // { dg-error "" } -float D::*p14 = static_cast<float D::*>(&B::x); // { dg-error "" } +float B::*p13 = static_cast<float B::*>(&D::x); // { dg-error "invalid .static_cast." } +float D::*p14 = static_cast<float D::*>(&B::x); // { dg-error "invalid .static_cast." } diff --git a/gcc/testsuite/g++.dg/gomp/tpl-atomic-2.C b/gcc/testsuite/g++.dg/gomp/tpl-atomic-2.C index 627c6c6..1591831 100644 --- a/gcc/testsuite/g++.dg/gomp/tpl-atomic-2.C +++ b/gcc/testsuite/g++.dg/gomp/tpl-atomic-2.C @@ -13,14 +13,14 @@ template<typename T> void f1() template<typename T> void f2(float *f) { #pragma omp atomic // { dg-error "invalid" } - *f |= 1; // { dg-error "evaluation" } + *f |= 1; // { dg-message "evaluation" "" { target *-*-* } .-1 } } // Here the rhs is dependent, but not type dependent. template<typename T> void f3(float *f) { #pragma omp atomic // { dg-error "invalid" } - *f |= sizeof (T); // { dg-error "evaluation" } + *f |= sizeof (T); // { dg-message "evaluation" "" { target *-*-* } .-1 } } // And the converse, no error here because we're never fed a T. |