diff options
author | Tom Tromey <tromey@cygnus.com> | 1999-11-05 18:27:28 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 1999-11-05 18:27:28 +0000 |
commit | 09e7d04a1b2b2365cc8bc61a0ab41115b653a2ce (patch) | |
tree | 3b52e6e9e1b58af468ce584c71e1c1a47ce2832b /gcc/java/class.c | |
parent | 467403ca5587335ab372bc19f8e261af067afe2f (diff) | |
download | gcc-09e7d04a1b2b2365cc8bc61a0ab41115b653a2ce.zip gcc-09e7d04a1b2b2365cc8bc61a0ab41115b653a2ce.tar.gz gcc-09e7d04a1b2b2365cc8bc61a0ab41115b653a2ce.tar.bz2 |
re GNATS gcj/85 (Compiler optimizes away private methods when native methods might access them)
* class.c (finish_class): Emit inlined methods if any native
methods exist in the class. Fixes PR gcj/85.
From-SVN: r30420
Diffstat (limited to 'gcc/java/class.c')
-rw-r--r-- | gcc/java/class.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/gcc/java/class.c b/gcc/java/class.c index 0333528..57930fde 100644 --- a/gcc/java/class.c +++ b/gcc/java/class.c @@ -1205,7 +1205,21 @@ finish_class () { tree method; tree type_methods = TYPE_METHODS (CLASS_TO_HANDLE_TYPE (current_class)); - + int saw_native_method = 0; + + /* Find out if we have any native methods. We use this information + later. */ + for (method = type_methods; + method != NULL_TREE; + method = TREE_CHAIN (method)) + { + if (METHOD_NATIVE (method)) + { + saw_native_method = 1; + break; + } + } + /* Emit deferred inline methods. */ for (method = type_methods; method != NULL_TREE; ) { @@ -1214,7 +1228,8 @@ finish_class () /* It's a deferred inline method. Decide if we need to emit it. */ if (flag_keep_inline_functions || TREE_SYMBOL_REFERENCED (DECL_ASSEMBLER_NAME (method)) - || ! METHOD_PRIVATE (method)) + || ! METHOD_PRIVATE (method) + || saw_native_method) { temporary_allocation (); output_inline_function (method); |