summaryrefslogtreecommitdiffstats
path: root/libjava
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2001-12-21 21:59:27 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2001-12-21 21:59:27 +0000
commitcd33b73a3ec611976b01dbd95ad4170162a44562 (patch)
tree54f9b84c2732cc330a0ac803e8b772e9bf190d7d /libjava
parent9c84a8bd72cd4e24cd20e3f4af5ae72ccaf15c7a (diff)
downloadppe42-gcc-cd33b73a3ec611976b01dbd95ad4170162a44562.tar.gz
ppe42-gcc-cd33b73a3ec611976b01dbd95ad4170162a44562.zip
Fix for PR java/5165:
* java/lang/natClassLoader.cc (_Jv_PrepareCompiledClass): Convert any constant string field to a String; not just final fields. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@48255 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava')
-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 a9ce3528f8c..b4daf82ee9c 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 a6f7b60e4c5..75d9e32ff2e 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)
OpenPOWER on IntegriCloud