Support methods for StaticTypeCheckingVisitor.
Modifiers | Name | Description |
---|---|---|
protected static ClassNode |
ArrayList_TYPE |
|
protected static ClassNode |
Collection_TYPE |
|
protected static Comparator<MethodNode> |
DGM_METHOD_NODE_COMPARATOR |
This comparator is used when we return the list of methods from DGM which name correspond to a given name. |
protected static ClassNode |
Deprecated_TYPE |
|
protected static StaticTypeCheckingSupport.ExtensionMethodCache |
EXTENSION_METHOD_CACHE |
|
protected static ClassNode |
GSTRING_STRING_CLASSNODE |
|
protected static ClassNode |
Matcher_TYPE |
|
protected static Map<String, Integer> |
NUMBER_OPS |
|
protected static Map<ClassNode, Integer> |
NUMBER_TYPES |
|
protected static ClassNode |
UNKNOWN_PARAMETER_TYPE |
This is for internal use only. |
Type Params | Return Type | Name and description |
---|---|---|
|
static int |
allParametersAndArgumentsMatch(Parameter[] params, ClassNode[] args) Checks that arguments and parameter types match. |
|
static boolean |
checkCompatibleAssignmentTypes(ClassNode left, ClassNode right) Returns true or false depending on whether the right classnode can be assigned to the left classnode. |
|
static boolean |
checkCompatibleAssignmentTypes(ClassNode left, ClassNode right, Expression rightExpression) |
|
static boolean |
checkCompatibleAssignmentTypes(ClassNode left, ClassNode right, Expression rightExpression, boolean allowConstructorCoercion) Everything that can be done by castToType should be allowed for assignment. |
|
static List<MethodNode> |
chooseBestMethod(ClassNode receiver, Collection<MethodNode> methods, ClassNode... argumentTypes) Returns the method(s) which best fit the argument types. |
|
static void |
clearExtensionMethodCache(ClassLoader loader) |
|
static Set<ClassNode> |
collectAllInterfaces(ClassNode node) Collects all interfaces of a class node, including those defined by the super class. |
|
static Object |
evaluateExpression(Expression expr, CompilerConfiguration config) A helper method that can be used to evaluate expressions as found in annotation parameters. |
|
static List<MethodNode> |
findDGMMethodsByNameAndArguments(ClassNode receiver, String name, ClassNode[] args) @deprecated Use findDGMMethodsByNameAndArguments(ClassLoader, org.codehaus.groovy.ast.ClassNode, String, org.codehaus.groovy.ast.ClassNode[], java.util.List) instead |
|
static List<MethodNode> |
findDGMMethodsByNameAndArguments(ClassLoader loader, ClassNode receiver, String name, ClassNode[] args) |
|
static List<MethodNode> |
findDGMMethodsByNameAndArguments(ClassNode receiver, String name, ClassNode[] args, List<MethodNode> methods) @deprecated Use findDGMMethodsByNameAndArguments(ClassLoader, org.codehaus.groovy.ast.ClassNode, String, org.codehaus.groovy.ast.ClassNode[], List) instead |
|
static List<MethodNode> |
findDGMMethodsByNameAndArguments(ClassLoader loader, ClassNode receiver, String name, ClassNode[] args, List<MethodNode> methods) |
|
protected static Set<MethodNode> |
findDGMMethodsForClassNode(ClassNode clazz, String name) @deprecated Use findDGMMethodsForClassNode(ClassLoader, ClassNode, String) instead |
|
protected static Set<MethodNode> |
findDGMMethodsForClassNode(ClassLoader loader, ClassNode clazz, String name) |
|
protected static void |
findDGMMethodsForClassNode(ClassNode clazz, String name, TreeSet<MethodNode> accumulator) @deprecated Use findDGMMethodsForClassNode(ClassLoader, ClassNode, String, TreeSet) instead |
|
protected static void |
findDGMMethodsForClassNode(ClassLoader loader, ClassNode clazz, String name, TreeSet<MethodNode> accumulator) |
|
static List<MethodNode> |
findSetters(ClassNode cn, String setterName, boolean voidOnly) |
|
protected static Variable |
findTargetVariable(VariableExpression ve) Given a variable expression, returns the ultimately accessed variable. |
|
protected static GenericsType |
fullyResolve(GenericsType gt, Map<GenericsTypeName, GenericsType> placeholders) Given a generics type representing SomeClass<T,V> and a resolved placeholder map, returns a new generics type for which placeholders are resolved recursively. |
|
protected static ClassNode |
fullyResolveType(ClassNode type, Map<GenericsTypeName, GenericsType> placeholders) |
|
static ClassNode |
getCorrectedClassNode(ClassNode type, ClassNode superClass, boolean handlingGenerics) |
|
static boolean |
implementsInterfaceOrIsSubclassOf(ClassNode type, ClassNode superOrInterface) |
|
protected static boolean |
isArrayAccessExpression(Expression expression) Returns true for expressions of the form x[...] |
|
static boolean |
isAssignment(int op) |
|
static boolean |
isBeingCompiled(ClassNode node) |
|
static boolean |
isClassClassNodeWrappingConcreteType(ClassNode classNode) Returns true if the class node represents a the class node for the Class class and if the parametrized type is a neither a placeholder or a wildcard. |
|
static boolean |
isCompareToBoolean(int op) |
|
static boolean |
isGStringOrGStringStringLUB(ClassNode node) @return true if the class node is either a GString or the LUB of String and GString. |
|
static boolean |
isParameterizedWithGStringOrGStringString(ClassNode node) @param node the node to be tested |
|
static boolean |
isParameterizedWithString(ClassNode node) @param node the node to be tested |
|
static ClassNode |
isTraitSelf(VariableExpression vexp) |
|
static boolean |
isUnboundedWildcard(GenericsType gt) |
|
static boolean |
isUsingGenericsOrIsArrayUsingGenerics(ClassNode cn) Returns true if a class node makes use of generic types. |
|
static boolean |
isUsingUncheckedGenerics(ClassNode node) Returns true if the provided class node, when considered as a receiver of a message or as a parameter, is using a placeholder in its generics type. |
|
static boolean |
isWildcardLeftHandSide(ClassNode node) Tells if a class is one of the "accept all" classes as the left hand side of an assignment. |
|
static boolean |
isWithCall(String name, Expression callArguments) Called on method call checks in order to determine if a method call corresponds to the idiomatic o.with { ... } structure |
|
static boolean |
missesGenericsTypes(ClassNode cn) |
|
static Parameter[] |
parameterizeArguments(ClassNode receiver, MethodNode m) Given a receiver and a method node, parameterize the method arguments using available generic type information. |
|
static ClassNode |
resolveClassNodeGenerics(Map<GenericsTypeName, GenericsType> resolvedPlaceholders, Map<GenericsTypeName, GenericsType> placeholdersFromContext, ClassNode currentType) |
|
protected static boolean |
typeCheckMethodArgumentWithGenerics(ClassNode parameterType, ClassNode argumentType, boolean lastArg) Checks that the parameterized generics of an argument are compatible with the generics of the parameter. |
|
protected static boolean |
typeCheckMethodsWithGenerics(ClassNode receiver, ClassNode[] arguments, MethodNode candidateMethod) |
This comparator is used when we return the list of methods from DGM which name correspond to a given name. As we also lookup for DGM methods of superclasses or interfaces, it may be possible to find two methods which have the same name and the same arguments. In that case, we should not add the method from superclass or interface otherwise the system won't be able to select the correct method, resulting in an ambiguous method selection for similar methods.
This is for internal use only. When an argument method is null, we cannot determine its type, so we use this one as a wildcard.
Checks that arguments and parameter types match.
params
- method parametersargs
- type argumentsReturns true or false depending on whether the right classnode can be assigned to the left classnode. This method should not add errors by itself: we let the caller decide what to do if an incompatible assignment is found.
left
- the class to be assigned toright
- the assignee class Everything that can be done by castToType
should be allowed for assignment.
Returns the method(s) which best fit the argument types.
Collects all interfaces of a class node, including those defined by the super class.
node
- a class for which we want to retrieve all interfacesA helper method that can be used to evaluate expressions as found in annotation parameters. For example, it will evaluate a constant, be it referenced directly as an integer or as a reference to a field.
If this method throws an exception, then the expression cannot be evaluated on its own.
expr
- the expression to be evaluatedconfig
- the compiler configurationGiven a variable expression, returns the ultimately accessed variable.
ve
- a variable expressionGiven a generics type representing SomeClass<T,V> and a resolved placeholder map, returns a new generics type for which placeholders are resolved recursively.
Returns true for expressions of the form x[...]
expression
- an expressionReturns true if the class node represents a the class node for the Class class and if the parametrized type is a neither a placeholder or a wildcard. For example, the class node Class<Foo> where Foo is a class would return true, but the class node for Class<?> would return false.
classNode
- a class node to be tested
node
- the node to be tested
node
- the node to be testedReturns true if a class node makes use of generic types. If the class node represents an array type, then checks if the component type is using generics.
cn
- a class node for which to check if it is using genericsReturns true if the provided class node, when considered as a receiver of a message or as a parameter, is using a placeholder in its generics type. In this case, we're facing unchecked generics and type checking is limited (ex: void foo(Set s) { s.keySet() }
node
- the node to testTells if a class is one of the "accept all" classes as the left hand side of an assignment.
node
- the classnode to testCalled on method call checks in order to determine if a method call corresponds to the idiomatic o.with { ... } structure
name
- name of the method calledcallArguments
- arguments of the methodGiven a receiver and a method node, parameterize the method arguments using available generic type information.
receiver
- the classm
- the methodChecks that the parameterized generics of an argument are compatible with the generics of the parameter.
parameterType
- the parameter type of a methodargumentType
- the type of the argument passed to the method