|
Groovy 2.2.2 | |||||||
FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.codehaus.groovy.ast.CodeVisitorSupport
org.codehaus.groovy.ast.ClassCodeVisitorSupport
org.codehaus.groovy.transform.stc.StaticTypeCheckingVisitor
public class StaticTypeCheckingVisitor extends ClassCodeVisitorSupport
The main class code visitor responsible for static type checking. It will perform various inspections like checking assignment types, type inference, ... Eventually, class nodes may be annotated with inferred type information.
Nested Class Summary | |
---|---|
static class |
StaticTypeCheckingVisitor.SignatureCodecFactory
|
protected class |
StaticTypeCheckingVisitor.VariableExpressionTypeMemoizer
|
Constructor Summary | |
StaticTypeCheckingVisitor(SourceUnit source, ClassNode cn)
|
Method Summary | |
---|---|
protected void
|
addAmbiguousErrorMessage(List foundMethods, String name, ClassNode[] args, Expression expr)
|
protected void
|
addAssignmentError(ClassNode leftType, ClassNode rightType, Expression assignmentExpression)
|
protected void
|
addCategoryMethodCallError(Expression call)
|
protected void
|
addClosureReturnType(ClassNode returnType)
|
protected void
|
addError(String msg, ASTNode expr)
|
protected void
|
addNoMatchingMethodError(ClassNode receiver, String name, ClassNode[] args, Expression call)
|
protected void
|
addReceivers(List receivers, Collection owners, boolean implicitThis)
|
protected void
|
addStaticTypeError(String msg, ASTNode expr)
|
void
|
addTypeCheckingExtension(TypeCheckingExtension extension)
|
protected void
|
addTypeCheckingInfoAnnotation(MethodNode node)
|
protected void
|
addUnsupportedPreOrPostfixExpressionError(Expression expression)
|
protected boolean
|
areCategoryMethodCalls(List foundMethods, String name, ClassNode[] args)
|
protected boolean
|
checkCast(ClassNode targetType, Expression source)
|
protected void
|
checkClosureParameters(Expression callArguments, ClassNode receiver)
visit a method call target, to infer the type. |
protected void
|
checkForbiddenSpreadArgument(ArgumentListExpression argumentList)
|
protected void
|
checkGroovyConstructorMap(Expression receiver, ClassNode receiverType, MapExpression mapExpression)
Checks that a constructor style expression is valid regarding the number of arguments and the argument types. |
protected void
|
checkGroovyStyleConstructor(ClassNode node, ClassNode[] arguments)
A helper method which determines which receiver class should be used in error messages when a field or attribute is not found. |
protected MethodNode
|
checkGroovyStyleConstructor(ClassNode node, ClassNode[] arguments, ASTNode source)
|
protected ClassNode
|
checkReturnType(ReturnStatement statement)
|
protected void
|
collectAllInterfaceMethodsByName(ClassNode receiver, String name, List methods)
|
protected boolean
|
existsProperty(PropertyExpression pexp, boolean checkForReadOnly)
|
protected boolean
|
existsProperty(PropertyExpression pexp, boolean readMode, ClassCodeVisitorSupport visitor)
|
static String
|
extractPropertyNameFromMethodName(String prefix, String methodName)
Stores the inferred return type of a closure or a method. |
protected Object
|
extractTemporaryTypeInfoKey(Expression expression)
|
protected static ClassNode[]
|
extractTypesFromParameters(Parameter[] parameters)
|
protected ClassNode
|
findCurrentInstanceOfClass(Expression expr, ClassNode type)
|
protected List
|
findMethod(ClassNode receiver, String name, ClassNode... args)
|
protected MethodNode
|
findMethodOrFail(Expression expr, ClassNode receiver, String name, ClassNode... args)
|
protected List
|
findMethodsWithGenerated(ClassNode receiver, String name)
|
protected static String
|
formatArgumentList(ClassNode[] nodes)
|
protected ClassNode[]
|
getArgumentTypes(ArgumentListExpression args)
|
protected DelegationMetadata
|
getDelegationMetadata(ClosureExpression expression)
|
protected static ClassNode
|
getGroupOperationResultType(ClassNode a, ClassNode b)
This method returns the list of methods named against the supplied parameter that are defined on the specified receiver, but it will also add "non existing" methods that will be generated afterwards by the compiler, for example if a method is using default values and that the specified class node isn't compiled yet. |
protected ClassNode
|
getInferredReturnType(ASTNode exp)
|
protected ClassNode
|
getInferredReturnTypeFromWithClosureArgument(Expression callArguments)
|
protected ClassNode
|
getOriginalDeclarationType(Expression lhs)
|
protected ClassNode
|
getResultType(ClassNode left, int op, ClassNode right, BinaryExpression expr)
|
protected SourceUnit
|
getSourceUnit()
|
protected List
|
getTemporaryTypesForExpression(Expression objectExpression)
|
protected ClassNode
|
getType(ASTNode exp)
If a method call returns a parameterized type, then we can perform additional inference on the return type, so that the type gets actual type parameters. |
protected ClassNode[]
|
getTypeCheckingAnnotations()
|
TypeCheckingContext
|
getTypeCheckingContext()
Returns the current type checking context. |
protected static boolean
|
hasRHSIncompleteGenericTypeInfo(ClassNode inferredRightExpressionType)
|
protected StaticTypeCheckingVisitor.SetterInfo
|
hasSetter(PropertyExpression pexp)
|
protected ClassNode
|
inferComponentType(ClassNode containerType, ClassNode indexType)
|
protected void
|
inferDiamondType(ConstructorCallExpression cce, ClassNode lType)
|
protected ClassNode
|
inferListExpressionType(ListExpression list)
|
static ClassNode
|
inferLoopElementType(ClassNode collectionType)
|
protected ClassNode
|
inferMapExpressionType(MapExpression map)
|
protected ClassNode
|
inferReturnTypeGenerics(ClassNode receiver, MethodNode method, Expression arguments)
|
void
|
initialize()
|
protected static boolean
|
isClassInnerClassOrEqualTo(ClassNode toBeChecked, ClassNode start)
|
protected boolean
|
isClosureCall(String name, Expression objectExpression, Expression arguments)
|
protected static boolean
|
isNullConstant(Expression expression)
|
protected boolean
|
isSecondPassNeededForControlStructure(Map varOrigType, Map oldTracker)
|
boolean
|
isSkipMode(AnnotatedNode node)
|
protected boolean
|
isSkippedInnerClass(AnnotatedNode node)
Test if a node is an inner class node, and if it is, then checks if the enclosing method is skipped. |
protected List
|
makeOwnerList(Expression objectExpression)
|
void
|
performSecondPass()
|
protected Map
|
popAssignmentTracking(Map oldTracker)
|
protected static String
|
prettyPrintMethodList(List nodes)
|
protected Map
|
pushAssignmentTracking()
|
protected void
|
pushInstanceOfTypeInfo(Expression objectOfInstanceOf, Expression typeExpression)
Stores information about types when [objectOfInstanceof instanceof typeExpression] is visited |
protected void
|
restoreVariableExpressionMetadata(Map typesBeforeVisit)
|
protected void
|
saveVariableExpressionMetadata(Set closureSharedExpressions, Map typesBeforeVisit)
|
void
|
setMethodsToBeVisited(Set methodsToBeVisited)
|
protected boolean
|
shouldSkipClassNode(ClassNode node)
|
protected boolean
|
shouldSkipMethodNode(MethodNode node)
|
protected void
|
silentlyVisitMethodNode(MethodNode directMethodCallCandidate)
|
protected void
|
startMethodInference(MethodNode node, ErrorCollector collector)
|
protected ClassNode
|
storeInferredReturnType(ASTNode node, ClassNode type)
This method will convert a closure type to the appropriate SAM type, which will be used to infer return type generics. |
protected void
|
storeInferredTypeForPropertyExpression(PropertyExpression pexp, ClassNode flatInferredType)
|
protected void
|
storeTargetMethod(Expression call, MethodNode directMethodCallCandidate)
|
protected void
|
storeType(Expression exp, ClassNode cn)
|
protected void
|
typeCheckAssignment(BinaryExpression assignmentExpression, Expression leftExpression, ClassNode leftExpressionType, Expression rightExpression, ClassNode inferredRightExpressionType)
|
protected void
|
typeCheckClosureCall(Expression callArguments, ClassNode[] args, Parameter[] parameters)
|
protected MethodNode
|
typeCheckMapConstructor(ConstructorCallExpression call, ClassNode receiver, Expression arguments)
|
protected boolean
|
typeCheckMethodsWithGenericsOrFail(ClassNode receiver, ClassNode[] arguments, MethodNode candidateMethod, Expression location)
Returns a wrapped type if, and only if, the provided class node is a primitive type. |
void
|
visitAttributeExpression(AttributeExpression expression)
|
void
|
visitBinaryExpression(BinaryExpression expression)
|
void
|
visitBitwiseNegationExpression(BitwiseNegationExpression expression)
|
void
|
visitCaseStatement(CaseStatement statement)
|
void
|
visitCastExpression(CastExpression expression)
|
void
|
visitClass(ClassNode node)
|
void
|
visitClassExpression(ClassExpression expression)
|
void
|
visitClosureExpression(ClosureExpression expression)
|
void
|
visitConstructorCallExpression(ConstructorCallExpression call)
|
protected void
|
visitConstructorOrMethod(MethodNode node, boolean isConstructor)
|
void
|
visitField(FieldNode node)
Given a loop collection type, returns the inferred type of the loop element. |
void
|
visitForLoop(ForStatement forLoop)
|
void
|
visitIfElse(IfStatement ifElse)
|
void
|
visitMethod(MethodNode node)
|
protected void
|
visitMethodCallArguments(ArgumentListExpression arguments, boolean visitClosures, MethodNode selectedMethod)
|
void
|
visitMethodCallExpression(MethodCallExpression call)
|
void
|
visitPostfixExpression(PostfixExpression expression)
|
void
|
visitPrefixExpression(PrefixExpression expression)
|
void
|
visitPropertyExpression(PropertyExpression pexp)
|
void
|
visitRangeExpression(RangeExpression expression)
|
void
|
visitReturnStatement(ReturnStatement statement)
|
void
|
visitStaticMethodCallExpression(StaticMethodCallExpression call)
|
void
|
visitSwitch(SwitchStatement statement)
|
void
|
visitTernaryExpression(TernaryExpression expression)
|
void
|
visitTryCatchFinally(TryCatchStatement statement)
|
void
|
visitUnaryMinusExpression(UnaryMinusExpression expression)
|
void
|
visitUnaryPlusExpression(UnaryPlusExpression expression)
|
void
|
visitVariableExpression(VariableExpression vexp)
|
void
|
visitWhileLoop(WhileStatement loop)
|
protected static ClassNode
|
wrapTypeIfNecessary(ClassNode type)
|
Field Detail |
---|
public static final MethodNode CLOSURE_CALL_NO_ARG
public static final MethodNode CLOSURE_CALL_ONE_ARG
public static final MethodNode CLOSURE_CALL_VARGS
protected static final Expression CURRENT_SIGNATURE_PROTOCOL
protected static final int CURRENT_SIGNATURE_PROTOCOL_VERSION
protected static final ClassNode DELEGATES_TO
protected static final ClassNode DELEGATES_TO_TARGET
protected static final ClassNode DGM_CLASSNODE
protected static final List EMPTY_METHODNODE_LIST
protected static final Object ERROR_COLLECTOR
public static final Statement GENERATED_EMPTY_STATEMENT
protected static final MethodNode GET_DELEGATE
protected static final MethodNode GET_OWNER
protected static final MethodNode GET_THISOBJECT
protected static final ClassNode ITERABLE_TYPE
protected static final ClassNode LINKEDHASHMAP_CLASSNODE
protected static final ClassNode TYPECHECKED_CLASSNODE
protected static final ClassNode[] TYPECHECKING_ANNOTATIONS
protected static final ClassNode TYPECHECKING_INFO_NODE
protected DefaultTypeCheckingExtension extension
protected final ReturnAdder returnAdder
protected final ReturnStatementListener returnListener
protected TypeCheckingContext typeCheckingContext
Constructor Detail |
---|
public StaticTypeCheckingVisitor(SourceUnit source, ClassNode cn)
Method Detail |
---|
protected void addAmbiguousErrorMessage(List foundMethods, String name, ClassNode[] args, Expression expr)
protected void addAssignmentError(ClassNode leftType, ClassNode rightType, Expression assignmentExpression)
protected void addCategoryMethodCallError(Expression call)
protected void addClosureReturnType(ClassNode returnType)
@Override protected void addError(String msg, ASTNode expr)
protected void addNoMatchingMethodError(ClassNode receiver, String name, ClassNode[] args, Expression call)
protected void addReceivers(List receivers, Collection owners, boolean implicitThis)
protected void addStaticTypeError(String msg, ASTNode expr)
public void addTypeCheckingExtension(TypeCheckingExtension extension)
protected void addTypeCheckingInfoAnnotation(MethodNode node)
protected void addUnsupportedPreOrPostfixExpressionError(Expression expression)
protected boolean areCategoryMethodCalls(List foundMethods, String name, ClassNode[] args)
protected boolean checkCast(ClassNode targetType, Expression source)
protected void checkClosureParameters(Expression callArguments, ClassNode receiver)
protected void checkForbiddenSpreadArgument(ArgumentListExpression argumentList)
protected void checkGroovyConstructorMap(Expression receiver, ClassNode receiverType, MapExpression mapExpression)
node
- the class node for which we will try to find a matching constructorarguments
- the constructor arguments
@Deprecated} protected void checkGroovyStyleConstructor(ClassNode node, ClassNode[] arguments)
expr
- the expression for which an unknown field has been foundtype
- the type of the expression (used as fallback type)
protected MethodNode checkGroovyStyleConstructor(ClassNode node, ClassNode[] arguments, ASTNode source)
protected ClassNode checkReturnType(ReturnStatement statement)
protected void collectAllInterfaceMethodsByName(ClassNode receiver, String name, List methods)
protected boolean existsProperty(PropertyExpression pexp, boolean checkForReadOnly)
protected boolean existsProperty(PropertyExpression pexp, boolean readMode, ClassCodeVisitorSupport visitor)
public static String extractPropertyNameFromMethodName(String prefix, String methodName)
node
- a ClosureExpression or a MethodNodetype
- the inferred return type of the code
protected Object extractTemporaryTypeInfoKey(Expression expression)
protected static ClassNode[] extractTypesFromParameters(Parameter[] parameters)
protected ClassNode findCurrentInstanceOfClass(Expression expr, ClassNode type)
protected List findMethod(ClassNode receiver, String name, ClassNode... args)
protected MethodNode findMethodOrFail(Expression expr, ClassNode receiver, String name, ClassNode... args)
protected List findMethodsWithGenerated(ClassNode receiver, String name)
protected static String formatArgumentList(ClassNode[] nodes)
protected ClassNode[] getArgumentTypes(ArgumentListExpression args)
protected DelegationMetadata getDelegationMetadata(ClosureExpression expression)
protected static ClassNode getGroupOperationResultType(ClassNode a, ClassNode b)
receiver
- the receiver where to find methodsname
- the name of the methods to return
protected ClassNode getInferredReturnType(ASTNode exp)
protected ClassNode getInferredReturnTypeFromWithClosureArgument(Expression callArguments)
protected ClassNode getOriginalDeclarationType(Expression lhs)
protected ClassNode getResultType(ClassNode left, int op, ClassNode right, BinaryExpression expr)
protected SourceUnit getSourceUnit()
protected List getTemporaryTypesForExpression(Expression objectExpression)
protected ClassNode getType(ASTNode exp)
method
- the method nodearguments
- the method call arguments
protected ClassNode[] getTypeCheckingAnnotations()
public TypeCheckingContext getTypeCheckingContext()
protected static boolean hasRHSIncompleteGenericTypeInfo(ClassNode inferredRightExpressionType)
@Deprecated} else { protected StaticTypeCheckingVisitor.SetterInfo hasSetter(PropertyExpression pexp)
protected ClassNode inferComponentType(ClassNode containerType, ClassNode indexType)
protected void inferDiamondType(ConstructorCallExpression cce, ClassNode lType)
protected ClassNode inferListExpressionType(ListExpression list)
public static ClassNode inferLoopElementType(ClassNode collectionType)
protected ClassNode inferMapExpressionType(MapExpression map)
protected ClassNode inferReturnTypeGenerics(ClassNode receiver, MethodNode method, Expression arguments)
public void initialize()
protected static boolean isClassInnerClassOrEqualTo(ClassNode toBeChecked, ClassNode start)
protected boolean isClosureCall(String name, Expression objectExpression, Expression arguments)
protected static boolean isNullConstant(Expression expression)
protected boolean isSecondPassNeededForControlStructure(Map varOrigType, Map oldTracker)
public boolean isSkipMode(AnnotatedNode node)
protected boolean isSkippedInnerClass(AnnotatedNode node)
protected List makeOwnerList(Expression objectExpression)
public void performSecondPass()
protected Map popAssignmentTracking(Map oldTracker)
protected static String prettyPrintMethodList(List nodes)
protected Map pushAssignmentTracking()
protected void pushInstanceOfTypeInfo(Expression objectOfInstanceOf, Expression typeExpression)
objectOfInstanceOf
- the expression which must be checked against instanceoftypeExpression
- the expression which represents the target type
protected void restoreVariableExpressionMetadata(Map typesBeforeVisit)
protected void saveVariableExpressionMetadata(Set closureSharedExpressions, Map typesBeforeVisit)
public void setMethodsToBeVisited(Set methodsToBeVisited)
protected boolean shouldSkipClassNode(ClassNode node)
protected boolean shouldSkipMethodNode(MethodNode node)
protected void silentlyVisitMethodNode(MethodNode directMethodCallCandidate)
protected void startMethodInference(MethodNode node, ErrorCollector collector)
protected ClassNode storeInferredReturnType(ASTNode node, ClassNode type)
closureType
- the inferred type of a closure (Closure<ClosureReturnType>)samType
- the type into which the closure is coerced intoplaceholders
- generics placeholders from context
protected void storeInferredTypeForPropertyExpression(PropertyExpression pexp, ClassNode flatInferredType)
protected void storeTargetMethod(Expression call, MethodNode directMethodCallCandidate)
protected void storeType(Expression exp, ClassNode cn)
protected void typeCheckAssignment(BinaryExpression assignmentExpression, Expression leftExpression, ClassNode leftExpressionType, Expression rightExpression, ClassNode inferredRightExpressionType)
protected void typeCheckClosureCall(Expression callArguments, ClassNode[] args, Parameter[] parameters)
protected MethodNode typeCheckMapConstructor(ConstructorCallExpression call, ClassNode receiver, Expression arguments)
protected boolean typeCheckMethodsWithGenericsOrFail(ClassNode receiver, ClassNode[] arguments, MethodNode candidateMethod, Expression location)
@Override public void visitAttributeExpression(AttributeExpression expression)
@OverrideSetterInfo setterInfo = removeSetterInfo(leftExpression); public void visitBinaryExpression(BinaryExpression expression)
@Override} public void visitBitwiseNegationExpression(BitwiseNegationExpression expression)
@Override// this can happen for example when "null" is used in an assignment or a method parameter. public void visitCaseStatement(CaseStatement statement)
@Override} public void visitCastExpression(CastExpression expression)
@Overrideif (shouldSkipClassNode(node)) return; public void visitClass(ClassNode node)
@Override} public void visitClassExpression(ClassExpression expression)
@OverrideListHashMapmetadata = new ListHashMap (); public void visitClosureExpression(ClosureExpression expression)
@Overridepublic void visitClosureExpression(final ClosureExpression expression) { public void visitConstructorCallExpression(ConstructorCallExpression call)
@Override// bean-style constructor protected void visitConstructorOrMethod(MethodNode node, boolean isConstructor)
@OverrideClassNode intf = GenericsUtils.parameterizeType(collectionType, ITERABLE_TYPE); public void visitField(FieldNode node)
collectionType
- the type of the collection
@Override} public void visitForLoop(ForStatement forLoop)
@Overrideif (isNullConstant(trueExpression) || isNullConstant(falseExpression)) { public void visitIfElse(IfStatement ifElse)
@Overrideif (extension.beforeMethodCall(call)) { public void visitMethod(MethodNode node)
protected void visitMethodCallArguments(ArgumentListExpression arguments, boolean visitClosures, MethodNode selectedMethod)
@OverridetypeCheckClosureCall(callArguments, args, parameters); public void visitMethodCallExpression(MethodCallExpression call)
@Override} else { public void visitPostfixExpression(PostfixExpression expression)
@Overrideprotected void visitConstructorOrMethod(MethodNode node, boolean isConstructor) { public void visitPrefixExpression(PrefixExpression expression)
@Override} public void visitPropertyExpression(PropertyExpression pexp)
@Override} public void visitRangeExpression(RangeExpression expression)
@Override} public void visitReturnStatement(ReturnStatement statement)
@OverrideaddStaticTypeError("Unexpected number of parameters for a with call", argList); public void visitStaticMethodCallExpression(StaticMethodCallExpression call)
@Override public void visitSwitch(SwitchStatement statement)
@Overrideif (method!=null && implementsInterfaceOrIsSubclassOf(right, RANGE_TYPE)) { public void visitTernaryExpression(TernaryExpression expression)
@Overrideif (!isPrimitiveType(leftRedirect) || !isPrimitiveType(rightRedirect)) { public void visitTryCatchFinally(TryCatchStatement statement)
@Override} else if (typeRe == ArrayList_TYPE) { public void visitUnaryMinusExpression(UnaryMinusExpression expression)
@Overrideprivate void negativeOrPositiveUnary(Expression expression, String name) { public void visitUnaryPlusExpression(UnaryPlusExpression expression)
@Override public void visitVariableExpression(VariableExpression vexp)
@OverrideMethodNode node = findMethodOrFail(new VariableExpression("_dummy_", exprType), exprType, name); public void visitWhileLoop(WhileStatement loop)
protected static ClassNode wrapTypeIfNecessary(ClassNode type)
Copyright © 2003-2013 The Codehaus. All rights reserved.