diff options
author | Andrew Haley <aph@redhat.com> | 2007-04-16 13:44:59 +0000 |
---|---|---|
committer | Andrew Haley <aph@gcc.gnu.org> | 2007-04-16 13:44:59 +0000 |
commit | 0e055c1cd2818af3d636b0a9736fd873bcbeb56e (patch) | |
tree | 596031af669670b840c0e1c7fc4b9cbcb65204c7 /libjava/java | |
parent | 60555ced95a26a5454d66d2d5ce2e435ed0efc3b (diff) | |
download | gcc-0e055c1cd2818af3d636b0a9736fd873bcbeb56e.zip gcc-0e055c1cd2818af3d636b0a9736fd873bcbeb56e.tar.gz gcc-0e055c1cd2818af3d636b0a9736fd873bcbeb56e.tar.bz2 |
BootClassLoader.java (getBootURLLoader): New method.
2007-04-16 Andrew Haley <aph@redhat.com>
* gnu/gcj/runtime/BootClassLoader.java (getBootURLLoader): New
method.
(bootGetResource): Use getBootURLLoader() to load resources.
(bootGetResources): Likewise.
* java/lang/reflect/natMethod.cc (Method::invoke): In invoke also
check that the method's declaring class is accessible.
From-SVN: r123862
Diffstat (limited to 'libjava/java')
-rw-r--r-- | libjava/java/lang/reflect/natMethod.cc | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/libjava/java/lang/reflect/natMethod.cc b/libjava/java/lang/reflect/natMethod.cc index 6dcd4ec..4593da7 100644 --- a/libjava/java/lang/reflect/natMethod.cc +++ b/libjava/java/lang/reflect/natMethod.cc @@ -173,16 +173,34 @@ java::lang::reflect::Method::invoke (jobject obj, jobjectArray args) } // Check accessibility, if required. - if (! (Modifier::isPublic (meth->accflags) || this->isAccessible())) + if (! this->isAccessible()) { - Class *caller = _Jv_StackTrace::GetCallingClass (&Method::class$); - if (! _Jv_CheckAccess(caller, declaringClass, meth->accflags)) - throw new IllegalAccessException; + if (! (Modifier::isPublic (meth->accflags))) + { + Class *caller = _Jv_StackTrace::GetCallingClass (&Method::class$); + if (! _Jv_CheckAccess(caller, declaringClass, meth->accflags)) + throw new IllegalAccessException; + } + else + // Method is public, check to see if class is accessible. + { + jint flags = (declaringClass->accflags + & (Modifier::PUBLIC + | Modifier::PROTECTED + | Modifier::PRIVATE)); + if (flags == 0) // i.e. class is package private + { + Class *caller = _Jv_StackTrace::GetCallingClass (&Method::class$); + if (! _Jv_ClassNameSamePackage (caller->name, + declaringClass->name)) + throw new IllegalAccessException; + } + } } if (declaringClass->isInterface()) iface = declaringClass; - + return _Jv_CallAnyMethodA (obj, return_type, meth, false, parameter_types, args, iface); } |