From: Martin v. Löwis Date: Sat, 1 Jan 2000 13:29:44 +0000 (+0000) Subject: * call.c (build_new_method_call): Also check destructors. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1cb47a5cab576fa5725eb857bf801a006a19571a;p=gcc.git * call.c (build_new_method_call): Also check destructors. From-SVN: r31157 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 3fb56b09bd6..630a1fa34db 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +1999-01-01 Martin v. Löwis + + * call.c (build_new_method_call): Also check destructors. + 1999-12-31 Mark Mitchell * cp-tree.h (VF_NORMAL_VALUE): Remove. diff --git a/gcc/cp/call.c b/gcc/cp/call.c index fd5cfeecb35..596cc325309 100644 --- a/gcc/cp/call.c +++ b/gcc/cp/call.c @@ -1,5 +1,5 @@ /* Functions related to invoking methods and overloaded functions. - Copyright (C) 1987, 92-97, 1998, 1999 Free Software Foundation, Inc. + Copyright (C) 1987, 92-99, 2000 Free Software Foundation, Inc. Contributed by Michael Tiemann (tiemann@cygnus.com) and modified by Brendan Kehoe (brendan@cygnus.com). @@ -4321,10 +4321,14 @@ build_new_method_call (instance, name, args, basetype_path, flags) if (DECL_PURE_VIRTUAL_P (cand->fn) && instance == current_class_ref - && DECL_CONSTRUCTOR_P (current_function_decl) + && (DECL_CONSTRUCTOR_P (current_function_decl) + || DECL_DESTRUCTOR_P (current_function_decl)) && ! (flags & LOOKUP_NONVIRTUAL) && value_member (cand->fn, CLASSTYPE_PURE_VIRTUALS (basetype))) - cp_error ("abstract virtual `%#D' called from constructor", cand->fn); + cp_error ((DECL_CONSTRUCTOR_P (current_function_decl) ? + "abstract virtual `%#D' called from constructor" + : "abstract virtual `%#D' called from destructor"), + cand->fn); if (TREE_CODE (TREE_TYPE (cand->fn)) == METHOD_TYPE && is_dummy_object (instance_ptr)) {