Package org.apache.groovy.ast.tools
Class ClassNodeUtils
java.lang.Object
org.apache.groovy.ast.tools.ClassNodeUtils
public class ClassNodeUtils
extends java.lang.Object
Utility class for working with ClassNodes
- 
Method SummaryModifier and Type Method Description static voidaddDeclaredMethodsFromAllInterfaces(ClassNode cNode, java.util.Map<java.lang.String,MethodNode> methodsMap)Adds methods from interfaces and parent interfaces.static voidaddDeclaredMethodsFromInterfaces(ClassNode cNode, java.util.Map<java.lang.String,MethodNode> methodsMap)Adds methods from all interfaces.static ConstructorNodeaddGeneratedConstructor(ClassNode classNode, int modifiers, Parameter[] parameters, ClassNode[] exceptions, Statement code)Add a method that is marked as@Generated.static voidaddGeneratedConstructor(ClassNode classNode, ConstructorNode consNode)Add a method that is marked as@Generated.static voidaddGeneratedInnerClass(ClassNode cNode, ClassNode inner)Add an inner class that is marked as@Generated.static MethodNodeaddGeneratedMethod(ClassNode cNode, java.lang.String name, int modifiers, ClassNode returnType, Parameter[] parameters, ClassNode[] exceptions, Statement code)Return an existing method if one exists or else create a new method and mark it as@Generated.static voidaddGeneratedMethod(ClassNode cNode, MethodNode mNode)Add a method and mark it as@Generated.static voidaddGeneratedMethod(ClassNode cNode, MethodNode mNode, boolean skipChecks)Add a method and mark it as@Generated.static java.lang.StringformatTypeName(ClassNode cNode)Formats a type name into a human readable version.static java.util.Map<java.lang.String,MethodNode>getDeclaredMethodsFromInterfaces(ClassNode cNode)Gets methods from all interfaces.static java.util.Map<java.lang.String,MethodNode>getDeclaredMethodsFromSuper(ClassNode cNode)Add methods from the super class.static FieldNodegetField(ClassNode classNode, java.lang.String fieldName)Return the (potentially inherited) field of the classnode.static java.lang.StringgetPropNameForAccessor(java.lang.String accessorName)Returns the property name, e.g.static PropertyNodegetStaticProperty(ClassNode cNode, java.lang.String propName)Detect whether a static property with the given name is within the class or a super class.static booleanhasExplicitConstructor(AbstractASTTransformation xform, ClassNode cNode)Determine if an explicit (non-generated) constructor is in the class.static booleanhasNoArgConstructor(ClassNode cNode)static booleanhasPossibleStaticMethod(ClassNode cNode, java.lang.String name, Expression arguments, boolean trySpread)Returns true if the given method has a possibly matching static method with the given name and arguments.static booleanhasPossibleStaticProperty(ClassNode cNode, java.lang.String methodName)Return true if we have a static accessorstatic booleanhasStaticProperty(ClassNode cNode, java.lang.String propName)static booleanisInnerClass(ClassNode cNode)Detect whether a given ClassNode is an inner class (non-static).static booleanisSubtype(ClassNode maybeSuperclassOrInterface, ClassNode candidateChild)static booleanisValidAccessorName(java.lang.String accessorName)Detect whether the given accessor name starts with "get", "set" or "is" followed by at least one character.static booleansamePackageName(ClassNode first, ClassNode second)Determine if the given ClassNode values have the same package name.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
- 
Method Details- 
formatTypeNameFormats a type name into a human readable version. For arrays, appends "[]" to the formatted type name of the component. For unit class nodes, uses the class node name.- Parameters:
- cNode- the type to format
- Returns:
- a human readable version of the type name (java.lang.String[] for example)
 
- 
addGeneratedMethodpublic static MethodNode addGeneratedMethod(ClassNode cNode, java.lang.String name, int modifiers, ClassNode returnType, Parameter[] parameters, ClassNode[] exceptions, Statement code)Return an existing method if one exists or else create a new method and mark it as@Generated.
- 
addGeneratedMethodAdd a method and mark it as@Generated.- See Also:
- ClassNode.addMethod(MethodNode)
 
- 
addGeneratedMethodAdd a method and mark it as@Generated.- See Also:
- ClassNode.addMethod(MethodNode)
 
