diff options
author | Tom Tromey <tromey@redhat.com> | 2002-03-23 01:19:40 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2002-03-23 01:19:40 +0000 |
commit | c58408bf8deb973f7aecbff4c80a093ba2203569 (patch) | |
tree | 9d22513daa79990d80e17edc0c4ea1c4f7260107 /gcc/java/expr.c | |
parent | b216cd4ae3bd06a171b0b2db41d79d4b6f818008 (diff) | |
download | gcc-c58408bf8deb973f7aecbff4c80a093ba2203569.zip gcc-c58408bf8deb973f7aecbff4c80a093ba2203569.tar.gz gcc-c58408bf8deb973f7aecbff4c80a093ba2203569.tar.bz2 |
Andrew Haley <aph@cambridge.redhat.com>
2002-03-22 Tom Tromey <tromey@redhat.com>
Andrew Haley <aph@cambridge.redhat.com>
* expr.c (build_field_ref): Don't build a check if the field is a
member of `this'.
From-SVN: r51213
Diffstat (limited to 'gcc/java/expr.c')
-rw-r--r-- | gcc/java/expr.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/java/expr.c b/gcc/java/expr.c index fa2935f..2a8e2e3 100644 --- a/gcc/java/expr.c +++ b/gcc/java/expr.c @@ -1582,6 +1582,10 @@ build_field_ref (self_value, self_class, name) } else { + int check = (flag_check_references + && ! (DECL_P (self_value) + && DECL_NAME (self_value) == this_identifier_node)); + tree base_handle_type = promote_type (base_class); if (base_handle_type != TREE_TYPE (self_value)) self_value = fold (build1 (NOP_EXPR, base_handle_type, self_value)); @@ -1589,7 +1593,7 @@ build_field_ref (self_value, self_class, name) self_value = unhand_expr (self_value); #endif self_value = build_java_indirect_ref (TREE_TYPE (TREE_TYPE (self_value)), - self_value, flag_check_references); + self_value, check); return fold (build (COMPONENT_REF, TREE_TYPE (field_decl), self_value, field_decl)); } |