diff options
Diffstat (limited to 'src/main/javassist/util')
-rw-r--r-- | src/main/javassist/util/proxy/DefinePackageHelper.java | 165 |
1 files changed, 84 insertions, 81 deletions
diff --git a/src/main/javassist/util/proxy/DefinePackageHelper.java b/src/main/javassist/util/proxy/DefinePackageHelper.java index 2124eebe..8a91eb28 100644 --- a/src/main/javassist/util/proxy/DefinePackageHelper.java +++ b/src/main/javassist/util/proxy/DefinePackageHelper.java @@ -32,110 +32,113 @@ import javassist.bytecode.ClassFile; */ public class DefinePackageHelper { - - private static enum SecuredPrivileged - { - JAVA_9 { - // definePackage has been discontinued for JAVA 9 - @Override - protected Package definePackage(ClassLoader loader, String name, String specTitle, + private static abstract class Helper { + abstract Package definePackage(ClassLoader loader, String name, String specTitle, + String specVersion, String specVendor, String implTitle, String implVersion, + String implVendor, URL sealBase) + throws IllegalArgumentException; + } + + private static class Java9 extends Helper { + // definePackage has been discontinued for JAVA 9 + @Override + Package definePackage(ClassLoader loader, String name, String specTitle, String specVersion, String specVendor, String implTitle, String implVersion, - String implVendor, URL sealBase) throws IllegalArgumentException - { - throw new RuntimeException("define package has been disabled for jigsaw"); - } - }, - JAVA_7 { - private final SecurityActions stack = SecurityActions.stack; - private final MethodHandle definePackage = getDefinePackageMethodHandle(); - private MethodHandle getDefinePackageMethodHandle() - { - if (stack.getCallerClass() != this.getClass()) - throw new IllegalAccessError("Access denied for caller."); - try { - return SecurityActions.getMethodHandle(ClassLoader.class, + String implVendor, URL sealBase) + throws IllegalArgumentException + { + throw new RuntimeException("define package has been disabled for jigsaw"); + } + }; + + private static class Java7 extends Helper { + private final SecurityActions stack = SecurityActions.stack; + private final MethodHandle definePackage = getDefinePackageMethodHandle(); + + private MethodHandle getDefinePackageMethodHandle() { + if (stack.getCallerClass() != this.getClass()) + throw new IllegalAccessError("Access denied for caller."); + try { + return SecurityActions.getMethodHandle(ClassLoader.class, "definePackage", new Class[] { String.class, String.class, String.class, String.class, String.class, String.class, String.class, URL.class }); - } catch (NoSuchMethodException e) { - throw new RuntimeException("cannot initialize", e); - } + } catch (NoSuchMethodException e) { + throw new RuntimeException("cannot initialize", e); } + } - @Override - protected Package definePackage(ClassLoader loader, String name, String specTitle, + @Override + Package definePackage(ClassLoader loader, String name, String specTitle, String specVersion, String specVendor, String implTitle, String implVersion, - String implVendor, URL sealBase) throws IllegalArgumentException { - if (stack.getCallerClass() != DefinePackageHelper.class) - throw new IllegalAccessError("Access denied for caller."); - try { - return (Package) definePackage.invokeWithArguments(loader, name, specTitle, + String implVendor, URL sealBase) + throws IllegalArgumentException + { + if (stack.getCallerClass() != DefinePackageHelper.class) + throw new IllegalAccessError("Access denied for caller."); + try { + return (Package) definePackage.invokeWithArguments(loader, name, specTitle, specVersion, specVendor, implTitle, implVersion, implVendor, sealBase); - } catch (Throwable e) { - if (e instanceof IllegalArgumentException) throw (IllegalArgumentException) e; - if (e instanceof RuntimeException) throw (RuntimeException) e; - } - return null; + } catch (Throwable e) { + if (e instanceof IllegalArgumentException) throw (IllegalArgumentException) e; + if (e instanceof RuntimeException) throw (RuntimeException) e; } - }, - JAVA_OTHER { - private final SecurityActions stack = SecurityActions.stack; - private final Method definePackage = getDefinePackageMethod(); - private Method getDefinePackageMethod() - { - if (stack.getCallerClass() != this.getClass()) - throw new IllegalAccessError("Access denied for caller."); - try { - return SecurityActions.getDeclaredMethod(ClassLoader.class, + return null; + } + } + + private static class JavaOther extends Helper { + private final SecurityActions stack = SecurityActions.stack; + private final Method definePackage = getDefinePackageMethod(); + + private Method getDefinePackageMethod() { + if (stack.getCallerClass() != this.getClass()) + throw new IllegalAccessError("Access denied for caller."); + try { + return SecurityActions.getDeclaredMethod(ClassLoader.class, "definePackage", new Class[] { String.class, String.class, String.class, String.class, String.class, String.class, String.class, URL.class }); - } catch (NoSuchMethodException e) { - throw new RuntimeException("cannot initialize", e); - } + } catch (NoSuchMethodException e) { + throw new RuntimeException("cannot initialize", e); } + } - @Override - protected Package definePackage(ClassLoader loader, String name, String specTitle, + @Override + Package definePackage(ClassLoader loader, String name, String specTitle, String specVersion, String specVendor, String implTitle, String implVersion, - String implVendor, URL sealBase) throws IllegalArgumentException - { - if (stack.getCallerClass() != DefinePackageHelper.class) - throw new IllegalAccessError("Access denied for caller."); - try { - definePackage.setAccessible(true); - return (Package) definePackage.invoke(loader, new Object[] { + String implVendor, URL sealBase) + throws IllegalArgumentException + { + if (stack.getCallerClass() != DefinePackageHelper.class) + throw new IllegalAccessError("Access denied for caller."); + try { + definePackage.setAccessible(true); + return (Package) definePackage.invoke(loader, new Object[] { name, specTitle, specVersion, specVendor, implTitle, implVersion, implVendor, sealBase }); - } catch (Throwable e) { - if (e instanceof InvocationTargetException) { - Throwable t = ((InvocationTargetException) e).getTargetException(); - if (t instanceof IllegalArgumentException) - throw (IllegalArgumentException) t; - } - if (e instanceof RuntimeException) throw (RuntimeException) e; - } - finally { - definePackage.setAccessible(false); + } catch (Throwable e) { + if (e instanceof InvocationTargetException) { + Throwable t = ((InvocationTargetException) e).getTargetException(); + if (t instanceof IllegalArgumentException) + throw (IllegalArgumentException) t; } - return null; + if (e instanceof RuntimeException) throw (RuntimeException) e; } - }; - - protected abstract Package definePackage(ClassLoader loader, String name, String specTitle, - String specVersion, String specVendor, String implTitle, String implVersion, - String implVendor, URL sealBase) throws IllegalArgumentException; - } - - private static final SecuredPrivileged privileged = ClassFile.MAJOR_VERSION >= ClassFile.JAVA_9 - ? SecuredPrivileged.JAVA_9 - : ClassFile.MAJOR_VERSION >= ClassFile.JAVA_7 - ? SecuredPrivileged.JAVA_7 - : SecuredPrivileged.JAVA_OTHER; + finally { + definePackage.setAccessible(false); + } + return null; + } + }; + private static final Helper privileged + = ClassFile.MAJOR_VERSION >= ClassFile.JAVA_9 + ? new Java9() : ClassFile.MAJOR_VERSION >= ClassFile.JAVA_7 + ? new Java7() : new JavaOther(); /** * Defines a new package. If the package is already defined, this method |