|
Groovy 2.2.0 | |||||||
FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.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)
Checks whether a property exists on the receiver, or on any of the possible receiver classes (found in the temporary type information table) |
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)
Returns a wrapped type if, and only if, the provided class node is a primitive type. |
protected static GenericsType
|
fullyResolve(GenericsType gt, Map placeholders)
|
protected static ClassNode
|
fullyResolveType(ClassNode type, Map placeholders)
|
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)
|
protected ClassNode[]
|
getTypeCheckingAnnotations()
|
TypeCheckingContext
|
getTypeCheckingContext()
Returns the current type checking context. |
protected static boolean
|
hasRHSIncompleteGenericTypeInfo(ClassNode inferredRightExpressionType)
When instanceof checks are found in the code, we store temporary type information data in the TypeCheckingContext.temporaryIfBranchTypeInformation table. |
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)
|
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
|
typeCheckMethodArgumentWithGenerics(ClassNode parameterType, ClassNode argumentType, boolean lastArg)
|
protected void
|
typeCheckMethodsWithGenerics(ClassNode receiver, ClassNode[] arguments, MethodNode candidateMethod, Expression location)
|
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
protected void checkGroovyStyleConstructor(ClassNode node, ClassNode[] arguments)
pexp
- a property expressionreadMode
- if true, look for property read, else for property setvisitor
- if not null, when the property node is found, visit it with the provided visitor
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 static GenericsType fullyResolve(GenericsType gt, Map placeholders)
protected static ClassNode fullyResolveType(ClassNode type, Map placeholders)
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)
protected ClassNode[] getTypeCheckingAnnotations()
public TypeCheckingContext getTypeCheckingContext()
protected static boolean hasRHSIncompleteGenericTypeInfo(ClassNode inferredRightExpressionType)
expression
- the expression for which to compute the key
@Deprecatedsuper.visitForLoop(forLoop); 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)
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 typeCheckMethodArgumentWithGenerics(ClassNode parameterType, ClassNode argumentType, boolean lastArg)
protected void typeCheckMethodsWithGenerics(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)
@Overrideif (cn == UNKNOWN_PARAMETER_TYPE) { 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)
@Overridefor (VariableExpression ve : closureSharedExpressions) { public void visitClosureExpression(ClosureExpression expression)
@Override public void visitConstructorCallExpression(ConstructorCallExpression call)
@Override&& findMethod(receiver, "", args).isEmpty()) { protected void visitConstructorOrMethod(MethodNode node, boolean isConstructor)
@Overrideif (collectionType.implementsInterface(ITERABLE_TYPE)) { public void visitField(FieldNode node)
collectionType
- the type of the collection
@Overridereturn false; public void visitForLoop(ForStatement forLoop)
@OverrideClassNode resultType; public void visitIfElse(IfStatement ifElse)
@Override public void visitMethod(MethodNode node)
protected void visitMethodCallArguments(ArgumentListExpression arguments, boolean visitClosures, MethodNode selectedMethod)
@OverrideParameter[] parameters = ((ClosureExpression) objectExpression).getParameters(); public void visitMethodCallExpression(MethodCallExpression call)
@OverrideresultType = mn.getReturnType(); public void visitPostfixExpression(PostfixExpression expression)
@Override public void visitPrefixExpression(PrefixExpression expression)
@Override} public void visitPropertyExpression(PropertyExpression pexp)
@Override} public void visitRangeExpression(RangeExpression expression)
@Overridenode = typeCheckMapConstructor(call, receiver, arguments); public void visitReturnStatement(ReturnStatement statement)
@Overrideif (parameters.length > 1) { public void visitStaticMethodCallExpression(StaticMethodCallExpression call)
@Override} public void visitSwitch(SwitchStatement statement)
@OverrideMethodNode method = findMethodOrFail(newExpr, left.getPlainNodeReference(), "getAt", right.getPlainNodeReference()); public void visitTernaryExpression(TernaryExpression expression)
@Overrideif (isFloatingCategory(leftRedirect) || isFloatingCategory(rightRedirect)) { public void visitTryCatchFinally(TryCatchStatement statement)
@OverrideresultType = type; public void visitUnaryMinusExpression(UnaryMinusExpression expression)
@Override public void visitUnaryPlusExpression(UnaryPlusExpression expression)
@Override public void visitVariableExpression(VariableExpression vexp)
@Overrideif (!isPrimitiveType(exprType)) { public void visitWhileLoop(WhileStatement loop)
protected static ClassNode wrapTypeIfNecessary(ClassNode type)
Copyright © 2003-2013 The Codehaus. All rights reserved.