From abf353fb5f2cb275f93170b048ebfcccf73d9e39 Mon Sep 17 00:00:00 2001 From: aph Date: Mon, 29 Jan 2007 13:14:38 +0000 Subject: 2007-01-26 Andrew Haley * java/lang/natClass.cc (initializeClass): Re-throw SecurityExceptions. * java/lang/natVMClassLoader.cc (loadClass): checkPackageAccess. * java/lang/ClassLoader.java: (loadClass): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@121285 138bc75d-0d04-0410-961f-82ee72b054a4 --- libjava/java/lang/natVMClassLoader.cc | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'libjava/java/lang/natVMClassLoader.cc') diff --git a/libjava/java/lang/natVMClassLoader.cc b/libjava/java/lang/natVMClassLoader.cc index 2db2429c927..3e5ff3ec70e 100644 --- a/libjava/java/lang/natVMClassLoader.cc +++ b/libjava/java/lang/natVMClassLoader.cc @@ -32,8 +32,10 @@ details. */ #include #include #include +#include #include #include +#include #include java::lang::Class * @@ -204,6 +206,16 @@ java::lang::VMClassLoader::nativeFindClass (jstring name) jclass java::lang::VMClassLoader::loadClass(jstring name, jboolean resolve) { + using namespace ::java::lang; + + SecurityManager *sm = (SecurityManager *)SecurityManager::current; + if (sm) + { + jint lastDot = name->lastIndexOf('.'); + if (lastDot != -1) + sm->checkPackageAccess(name->substring(0, lastDot)); + } + // We try the boot loader first, so that the endorsed directory // overrides compiled-in classes. jclass klass = NULL; -- cgit v1.2.3