From: Tom Tromey Date: Thu, 23 Jan 2003 21:19:50 +0000 (+0000) Subject: expr.c (build_known_method_ref): Use method's context to find method table index. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1f369e606fac3810e79ef0c0d4fd353a43d0d2b4;p=gcc.git expr.c (build_known_method_ref): Use method's context to find method table index. * expr.c (build_known_method_ref): Use method's context to find method table index. From-SVN: r61670 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 092d5bdc0d6..3050610a291 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,8 @@ +2003-01-23 Tom Tromey + + * expr.c (build_known_method_ref): Use method's context to find + method table index. + 2003-01-23 Tom Tromey * constants.c (set_constant_entry): Allocated cleared memory. diff --git a/gcc/java/expr.c b/gcc/java/expr.c index bf1f41b5414..5ce92e00376 100644 --- a/gcc/java/expr.c +++ b/gcc/java/expr.c @@ -1748,13 +1748,16 @@ build_known_method_ref (tree method, tree method_type ATTRIBUTE_UNUSED, SELF_TYPE->methods[METHOD_INDEX].ncode - This is guaranteed to work (assuming SELF_TYPE has - been initialized), since if the method is not compiled yet, - its ncode points to a trampoline that forces compilation. */ + */ int method_index = 0; - tree meth; - tree ref = build_class_ref (self_type); + tree meth, ref; + + /* The method might actually be declared in some superclass, so + we have to use its class context, not the caller's notion of + where the method is. */ + self_type = DECL_CONTEXT (method); + ref = build_class_ref (self_type); ref = build1 (INDIRECT_REF, class_type_node, ref); if (ncode_ident == NULL_TREE) ncode_ident = get_identifier ("ncode");