Package org.codehaus.groovy.vmplugin.v9
Class Java9
- java.lang.Object
-
- org.codehaus.groovy.vmplugin.v8.Java8
-
- org.codehaus.groovy.vmplugin.v9.Java9
-
-
Constructor Summary
Constructors Constructor Description Java9()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancheckAccessible(Class<?> callerClass, Class<?> declaringClass, int memberModifiers, boolean allowIllegalAccess)check whether the member can be accessed or notbooleancheckCanSetAccessible(AccessibleObject accessibleObject, Class<?> callerClass)This method may be used by a caller in class C to check whether to enable access to a member of declaring class D successfully ifJava8.checkCanSetAccessible(java.lang.reflect.AccessibleObject, java.lang.Class)returns true and any of the following hold:Map<String,Set<String>>getDefaultImportClasses(String[] packageNames)Returns the default import classes: class name -> the relevant package namesObjectgetInvokeSpecialHandle(Method method, Object receiver)Returns a handle with bound receiver to invokeSpecial the given method.intgetVersion()Gives the version the plugin is made forstatic MethodHandles.Lookupof(Class<?> declaringClass)MetaMethodtransformMetaMethod(MetaClass metaClass, MetaMethod metaMethod, Class<?> caller)transform meta methodbooleantrySetAccessible(AccessibleObject ao)Set theaccessibleflag for this reflected object totrueif possible.-
Methods inherited from class org.codehaus.groovy.vmplugin.v8.Java8
configureAnnotation, configureAnnotationNodeFromDefinition, configureClassNode, configureTypeVariableDefinition, configureTypeVariableReference, getElementCode, getPluginDefaultGroovyMethods, getPluginStaticGroovyMethods, invalidateCallSites, invokeHandle, makeParameter, processParameters, setAdditionalClassInformation, transformMetaMethod
-
-
-
-
Method Detail
-
getDefaultImportClasses
public Map<String,Set<String>> getDefaultImportClasses(String[] packageNames)
Description copied from interface:VMPluginReturns the default import classes: class name -> the relevant package names- Parameters:
packageNames- the default import package names, e.g. java.lang.- Returns:
- the default import classes
-
of
public static MethodHandles.Lookup of(Class<?> declaringClass)
-
getVersion
public int getVersion()
Description copied from interface:VMPluginGives the version the plugin is made for- Specified by:
getVersionin interfaceVMPlugin- Overrides:
getVersionin classJava8- Returns:
- 7 for jdk7, 8 for jdk8, 9 for jdk9 or higher
-
getInvokeSpecialHandle
public Object getInvokeSpecialHandle(Method method, Object receiver)
Description copied from interface:VMPluginReturns a handle with bound receiver to invokeSpecial the given method. This method will require at least Java 7, but since the source has to compile on older Java versions as well it is not marked to return a MethodHandle and uses Object instead- Specified by:
getInvokeSpecialHandlein interfaceVMPlugin- Overrides:
getInvokeSpecialHandlein classJava8- Returns:
- null in case of jdk<7, otherwise a handle that takes the method call arguments for the invokespecial call
-
checkCanSetAccessible
public boolean checkCanSetAccessible(AccessibleObject accessibleObject, Class<?> callerClass)
This method may be used by a caller in class C to check whether to enable access to a member of declaring class D successfully ifJava8.checkCanSetAccessible(java.lang.reflect.AccessibleObject, java.lang.Class)returns true and any of the following hold:1) C and D are in the same module. 2) The member is public and D is public in a package that the module containing D exports to at least the module containing C. 3) The member is protected static, D is public in a package that the module containing D exports to at least the module containing C, and C is a subclass of D. 4) D is in a package that the module containing D opens to at least the module containing C. All packages in unnamed and open modules are open to all modules and so this method always succeeds when D is in an unnamed or open module.
- Specified by:
checkCanSetAccessiblein interfaceVMPlugin- Overrides:
checkCanSetAccessiblein classJava8- Parameters:
accessibleObject- the accessible object to checkcallerClass- the callerClass to invokesetAccessible- Returns:
- the check result
-
trySetAccessible
public boolean trySetAccessible(AccessibleObject ao)
Description copied from interface:VMPluginSet theaccessibleflag for this reflected object totrueif possible.- Specified by:
trySetAccessiblein interfaceVMPlugin- Overrides:
trySetAccessiblein classJava8- Parameters:
ao- the accessible object- Returns:
trueif theaccessibleflag is set totrue;falseif access cannot be enabled.
-
transformMetaMethod
public MetaMethod transformMetaMethod(MetaClass metaClass, MetaMethod metaMethod, Class<?> caller)
Description copied from interface:VMPlugintransform meta method- Specified by:
transformMetaMethodin interfaceVMPlugin- Overrides:
transformMetaMethodin classJava8- Parameters:
metaClass- meta classmetaMethod- the original meta methodcaller- caller class, whose method sets accessible for methods- Returns:
- the transformed meta method
-
checkAccessible
public boolean checkAccessible(Class<?> callerClass, Class<?> declaringClass, int memberModifiers, boolean allowIllegalAccess)
Description copied from interface:VMPlugincheck whether the member can be accessed or not- Specified by:
checkAccessiblein interfaceVMPlugin- Overrides:
checkAccessiblein classJava8- Parameters:
callerClass- callerClass the callerClass to invokesetAccessibledeclaringClass- the type of member ownermemberModifiers- modifiers of memberallowIllegalAccess- whether to allow illegal access- Returns:
- the result of checking
-
-