From: Jim Kingdon Date: Fri, 26 Apr 1991 23:00:55 +0000 (+0000) Subject: * symfile.c (fill_in_vptr_fieldno): Don't call check_stub_type. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7cc4387940ab7594e38782cc41a78d9c79496c09;p=binutils-gdb.git * symfile.c (fill_in_vptr_fieldno): Don't call check_stub_type. Return void not int. (also declarations in symfile.h and value.h). Deal with multiple inheritance. --- diff --git a/gdb/symfile.c b/gdb/symfile.c index 5241959dc0c..e1345dbcb83 100644 --- a/gdb/symfile.c +++ b/gdb/symfile.c @@ -681,18 +681,28 @@ reread_symbols () } } - /* This function is really horrible, but to avoid it, there would need to be more filling in of forward references. */ -int +void fill_in_vptr_fieldno (type) struct type *type; { - check_stub_type (type); if (TYPE_VPTR_FIELDNO (type) < 0) - TYPE_VPTR_FIELDNO (type) = - fill_in_vptr_fieldno (TYPE_BASECLASS (type, 1)); - return TYPE_VPTR_FIELDNO (type); + { + int i; + for (i = 1; i < TYPE_N_BASECLASSES (type); i++) + { + fill_in_vptr_fieldno (TYPE_BASECLASS (type, i)); + if (TYPE_VPTR_FIELDNO (TYPE_BASECLASS (type, i)) >= 0) + { + TYPE_VPTR_FIELDNO (type) + = TYPE_VPTR_FIELDNO (TYPE_BASECLASS (type, i)); + TYPE_VPTR_BASETYPE (type) + = TYPE_VPTR_BASETYPE (TYPE_BASECLASS (type, i)); + break; + } + } + } } /* Functions to handle complaints during symbol reading. */