From: tromey Date: Wed, 27 Mar 2002 23:12:05 +0000 (+0000) Subject: * expr.c (expand_invoke): Don't generate null pointer check if X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f457b1b8350ea26180d60c739dfd7258552ee41a;p=thirdparty%2Fgcc.git * expr.c (expand_invoke): Don't generate null pointer check if we're calling . git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@51487 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 58cf198e3da2..aba8cdb504db 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,8 @@ +2002-03-27 Tom Tromey + + * expr.c (expand_invoke): Don't generate null pointer check if + we're calling . + 2002-03-27 Neil Booth * expr.c (java_lang_expand_expr): Rename java_expand_expr, diff --git a/gcc/java/expr.c b/gcc/java/expr.c index a25140463f3b..895c3221629b 100644 --- a/gcc/java/expr.c +++ b/gcc/java/expr.c @@ -2129,12 +2129,13 @@ expand_invoke (opcode, method_ref_index, nargs) method's `this'. In other cases we just rely on an optimization pass to eliminate redundant checks. FIXME: Unfortunately there doesn't seem to be a way to determine - what the current method is right now. */ + what the current method is right now. + We do omit the check if we're calling . */ /* We use a SAVE_EXPR here to make sure we only evaluate the new `self' expression once. */ tree save_arg = save_expr (TREE_VALUE (arg_list)); TREE_VALUE (arg_list) = save_arg; - check = java_check_reference (save_arg, 1); + check = java_check_reference (save_arg, ! DECL_INIT_P (method)); func = build_known_method_ref (method, method_type, self_type, method_signature, arg_list); }