diff options
author | Jakub Jelinek <jakub@redhat.com> | 2005-09-22 18:34:58 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2005-09-22 18:34:58 +0200 |
commit | 16a1369ec35a3941e274bce2bf45dd1d12dbb2df (patch) | |
tree | 01156e735f59c6f7bfc3da148ed985f68a4a666a /gcc/cp/class.c | |
parent | 861fd9a03af8905545c6a069a399b971f4394950 (diff) | |
download | gcc-16a1369ec35a3941e274bce2bf45dd1d12dbb2df.zip gcc-16a1369ec35a3941e274bce2bf45dd1d12dbb2df.tar.gz gcc-16a1369ec35a3941e274bce2bf45dd1d12dbb2df.tar.bz2 |
re PR c++/21983 (multiple diagnostics)
PR c++/21983
* class.c (find_final_overrider): Move diagnostic about no unique final
overrider to...
(update_vtable_entry_for_fn): ... here.
* g++.dg/warn/pr21983.C: New test.
From-SVN: r104533
Diffstat (limited to 'gcc/cp/class.c')
-rw-r--r-- | gcc/cp/class.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/gcc/cp/class.c b/gcc/cp/class.c index 7fdeb87..35e7cb9 100644 --- a/gcc/cp/class.c +++ b/gcc/cp/class.c @@ -1906,11 +1906,7 @@ find_final_overrider (tree derived, tree binfo, tree fn) /* If there was no winner, issue an error message. */ if (!ffod.candidates || TREE_CHAIN (ffod.candidates)) - { - error ("no unique final overrider for %qD in %qT", fn, - BINFO_TYPE (derived)); - return error_mark_node; - } + return error_mark_node; return ffod.candidates; } @@ -1970,7 +1966,10 @@ update_vtable_entry_for_fn (tree t, tree binfo, tree fn, tree* virtuals, /* Find the final overrider. */ overrider = find_final_overrider (TYPE_BINFO (t), b, target_fn); if (overrider == error_mark_node) - return; + { + error ("no unique final overrider for %qD in %qT", target_fn, t); + return; + } overrider_target = overrider_fn = TREE_PURPOSE (overrider); /* Check for adjusting covariant return types. */ |