From: tromey Date: Wed, 22 Jan 2003 20:53:54 +0000 (+0000) Subject: * expr.c (build_invokeinterface): Abort if method's context is not X-Git-Tag: upstream/4.9.2~82241 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=28cacd2dfa89f2d82bd7051baa0030668a97c05c;p=platform%2Fupstream%2Flinaro-gcc.git * expr.c (build_invokeinterface): Abort if method's context is not an interface. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@61615 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index bdb9917..5d42c0a 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,5 +1,10 @@ 2003-01-22 Tom Tromey + * expr.c (build_invokeinterface): Abort if method's context is not + an interface. + +2003-01-22 Tom Tromey + * gcj.texi (Input and output files): Mention non-class entries. * decl.c (java_init_decl_processing): Call init_resource_processing. diff --git a/gcc/java/expr.c b/gcc/java/expr.c index e5c677c..bf1f41b 100644 --- a/gcc/java/expr.c +++ b/gcc/java/expr.c @@ -1901,15 +1901,16 @@ build_invokeinterface (tree dtable, tree method) abstract nor static. */ if (class_ident == NULL_TREE) - { - class_ident = get_identifier ("class"); - } + class_ident = get_identifier ("class"); - dtable = build_java_indirect_ref (dtable_type, dtable, flag_check_references); + dtable = build_java_indirect_ref (dtable_type, dtable, + flag_check_references); dtable = build (COMPONENT_REF, class_ptr_type, dtable, lookup_field (&dtable_type, class_ident)); interface = DECL_CONTEXT (method); + if (! CLASS_INTERFACE (TYPE_NAME (interface))) + abort (); layout_class_methods (interface); if (flag_indirect_dispatch)