aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2001-12-21 21:59:27 +0000
committerTom Tromey <tromey@gcc.gnu.org>2001-12-21 21:59:27 +0000
commitd47eb5d3f27cd5a42271366d82a4691ae5b931ee (patch)
tree54f9b84c2732cc330a0ac803e8b772e9bf190d7d
parent655781b7af994b586ae96c191d4ae2d3c2c33822 (diff)
downloadgcc-d47eb5d3f27cd5a42271366d82a4691ae5b931ee.zip
gcc-d47eb5d3f27cd5a42271366d82a4691ae5b931ee.tar.gz
gcc-d47eb5d3f27cd5a42271366d82a4691ae5b931ee.tar.bz2
re PR java/5165 (Loading class fields with a ConstantValue attribute)
Fix for PR java/5165: * java/lang/natClassLoader.cc (_Jv_PrepareCompiledClass): Convert any constant string field to a String; not just final fields. From-SVN: r48255
-rw-r--r--libjava/ChangeLog5
-rw-r--r--libjava/java/lang/natClassLoader.cc8
2 files changed, 8 insertions, 5 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index a9ce352..b4daf82 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,5 +1,10 @@
2001-12-21 Tom Tromey <tromey@redhat.com>
+ Fix for PR java/5165:
+ * java/lang/natClassLoader.cc (_Jv_PrepareCompiledClass):
+ Convert any constant string field to a String; not just final
+ fields.
+
Fix for PR libgcj/2428:
* java/lang/natClass.cc: Include RuntimePermission.h.
(getClassLoader): Define.
diff --git a/libjava/java/lang/natClassLoader.cc b/libjava/java/lang/natClassLoader.cc
index a6f7b60..75d9e32 100644
--- a/libjava/java/lang/natClassLoader.cc
+++ b/libjava/java/lang/natClassLoader.cc
@@ -292,12 +292,10 @@ _Jv_PrepareCompiledClass (jclass klass)
for (int n = JvNumStaticFields (klass); n > 0; --n)
{
int mod = f->getModifiers ();
- // Maybe the compiler should mark these with
- // _Jv_FIELD_CONSTANT_VALUE? For now we just know that this
- // only happens for constant strings.
+ // If we have a static String field with a non-null initial
+ // value, we know it points to a Utf8Const.
if (f->getClass () == &StringClass
- && java::lang::reflect::Modifier::isStatic (mod)
- && java::lang::reflect::Modifier::isFinal (mod))
+ && java::lang::reflect::Modifier::isStatic (mod))
{
jstring *strp = (jstring *) f->u.addr;
if (*strp)