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
This commit is contained in:
parent
67f1b90611
commit
76508852a0
@ -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>
|
2002-12-03 Mark Wielaard <mark@klomp.org>
|
||||||
|
|
||||||
* java/util/jar/JarFile.java (manifest): Not final.
|
* java/util/jar/JarFile.java (manifest): Not final.
|
||||||
|
@ -2337,6 +2337,7 @@ java/lang/natString.cc \
|
|||||||
java/lang/natStringBuffer.cc \
|
java/lang/natStringBuffer.cc \
|
||||||
java/lang/natSystem.cc \
|
java/lang/natSystem.cc \
|
||||||
java/lang/natThread.cc \
|
java/lang/natThread.cc \
|
||||||
|
java/lang/natVMSecurityManager.cc \
|
||||||
java/lang/ref/natReference.cc \
|
java/lang/ref/natReference.cc \
|
||||||
java/lang/reflect/natArray.cc \
|
java/lang/reflect/natArray.cc \
|
||||||
java/lang/reflect/natConstructor.cc \
|
java/lang/reflect/natConstructor.cc \
|
||||||
@ -2348,6 +2349,7 @@ java/net/natInetAddress.cc \
|
|||||||
java/net/natPlainDatagramSocketImpl.cc \
|
java/net/natPlainDatagramSocketImpl.cc \
|
||||||
java/net/natPlainSocketImpl.cc \
|
java/net/natPlainSocketImpl.cc \
|
||||||
java/text/natCollator.cc \
|
java/text/natCollator.cc \
|
||||||
|
java/util/natResourceBundle.cc \
|
||||||
java/util/natTimeZone.cc \
|
java/util/natTimeZone.cc \
|
||||||
java/util/zip/natDeflater.cc \
|
java/util/zip/natDeflater.cc \
|
||||||
java/util/zip/natInflater.cc
|
java/util/zip/natInflater.cc
|
||||||
|
@ -2086,6 +2086,7 @@ java/lang/natString.cc \
|
|||||||
java/lang/natStringBuffer.cc \
|
java/lang/natStringBuffer.cc \
|
||||||
java/lang/natSystem.cc \
|
java/lang/natSystem.cc \
|
||||||
java/lang/natThread.cc \
|
java/lang/natThread.cc \
|
||||||
|
java/lang/natVMSecurityManager.cc \
|
||||||
java/lang/ref/natReference.cc \
|
java/lang/ref/natReference.cc \
|
||||||
java/lang/reflect/natArray.cc \
|
java/lang/reflect/natArray.cc \
|
||||||
java/lang/reflect/natConstructor.cc \
|
java/lang/reflect/natConstructor.cc \
|
||||||
@ -2097,6 +2098,7 @@ java/net/natInetAddress.cc \
|
|||||||
java/net/natPlainDatagramSocketImpl.cc \
|
java/net/natPlainDatagramSocketImpl.cc \
|
||||||
java/net/natPlainSocketImpl.cc \
|
java/net/natPlainSocketImpl.cc \
|
||||||
java/text/natCollator.cc \
|
java/text/natCollator.cc \
|
||||||
|
java/util/natResourceBundle.cc \
|
||||||
java/util/natTimeZone.cc \
|
java/util/natTimeZone.cc \
|
||||||
java/util/zip/natDeflater.cc \
|
java/util/zip/natDeflater.cc \
|
||||||
java/util/zip/natInflater.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/natDouble.lo java/lang/natFloat.lo java/lang/natMath.lo \
|
||||||
java/lang/natObject.lo java/lang/natRuntime.lo java/lang/natString.lo \
|
java/lang/natObject.lo java/lang/natRuntime.lo java/lang/natString.lo \
|
||||||
java/lang/natStringBuffer.lo java/lang/natSystem.lo \
|
java/lang/natStringBuffer.lo java/lang/natSystem.lo \
|
||||||
java/lang/natThread.lo java/lang/ref/natReference.lo \
|
java/lang/natThread.lo java/lang/natVMSecurityManager.lo \
|
||||||
java/lang/reflect/natArray.lo java/lang/reflect/natConstructor.lo \
|
java/lang/ref/natReference.lo java/lang/reflect/natArray.lo \
|
||||||
java/lang/reflect/natField.lo java/lang/reflect/natMethod.lo \
|
java/lang/reflect/natConstructor.lo java/lang/reflect/natField.lo \
|
||||||
java/lang/reflect/natProxy.lo java/net/natNetworkInterface.lo \
|
java/lang/reflect/natMethod.lo java/lang/reflect/natProxy.lo \
|
||||||
java/net/natInetAddress.lo java/net/natPlainDatagramSocketImpl.lo \
|
java/net/natNetworkInterface.lo java/net/natInetAddress.lo \
|
||||||
java/net/natPlainSocketImpl.lo java/text/natCollator.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/natTimeZone.lo java/util/zip/natDeflater.lo \
|
||||||
java/util/zip/natInflater.lo
|
java/util/zip/natInflater.lo
|
||||||
libgcjx_la_OBJECTS = gnu/gcj/xlib/natClip.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/natMath.P .deps/java/lang/natObject.P \
|
||||||
.deps/java/lang/natRuntime.P .deps/java/lang/natString.P \
|
.deps/java/lang/natRuntime.P .deps/java/lang/natString.P \
|
||||||
.deps/java/lang/natStringBuffer.P .deps/java/lang/natSystem.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/natThread.P .deps/java/lang/natVMSecurityManager.P \
|
||||||
.deps/java/lang/ref/Reference.P .deps/java/lang/ref/ReferenceQueue.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/SoftReference.P .deps/java/lang/ref/WeakReference.P \
|
||||||
.deps/java/lang/ref/natReference.P \
|
.deps/java/lang/ref/natReference.P \
|
||||||
.deps/java/lang/reflect/AccessibleObject.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/JarException.P .deps/java/util/jar/JarFile.P \
|
||||||
.deps/java/util/jar/JarInputStream.P \
|
.deps/java/util/jar/JarInputStream.P \
|
||||||
.deps/java/util/jar/JarOutputStream.P .deps/java/util/jar/Manifest.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/natResourceBundle.P .deps/java/util/natTimeZone.P \
|
||||||
.deps/java/util/regex/Pattern.P \
|
.deps/java/util/regex/Matcher.P .deps/java/util/regex/Pattern.P \
|
||||||
.deps/java/util/regex/PatternSyntaxException.P \
|
.deps/java/util/regex/PatternSyntaxException.P \
|
||||||
.deps/java/util/zip/Adler32.P .deps/java/util/zip/CRC32.P \
|
.deps/java/util/zip/Adler32.P .deps/java/util/zip/CRC32.P \
|
||||||
.deps/java/util/zip/CheckedInputStream.P \
|
.deps/java/util/zip/CheckedInputStream.P \
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* java.lang.SecurityManager: part of the Java Class Libraries project.
|
* 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
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* 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
|
** @return an array containing all the methods on classes
|
||||||
** on the Java execution stack.
|
** on the Java execution stack.
|
||||||
**/
|
**/
|
||||||
static Class[] getClassContext()
|
static native Class[] getClassContext();
|
||||||
{
|
|
||||||
// FIXME: can't yet implement this for libgcj.
|
|
||||||
return new Class[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Get the current ClassLoader--the one nearest to the
|
/** Get the current ClassLoader--the one nearest to the
|
||||||
** top of the stack.
|
** top of the stack.
|
||||||
|
54
libjava/java/lang/natVMSecurityManager.cc
Normal file
54
libjava/java/lang/natVMSecurityManager.cc
Normal file
@ -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;
|
||||||
|
}
|
@ -42,8 +42,6 @@ import java.lang.ref.Reference;
|
|||||||
import java.lang.ref.SoftReference;
|
import java.lang.ref.SoftReference;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.PrivilegedAction;
|
|
||||||
import gnu.classpath.Configuration;
|
import gnu.classpath.Configuration;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -105,44 +103,7 @@ public abstract class ResourceBundle
|
|||||||
*/
|
*/
|
||||||
private Locale locale;
|
private Locale locale;
|
||||||
|
|
||||||
/**
|
private static native ClassLoader getCallingClassLoader();
|
||||||
* 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();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The resource bundle cache. This is a two-level hash map: The key
|
* 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)
|
public static final ResourceBundle getBundle(String baseName)
|
||||||
{
|
{
|
||||||
return getBundle(baseName, Locale.getDefault(),
|
return getBundle(baseName, Locale.getDefault(),
|
||||||
security.getCallingClassLoader());
|
getCallingClassLoader());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -274,7 +235,7 @@ public abstract class ResourceBundle
|
|||||||
public static final ResourceBundle getBundle(String baseName,
|
public static final ResourceBundle getBundle(String baseName,
|
||||||
Locale locale)
|
Locale locale)
|
||||||
{
|
{
|
||||||
return getBundle(baseName, locale, security.getCallingClassLoader());
|
return getBundle(baseName, locale, getCallingClassLoader());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
34
libjava/java/util/natResourceBundle.cc
Normal file
34
libjava/java/util/natResourceBundle.cc
Normal file
@ -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;
|
||||||
|
}
|
@ -397,7 +397,7 @@ _Jv_AllocObject (jclass klass, jint size)
|
|||||||
// if there really is an interesting finalizer.
|
// if there really is an interesting finalizer.
|
||||||
// Unfortunately, we still have to the dynamic test, since there may
|
// Unfortunately, we still have to the dynamic test, since there may
|
||||||
// be cni calls to this routine.
|
// 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.
|
// function, not a function pointer. Thus this still works.
|
||||||
if (klass->vtable->get_finalizer ()
|
if (klass->vtable->get_finalizer ()
|
||||||
!= java::lang::Object::class$.vtable->get_finalizer ())
|
!= java::lang::Object::class$.vtable->get_finalizer ())
|
||||||
|
Loading…
Reference in New Issue
Block a user