java.lang.Object
jdk.dynalink.linker.support.Guards
public final class Guards extends Object
Utility methods for creating typical guards for
MethodHandles.guardWithTest(MethodHandle, MethodHandle, MethodHandle)
and for adjusting their method types.-
Method Summary
Modifier and Type Method Description static MethodHandle
asType(MethodHandle test, MethodType type)
Takes a method handle intended to be used as a guard, and adapts it to the requested type, but returning a boolean.static MethodHandle
asType(LinkerServices linkerServices, MethodHandle test, MethodType type)
Takes a method handle intended to be used as a guard, and adapts it to the requested type, but returning a boolean.static MethodHandle
getClassGuard(Class<?> clazz)
Creates a guard method that tests its only argument for being of an exact particular class.static MethodHandle
getIdentityGuard(Object obj)
Creates a guard method that tests its only argument for being referentially identical to another objectstatic MethodHandle
getInstanceOfGuard(Class<?> clazz)
Creates a guard method that tests its only argument for being an instance of a particular class.static MethodHandle
isArray(int pos, MethodType type)
Creates a method handle that returns true if the argument in the specified position is a Java array.static MethodHandle
isInstance(Class<?> clazz, int pos, MethodType type)
Creates a method handle with arguments of a specified type, but with boolean return value.static MethodHandle
isInstance(Class<?> clazz, MethodType type)
Creates a method handle with arguments of a specified type, but with boolean return value.static MethodHandle
isNotNull()
Returns a guard that tests whether the first argument is not null.static MethodHandle
isNull()
Returns a guard that tests whether the first argument is null.static MethodHandle
isOfClass(Class<?> clazz, MethodType type)
Creates a guard method handle with arguments of a specified type, but with boolean return value.
-
Method Details
-
isOfClass
Creates a guard method handle with arguments of a specified type, but with boolean return value. When invoked, it returns true if the first argument is of the specified class (exactly of it, not a subclass). The rest of the arguments will be ignored.- Parameters:
clazz
- the class of the first argument to test fortype
- the method type- Returns:
- a method handle testing whether its first argument is of the specified class.
-
isInstance
Creates a method handle with arguments of a specified type, but with boolean return value. When invoked, it returns true if the first argument is instance of the specified class or its subclass). The rest of the arguments will be ignored.- Parameters:
clazz
- the class of the first argument to test fortype
- the method type- Returns:
- a method handle testing whether its first argument is of the specified class or subclass.
-
isInstance
Creates a method handle with arguments of a specified type, but with boolean return value. When invoked, it returns true if the n'th argument is instance of the specified class or its subclass). The rest of the arguments will be ignored.- Parameters:
clazz
- the class of the first argument to test forpos
- the position on the argument list to testtype
- the method type- Returns:
- a method handle testing whether its first argument is of the specified class or subclass.
-
isArray
Creates a method handle that returns true if the argument in the specified position is a Java array.- Parameters:
pos
- the position in the argument littype
- the method type of the handle- Returns:
- a method handle that returns true if the argument in the specified position is a Java array; the rest of the arguments are ignored.
-
asType
Takes a method handle intended to be used as a guard, and adapts it to the requested type, but returning a boolean. AppliesMethodHandle.asType(MethodType)
to convert types and usesMethodHandles.dropArguments(MethodHandle, int, Class...)
to match the requested type arity.- Parameters:
test
- the test method handletype
- the type to adapt the method handle to- Returns:
- the adapted method handle
-
asType
public static MethodHandle asType(LinkerServices linkerServices, MethodHandle test, MethodType type)Takes a method handle intended to be used as a guard, and adapts it to the requested type, but returning a boolean. AppliesLinkerServices.asType(MethodHandle, MethodType)
to convert types and usesMethodHandles.dropArguments(MethodHandle, int, Class...)
to match the requested type arity.- Parameters:
linkerServices
- the linker services to use for type conversionstest
- the test method handletype
- the type to adapt the method handle to- Returns:
- the adapted method handle
-
getClassGuard
Creates a guard method that tests its only argument for being of an exact particular class.- Parameters:
clazz
- the class to test for.- Returns:
- the desired guard method.
-
getInstanceOfGuard
Creates a guard method that tests its only argument for being an instance of a particular class.- Parameters:
clazz
- the class to test for.- Returns:
- the desired guard method.
-
getIdentityGuard
Creates a guard method that tests its only argument for being referentially identical to another object- Parameters:
obj
- the object used as referential identity test- Returns:
- the desired guard method.
-
isNull
Returns a guard that tests whether the first argument is null.- Returns:
- a guard that tests whether the first argument is null.
-
isNotNull
Returns a guard that tests whether the first argument is not null.- Returns:
- a guard that tests whether the first argument is not null.
-