Package spoon.reflect.declaration
Interface CtExecutable<R>
- All Superinterfaces:
Cloneable,CtBodyHolder,CtElement,CtNamedElement,CtQueryable,CtTypedElement<R>,CtVisitable,FactoryAccessor,Serializable,SourcePositionHolder
- All Known Subinterfaces:
CtAnnotationMethod<T>,CtAnonymousExecutable,CtConstructor<T>,CtLambda<T>,CtMethod<T>
- All Known Implementing Classes:
CtAnnotationMethodImpl,CtAnonymousExecutableImpl,CtConstructorImpl,CtExecutableImpl,CtLambdaImpl,CtMethodImpl,InvisibleArrayConstructorImpl
This element represents an executable element such as a method, a
constructor, or an anonymous block.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic StringThe separator for a string representation of an executable. -
Method Summary
Modifier and TypeMethodDescription<T extends CtExecutable<R>>
TaddParameter(CtParameter<?> parameter)Add a parameter for this executable<T extends CtExecutable<R>>
TaddParameterAt(int position, CtParameter<?> parameter)Add a parameter at a specific position in the executable.<T extends CtExecutable<R>>
TaddThrownType(CtTypeReference<? extends Throwable> throwType)add a thrown type.clone()Clone the element which calls this method in a new object.getBody()Gets the body expression.List<CtParameter<?>>Gets the parameters list.Returns the corresponding reference.Gets the signature of this exectuable.Set<CtTypeReference<? extends Throwable>>Returns the exceptions and other throwables listed in this method or constructor's throws clause.booleanremoveParameter(CtParameter<?> parameter)Remove a parameter for this executablebooleanremoveThrownType(CtTypeReference<? extends Throwable> throwType)remove a thrown type.<T extends CtExecutable<R>>
TsetParameters(List<CtParameter<?>> parameters)Sets the parameters.<T extends CtExecutable<R>>
TsetThrownTypes(Set<CtTypeReference<? extends Throwable>> thrownTypes)Sets the thrown types.Methods inherited from interface spoon.reflect.code.CtBodyHolder
setBodyMethods 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, setComments, setDocComment, setImplicit, setParent, setPosition, setPositions, setValueByRole, toString, toStringDebug, updateAllParentsBelowMethods inherited from interface spoon.reflect.declaration.CtNamedElement
getSimpleName, setSimpleNameMethods inherited from interface spoon.reflect.visitor.chain.CtQueryable
filterChildren, map, mapMethods inherited from interface spoon.reflect.declaration.CtTypedElement
getType, setTypeMethods inherited from interface spoon.reflect.visitor.CtVisitable
acceptMethods inherited from interface spoon.processing.FactoryAccessor
getFactory, setFactory
-
Field Details
-
EXECUTABLE_SEPARATOR
The separator for a string representation of an executable.- See Also:
- Constant Field Values
-
-
Method Details
-
getReference
CtExecutableReference<R> getReference()Description copied from interface:CtNamedElementReturns the corresponding reference.- Specified by:
getReferencein interfaceCtNamedElement
-
getBody
Gets the body expression.- Specified by:
getBodyin interfaceCtBodyHolder
-
getParameters
List<CtParameter<?>> getParameters()Gets the parameters list. -
setParameters
Sets the parameters. -
addParameter
Add a parameter for this executable- Parameters:
parameter-- Returns:
- true if this element changed as a result of the call
-
addParameterAt
Add a parameter at a specific position in the executable.- Parameters:
position- index where the `parameter` needs to be insertedparameter- parameter to be inserted- Returns:
- an object or sub-type of
CtExecutable
-
removeParameter
Remove a parameter for this executable- Parameters:
parameter-- Returns:
- true if this element changed as a result of the call
-
getThrownTypes
Set<CtTypeReference<? extends Throwable>> getThrownTypes()Returns the exceptions and other throwables listed in this method or constructor's throws clause. -
setThrownTypes
<T extends CtExecutable<R>> T setThrownTypes(Set<CtTypeReference<? extends Throwable>> thrownTypes)Sets the thrown types. -
addThrownType
add a thrown type.- Parameters:
throwType-- Returns:
- true if this element changed as a result of the call
-
removeThrownType
remove a thrown type.- Parameters:
throwType-- Returns:
- true if this element changed as a result of the call
-
getSignature
String getSignature()Gets the signature of this exectuable. The signature is composed of the method name and the parameter types, all fully-qualified, eg "foo(java.lang.String)". The core contract is that in a type, there cannot be two methods with the same signature.Note that the concept of method signature in Java is not well defined (see chapter "8.4.2 Method Signature" of the Java specification, which defines what relations between signatures but not what a signature is exactly).
Note also that the signature of a method reference is the same as the signature of the corresponding method if and only if the method parameters does not involve generics in their types. Otherwise, one has eg m(String) (reference) and m(T) (declaration)
Reference: "In the Java programming language, a method signature is the method name and the number and type of its parameters. Return types and thrown exceptions are not considered to be a part of the method signature."
see Stackoverflow
see Wikipedia -
clone
CtExecutable<R> clone()Description copied from interface:CtElementClone 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.- Specified by:
clonein interfaceCtElement- Specified by:
clonein interfaceCtNamedElement
-