diff options
author | Tom Tromey <tromey@redhat.com> | 2002-12-05 00:49:30 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2002-12-05 00:49:30 +0000 |
commit | 76508852a0241db33b2512c0b460cdf06f7e0ce5 (patch) | |
tree | 55c5e4e7a3fc1386a525f3b48aea94a0f0b26bef /libjava | |
parent | 67f1b906114cdfc69b72e7135f34162ec6a67cc0 (diff) | |
download | gcc-76508852a0241db33b2512c0b460cdf06f7e0ce5.zip gcc-76508852a0241db33b2512c0b460cdf06f7e0ce5.tar.gz gcc-76508852a0241db33b2512c0b460cdf06f7e0ce5.tar.bz2 |
Makefile.in: Rebuilt.
* Makefile.in: Rebuilt.
* Makefile.am (nat_source_files): Added natVMSecurityManager,
natResourceBundle.
* java/util/ResourceBundle.java (Security): Removed.
(getCallingClassLoader): Now native.
* java/util/natResourceBundle.cc: New file.
* java/lang/natVMSecurityManager.cc: New file.
* java/lang/VMSecurityManager.java (getClassContext): Now native.
From-SVN: r59840
Diffstat (limited to 'libjava')
-rw-r--r-- | libjava/ChangeLog | 11 | ||||
-rw-r--r-- | libjava/Makefile.am | 2 | ||||
-rw-r--r-- | libjava/Makefile.in | 24 | ||||
-rw-r--r-- | libjava/java/lang/VMSecurityManager.java | 8 | ||||
-rw-r--r-- | libjava/java/lang/natVMSecurityManager.cc | 54 | ||||
-rw-r--r-- | libjava/java/util/ResourceBundle.java | 45 | ||||
-rw-r--r-- | libjava/java/util/natResourceBundle.cc | 34 | ||||
-rw-r--r-- | libjava/prims.cc | 2 |
8 files changed, 121 insertions, 59 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 0fb8c6a..4d7c7ff 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,14 @@ +2002-12-04 Tom Tromey <tromey@redhat.com> + + * Makefile.in: Rebuilt. + * Makefile.am (nat_source_files): Added natVMSecurityManager, + natResourceBundle. + * java/util/ResourceBundle.java (Security): Removed. + (getCallingClassLoader): Now native. + * java/util/natResourceBundle.cc: New file. + * java/lang/natVMSecurityManager.cc: New file. + * java/lang/VMSecurityManager.java (getClassContext): Now native. + 2002-12-03 Mark Wielaard <mark@klomp.org> * java/util/jar/JarFile.java (manifest): Not final. diff --git a/libjava/Makefile.am b/libjava/Makefile.am index 9c7eb96..b993d50 100644 --- a/libjava/Makefile.am +++ b/libjava/Makefile.am @@ -2337,6 +2337,7 @@ java/lang/natString.cc \ java/lang/natStringBuffer.cc \ java/lang/natSystem.cc \ java/lang/natThread.cc \ +java/lang/natVMSecurityManager.cc \ java/lang/ref/natReference.cc \ java/lang/reflect/natArray.cc \ java/lang/reflect/natConstructor.cc \ @@ -2348,6 +2349,7 @@ java/net/natInetAddress.cc \ java/net/natPlainDatagramSocketImpl.cc \ java/net/natPlainSocketImpl.cc \ java/text/natCollator.cc \ +java/util/natResourceBundle.cc \ java/util/natTimeZone.cc \ java/util/zip/natDeflater.cc \ java/util/zip/natInflater.cc diff --git a/libjava/Makefile.in b/libjava/Makefile.in index 994002e..8b74b39 100644 --- a/libjava/Makefile.in +++ b/libjava/Makefile.in @@ -2086,6 +2086,7 @@ java/lang/natString.cc \ java/lang/natStringBuffer.cc \ java/lang/natSystem.cc \ java/lang/natThread.cc \ +java/lang/natVMSecurityManager.cc \ java/lang/ref/natReference.cc \ java/lang/reflect/natArray.cc \ java/lang/reflect/natConstructor.cc \ @@ -2097,6 +2098,7 @@ java/net/natInetAddress.cc \ java/net/natPlainDatagramSocketImpl.cc \ java/net/natPlainSocketImpl.cc \ java/text/natCollator.cc \ +java/util/natResourceBundle.cc \ java/util/natTimeZone.cc \ java/util/zip/natDeflater.cc \ java/util/zip/natInflater.cc @@ -2244,12 +2246,13 @@ java/lang/natClassLoader.lo java/lang/natConcreteProcess.lo \ java/lang/natDouble.lo java/lang/natFloat.lo java/lang/natMath.lo \ java/lang/natObject.lo java/lang/natRuntime.lo java/lang/natString.lo \ java/lang/natStringBuffer.lo java/lang/natSystem.lo \ -java/lang/natThread.lo java/lang/ref/natReference.lo \ -java/lang/reflect/natArray.lo java/lang/reflect/natConstructor.lo \ -java/lang/reflect/natField.lo java/lang/reflect/natMethod.lo \ -java/lang/reflect/natProxy.lo java/net/natNetworkInterface.lo \ -java/net/natInetAddress.lo java/net/natPlainDatagramSocketImpl.lo \ -java/net/natPlainSocketImpl.lo java/text/natCollator.lo \ +java/lang/natThread.lo java/lang/natVMSecurityManager.lo \ +java/lang/ref/natReference.lo java/lang/reflect/natArray.lo \ +java/lang/reflect/natConstructor.lo java/lang/reflect/natField.lo \ +java/lang/reflect/natMethod.lo java/lang/reflect/natProxy.lo \ +java/net/natNetworkInterface.lo java/net/natInetAddress.lo \ +java/net/natPlainDatagramSocketImpl.lo java/net/natPlainSocketImpl.lo \ +java/text/natCollator.lo java/util/natResourceBundle.lo \ java/util/natTimeZone.lo java/util/zip/natDeflater.lo \ java/util/zip/natInflater.lo libgcjx_la_OBJECTS = gnu/gcj/xlib/natClip.lo \ @@ -2959,8 +2962,9 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \ .deps/java/lang/natMath.P .deps/java/lang/natObject.P \ .deps/java/lang/natRuntime.P .deps/java/lang/natString.P \ .deps/java/lang/natStringBuffer.P .deps/java/lang/natSystem.P \ -.deps/java/lang/natThread.P .deps/java/lang/ref/PhantomReference.P \ -.deps/java/lang/ref/Reference.P .deps/java/lang/ref/ReferenceQueue.P \ +.deps/java/lang/natThread.P .deps/java/lang/natVMSecurityManager.P \ +.deps/java/lang/ref/PhantomReference.P .deps/java/lang/ref/Reference.P \ +.deps/java/lang/ref/ReferenceQueue.P \ .deps/java/lang/ref/SoftReference.P .deps/java/lang/ref/WeakReference.P \ .deps/java/lang/ref/natReference.P \ .deps/java/lang/reflect/AccessibleObject.P \ @@ -3286,8 +3290,8 @@ DEP_FILES = .deps/$(srcdir)/$(CONVERT_DIR)/gen-from-JIS.P \ .deps/java/util/jar/JarException.P .deps/java/util/jar/JarFile.P \ .deps/java/util/jar/JarInputStream.P \ .deps/java/util/jar/JarOutputStream.P .deps/java/util/jar/Manifest.P \ -.deps/java/util/natTimeZone.P .deps/java/util/regex/Matcher.P \ -.deps/java/util/regex/Pattern.P \ +.deps/java/util/natResourceBundle.P .deps/java/util/natTimeZone.P \ +.deps/java/util/regex/Matcher.P .deps/java/util/regex/Pattern.P \ .deps/java/util/regex/PatternSyntaxException.P \ .deps/java/util/zip/Adler32.P .deps/java/util/zip/CRC32.P \ .deps/java/util/zip/CheckedInputStream.P \ diff --git a/libjava/java/lang/VMSecurityManager.java b/libjava/java/lang/VMSecurityManager.java index fd16804..f6f0645 100644 --- a/libjava/java/lang/VMSecurityManager.java +++ b/libjava/java/lang/VMSecurityManager.java @@ -1,6 +1,6 @@ /* * java.lang.SecurityManager: part of the Java Class Libraries project. - * Copyright (C) 1998, 2001 Free Software Foundation + * Copyright (C) 1998, 2001, 2002 Free Software Foundation * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public @@ -43,11 +43,7 @@ class VMSecurityManager ** @return an array containing all the methods on classes ** on the Java execution stack. **/ - static Class[] getClassContext() - { - // FIXME: can't yet implement this for libgcj. - return new Class[0]; - } + static native Class[] getClassContext(); /** Get the current ClassLoader--the one nearest to the ** top of the stack. diff --git a/libjava/java/lang/natVMSecurityManager.cc b/libjava/java/lang/natVMSecurityManager.cc new file mode 100644 index 0000000..7b88e8a --- /dev/null +++ b/libjava/java/lang/natVMSecurityManager.cc @@ -0,0 +1,54 @@ +/* Copyright (C) 2002 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +// Written by Tom Tromey <tromey@redhat.com> + +#include <config.h> + +#include <gcj/cni.h> +#include <jvm.h> +#include <java/lang/VMSecurityManager.h> +#include <java/lang/SecurityManager.h> +#include <java/lang/ClassLoader.h> +#include <java/lang/Class.h> +#include <gnu/gcj/runtime/StackTrace.h> + +JArray<jclass> * +java::lang::VMSecurityManager::getClassContext () +{ + JArray<jclass> *result = NULL; + gnu::gcj::runtime::StackTrace *t = new gnu::gcj::runtime::StackTrace(); + if (t) + { + int maxlen = t->length(); + + int len = 0; + while (len < maxlen) + { + jclass klass = t->classAt(len); + if (klass != NULL && klass != &java::lang::VMSecurityManager::class$ + && klass != &java::lang::SecurityManager::class$) + ++len; + } + + result = + (JArray<jclass> *) _Jv_NewObjectArray (len, &java::lang::Class::class$, + NULL); + + len = 0; + while (len < maxlen) + { + jclass klass = t->classAt(len); + if (klass != NULL && klass != &java::lang::VMSecurityManager::class$ + && klass != &java::lang::SecurityManager::class$) + elements(result)[len++] = klass; + } + } + + return result; +} diff --git a/libjava/java/util/ResourceBundle.java b/libjava/java/util/ResourceBundle.java index bfb6b30..ecc63af 100644 --- a/libjava/java/util/ResourceBundle.java +++ b/libjava/java/util/ResourceBundle.java @@ -42,8 +42,6 @@ import java.lang.ref.Reference; import java.lang.ref.SoftReference; import java.io.InputStream; import java.io.IOException; -import java.security.AccessController; -import java.security.PrivilegedAction; import gnu.classpath.Configuration; /** @@ -105,44 +103,7 @@ public abstract class ResourceBundle */ private Locale locale; - /** - * We override SecurityManager in order to access getClassContext(). - */ - private static final class Security extends SecurityManager - { - /** - * Avoid accessor method of private constructor. - */ - Security() - { - } - - /** - * Return the ClassLoader of the class which called into this - * ResourceBundle, or null if it cannot be determined. - */ - ClassLoader getCallingClassLoader() - { - Class[] stack = getClassContext(); - for (int i = 0; i < stack.length; i++) - if (stack[i] != Security.class && stack[i] != ResourceBundle.class) - return stack[i].getClassLoader(); - return null; - } - } - - /** A security context for grabbing the correct class loader. */ - private static final Security security - = (Security) AccessController.doPrivileged(new PrivilegedAction() - { - // This will always work since java.util classes have (all) system - // permissions. - public Object run() - { - return new Security(); - } - } - ); + private static native ClassLoader getCallingClassLoader(); /** * The resource bundle cache. This is a two-level hash map: The key @@ -256,7 +217,7 @@ public abstract class ResourceBundle public static final ResourceBundle getBundle(String baseName) { return getBundle(baseName, Locale.getDefault(), - security.getCallingClassLoader()); + getCallingClassLoader()); } /** @@ -274,7 +235,7 @@ public abstract class ResourceBundle public static final ResourceBundle getBundle(String baseName, Locale locale) { - return getBundle(baseName, locale, security.getCallingClassLoader()); + return getBundle(baseName, locale, getCallingClassLoader()); } /** diff --git a/libjava/java/util/natResourceBundle.cc b/libjava/java/util/natResourceBundle.cc new file mode 100644 index 0000000..9d142e0 --- /dev/null +++ b/libjava/java/util/natResourceBundle.cc @@ -0,0 +1,34 @@ +/* Copyright (C) 2002 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +// Written by Tom Tromey <tromey@redhat.com> + +#include <config.h> + +#include <gcj/cni.h> +#include <jvm.h> +#include <java/util/ResourceBundle.h> +#include <java/lang/SecurityManager.h> +#include <java/lang/ClassLoader.h> +#include <java/lang/Class.h> +#include <gnu/gcj/runtime/StackTrace.h> + +java::lang::ClassLoader * +java::util::ResourceBundle::getCallingClassLoader () +{ + gnu::gcj::runtime::StackTrace *t = new gnu::gcj::runtime::StackTrace(6); + if (! t) + return NULL; + for (int i = 3; i < 6; ++i) + { + jclass klass = t->classAt(i); + if (klass != NULL) + return klass->getClassLoaderInternal(); + } + return NULL; +} diff --git a/libjava/prims.cc b/libjava/prims.cc index 9244587..2195db1 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -397,7 +397,7 @@ _Jv_AllocObject (jclass klass, jint size) // if there really is an interesting finalizer. // Unfortunately, we still have to the dynamic test, since there may // be cni calls to this routine. - // Nore that on IA64 get_finalizer() returns the starting address of the + // Note that on IA64 get_finalizer() returns the starting address of the // function, not a function pointer. Thus this still works. if (klass->vtable->get_finalizer () != java::lang::Object::class$.vtable->get_finalizer ()) |