aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/lang/natClass.cc
diff options
context:
space:
mode:
authorAndrew Haley <aph@gcc.gnu.org>2007-01-29 13:14:38 +0000
committerAndrew Haley <aph@gcc.gnu.org>2007-01-29 13:14:38 +0000
commit6b05e79165f6d8c5660a874d77f87da41ca934c9 (patch)
tree40df469186ef32efb4fe4cfc7ff23eb2b0c7e713 /libjava/java/lang/natClass.cc
parent2631dfddd2d1492ded5836b7385d3754c9cca33f (diff)
downloadgcc-6b05e79165f6d8c5660a874d77f87da41ca934c9.zip
gcc-6b05e79165f6d8c5660a874d77f87da41ca934c9.tar.gz
gcc-6b05e79165f6d8c5660a874d77f87da41ca934c9.tar.bz2
natClass.cc (initializeClass): Re-throw SecurityExceptions.
2007-01-26 Andrew Haley <aph@redhat.com> * java/lang/natClass.cc (initializeClass): Re-throw SecurityExceptions. * java/lang/natVMClassLoader.cc (loadClass): checkPackageAccess. * java/lang/ClassLoader.java: (loadClass): Likewise. From-SVN: r121285
Diffstat (limited to 'libjava/java/lang/natClass.cc')
-rw-r--r--libjava/java/lang/natClass.cc13
1 files changed, 13 insertions, 0 deletions
diff --git a/libjava/java/lang/natClass.cc b/libjava/java/lang/natClass.cc
index 8ac72a4..8af533b 100644
--- a/libjava/java/lang/natClass.cc
+++ b/libjava/java/lang/natClass.cc
@@ -50,6 +50,7 @@ details. */
#include <java/lang/NullPointerException.h>
#include <java/lang/RuntimePermission.h>
#include <java/lang/System.h>
+#include <java/lang/SecurityException.h>
#include <java/lang/SecurityManager.h>
#include <java/lang/StringBuffer.h>
#include <java/lang/VMClassLoader.h>
@@ -690,6 +691,10 @@ java::lang::Class::initializeClass (void)
{
_Jv_Linker::wait_for_state(this, JV_STATE_LINKED);
}
+ catch (java::lang::SecurityException *x)
+ {
+ throw x;
+ }
catch (java::lang::Throwable *x)
{
// Turn into a NoClassDefFoundError.
@@ -727,6 +732,10 @@ java::lang::Class::initializeClass (void)
{
_Jv_InitClass (superclass);
}
+ catch (java::lang::SecurityException *x)
+ {
+ throw x;
+ }
catch (java::lang::Throwable *except)
{
// Caught an exception.
@@ -745,6 +754,10 @@ java::lang::Class::initializeClass (void)
if (meth)
((void (*) (void)) meth->ncode) ();
}
+ catch (java::lang::SecurityException *x)
+ {
+ throw x;
+ }
catch (java::lang::Throwable *except)
{
if (! java::lang::Error::class$.isInstance(except))