diff options
author | Andrew Haley <aph@gcc.gnu.org> | 2007-01-29 13:14:38 +0000 |
---|---|---|
committer | Andrew Haley <aph@gcc.gnu.org> | 2007-01-29 13:14:38 +0000 |
commit | 6b05e79165f6d8c5660a874d77f87da41ca934c9 (patch) | |
tree | 40df469186ef32efb4fe4cfc7ff23eb2b0c7e713 /libjava/java/lang/natClass.cc | |
parent | 2631dfddd2d1492ded5836b7385d3754c9cca33f (diff) | |
download | gcc-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.cc | 13 |
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)) |