From: Nathan Sidwell Date: Tue, 20 Jun 2000 16:13:33 +0000 (+0000) Subject: * rtti.c (get_base_offset): Cope when vbase field is in a base. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0f1e25b0d72e2ed1acda264536f5fa35df873bd2;p=gcc.git * rtti.c (get_base_offset): Cope when vbase field is in a base. From-SVN: r34619 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index b4167416a3c..3be1d2afcbd 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +2000-06-20 Nathan Sidwell + + * rtti.c (get_base_offset): Cope when vbase field is in a base. + 2000-06-20 Nathan Sidwell * call.c (build_conditional_expr): Use VOID_TYPE_P. diff --git a/gcc/cp/rtti.c b/gcc/cp/rtti.c index 8bf17d985ab..98a4582e308 100644 --- a/gcc/cp/rtti.c +++ b/gcc/cp/rtti.c @@ -549,10 +549,25 @@ get_base_offset (binfo, parent) else if (! vbase_offsets_in_vtable_p ()) { const char *name; + tree result; + tree field; FORMAT_VBASE_NAME (name, BINFO_TYPE (binfo)); - return byte_position (lookup_field (parent, get_identifier (name), - 0, 0)); + field = lookup_field (parent, get_identifier (name), 0, 0); + result = byte_position (field); + + if (DECL_CONTEXT (field) != parent) + { + /* The vbase pointer might be in a non-virtual base of PARENT. + * Adjust for the offset of that base in PARENT. */ + tree path; + + get_base_distance (DECL_CONTEXT (field), parent, -1, &path); + result = build (PLUS_EXPR, TREE_TYPE (result), + result, BINFO_OFFSET (path)); + result = fold (result); + } + return result; } else /* Under the new ABI, we store the vtable offset at which