- 
addGeneratedInnerClassAdd an inner class that is marked as@Generated.- See Also:
- ModuleNode.addClass(ClassNode)
 
- 
addGeneratedConstructorpublic static ConstructorNode addGeneratedConstructor(ClassNode classNode, int modifiers, Parameter[] parameters, ClassNode[] exceptions, Statement code)Add a method that is marked as@Generated.
- 
addGeneratedConstructorAdd a method that is marked as@Generated.
- 
getDeclaredMethodsFromSuperpublic static java.util.Map<java.lang.String,MethodNode> getDeclaredMethodsFromSuper(ClassNode cNode)Add methods from the super class.- Parameters:
- cNode- The ClassNode
- Returns:
- A map of methods
 
- 
addDeclaredMethodsFromInterfacespublic static void addDeclaredMethodsFromInterfaces(ClassNode cNode, java.util.Map<java.lang.String,MethodNode> methodsMap)Adds methods from all interfaces. Existing entries in the methods map take precedence. Methods from interfaces visited early take precedence over later ones.- Parameters:
- cNode- The ClassNode
- methodsMap- A map of existing methods to alter
 
- 
getDeclaredMethodsFromInterfacespublic static java.util.Map<java.lang.String,MethodNode> getDeclaredMethodsFromInterfaces(ClassNode cNode)Gets methods from all interfaces. Methods from interfaces visited early take precedence over later ones.- Parameters:
- cNode- The ClassNode
- Returns:
- A map of methods
 
- 
addDeclaredMethodsFromAllInterfacespublic static void addDeclaredMethodsFromAllInterfaces(ClassNode cNode, java.util.Map<java.lang.String,MethodNode> methodsMap)Adds methods from interfaces and parent interfaces. Existing entries in the methods map take precedence. Methods from interfaces visited early take precedence over later ones.- Parameters:
- cNode- The ClassNode
- methodsMap- A map of existing methods to alter
 
- 
hasPossibleStaticMethodpublic static boolean hasPossibleStaticMethod(ClassNode cNode, java.lang.String name, Expression arguments, boolean trySpread)Returns true if the given method has a possibly matching static method with the given name and arguments. Handles default arguments and optionally spread expressions.- Parameters:
- cNode- the ClassNode of interest
- name- the name of the method of interest
- arguments- the arguments to match against
- trySpread- whether to try to account for SpreadExpressions within the arguments
- Returns:
- trueif a matching method was found.
 
- 
hasPossibleStaticPropertyReturn true if we have a static accessor
- 
getPropNameForAccessorpublic static java.lang.String getPropNameForAccessor(java.lang.String accessorName)Returns the property name, e.g. age, given an accessor name, e.g. getAge. Returns the original if a valid prefix cannot be removed.- Parameters:
- accessorName- the accessor name of interest, e.g. getAge
- Returns:
- the property name, e.g. age, or original if not a valid property accessor name
 
- 
isValidAccessorNamepublic static boolean isValidAccessorName(java.lang.String accessorName)Detect whether the given accessor name starts with "get", "set" or "is" followed by at least one character.- Parameters:
- accessorName- the accessor name of interest, e.g. getAge
- Returns:
- true if a valid prefix is found
 
- 
hasStaticProperty
- 
getStaticPropertyDetect whether a static property with the given name is within the class or a super class.- Parameters:
- cNode- the ClassNode of interest
- propName- the property name
- Returns:
- the static property if found or else null
 
- 
isInnerClassDetect whether a given ClassNode is an inner class (non-static).- Parameters:
- cNode- the ClassNode of interest
- Returns:
- true if the given node is a (non-static) inner class, else false
 
- 
hasNoArgConstructor
- 
hasExplicitConstructorDetermine if an explicit (non-generated) constructor is in the class.- Parameters:
- xform- if non null, add an error if an explicit constructor is found
- cNode- the type of the containing class
- Returns:
- true if an explicit (non-generated) constructor was found
 
- 
samePackageNameDetermine if the given ClassNode values have the same package name.- Parameters:
- first- a ClassNode
- second- a ClassNode
- Returns:
- true if both given nodes have the same package name
- Throws:
- java.lang.NullPointerException- if either of the given nodes are null
 
- 
getFieldReturn the (potentially inherited) field of the classnode.- Parameters:
- classNode- the classnode
- fieldName- the name of the field
- Returns:
- the field or null if not found
 
- 
isSubtype
 
-