Package spoon.reflect.reference
Interface CtReference
- All Superinterfaces:
Cloneable
,CtElement
,CtQueryable
,CtVisitable
,FactoryAccessor
,Serializable
,SourcePositionHolder
- All Known Subinterfaces:
CtArrayTypeReference<T>
,CtCatchVariableReference<T>
,CtExecutableReference<T>
,CtFieldReference<T>
,CtIntersectionTypeReference<T>
,CtLocalVariableReference<T>
,CtModuleReference
,CtPackageReference
,CtParameterReference<T>
,CtTypeMemberWildcardImportReference
,CtTypeParameterReference
,CtTypeReference<T>
,CtUnboundVariableReference<T>
,CtVariableReference<T>
,CtWildcardReference
- All Known Implementing Classes:
CtArrayTypeReferenceImpl
,CtCatchVariableReferenceImpl
,CtExecutableReferenceImpl
,CtFieldReferenceImpl
,CtIntersectionTypeReferenceImpl
,CtLocalVariableReferenceImpl
,CtModuleReferenceImpl
,CtPackageReferenceImpl
,CtParameterReferenceImpl
,CtReferenceImpl
,CtTypeMemberWildcardImportReferenceImpl
,CtTypeParameterReferenceImpl
,CtTypeReferenceImpl
,CtUnboundVariableReferenceImpl
,CtVariableReferenceImpl
,CtWildcardReferenceImpl
This is the root interface for named program element references, such as fields, types,
variables, and so on.
If a reference refers to an element in the shadow model, all introspection methods
fall back to reflection where possible, but not all information might be available.
- See Also:
CtElement
-
Method Summary
Modifier and TypeMethodDescriptionclone()
Clone the element which calls this method in a new object.Returns the declaration that corresponds to the referenced element only if the declaration is in the analyzed source files.Gets the simple name of referenced element.<E extends CtElement>
EsetComments(List<CtComment> comments)
comments are not possible for references<T extends CtReference>
TsetSimpleName(String simpleName)
Sets the name of referenced element.Methods inherited from interface spoon.reflect.declaration.CtElement
addAnnotation, addComment, asIterable, delete, descendantIterator, getAllMetadata, getAnnotatedChildren, getAnnotation, getAnnotation, getAnnotations, getComments, getDirectChildren, getDocComment, getElements, getMetadata, getMetadataKeys, getOriginalSourceFragment, getParent, getParent, getParent, getPath, getPosition, getReferencedTypes, getRoleInParent, getShortRepresentation, getValueByRole, hasAnnotation, hasParent, isImplicit, isParentInitialized, prettyprint, putMetadata, removeAnnotation, removeComment, replace, replace, setAllMetadata, setAnnotations, setDocComment, setImplicit, setParent, setPosition, setPositions, setValueByRole, toString, toStringDebug, updateAllParentsBelow
Methods inherited from interface spoon.reflect.visitor.chain.CtQueryable
filterChildren, map, map
Methods inherited from interface spoon.reflect.visitor.CtVisitable
accept
Methods inherited from interface spoon.processing.FactoryAccessor
getFactory, setFactory
-
Method Details
-
getSimpleName
String getSimpleName()Gets the simple name of referenced element. -
setSimpleName
Sets the name of referenced element. -
getDeclaration
CtElement getDeclaration()Returns the declaration that corresponds to the referenced element only if the declaration is in the analyzed source files. It is strongly advised to use the more robustCtTypeReference.getTypeDeclaration()
andCtExecutableReference.getExecutableDeclaration()
that never return null.- Returns:
- referenced element or null if element is not in the source path (aka input resource).
-
clone
CtReference clone()Description copied from interface:CtElement
Clone the element which calls this method in a new object. Note that that references are kept as is, and thus, so if you clone whole classes or methods, some parts of the cloned element (eg executable references) may still point to the initial element. In this case, consider using methodsRefactoring.copyType(CtType)
andRefactoring.copyMethod(CtMethod)
instead which does additional work beyond cloning. -
setComments
comments are not possible for references- Specified by:
setComments
in interfaceCtElement
-