spoon.reflect.declaration.CtExecutable Maven / Gradle / Ivy
/*
* SPDX-License-Identifier: (MIT OR CECILL-C)
*
* Copyright (C) 2006-2019 INRIA and contributors
*
* Spoon is available either under the terms of the MIT License (see LICENSE-MIT.txt) of the Cecill-C License (see LICENSE-CECILL-C.txt). You as the user are entitled to choose the terms under which to adopt Spoon.
*/
package spoon.reflect.declaration;
import spoon.reflect.annotations.PropertyGetter;
import spoon.reflect.annotations.PropertySetter;
import spoon.reflect.code.CtBlock;
import spoon.reflect.code.CtBodyHolder;
import spoon.reflect.reference.CtExecutableReference;
import spoon.reflect.reference.CtTypeReference;
import spoon.support.DerivedProperty;
import java.util.List;
import java.util.Set;
import static spoon.reflect.path.CtRole.PARAMETER;
import static spoon.reflect.path.CtRole.THROWN;
/**
* This element represents an executable element such as a method, a
* constructor, or an anonymous block.
*/
public interface CtExecutable extends CtNamedElement, CtTypedElement, CtBodyHolder {
/**
* The separator for a string representation of an executable.
*/
String EXECUTABLE_SEPARATOR = "#";
/*
* (non-Javadoc)
*
* @see spoon.reflect.declaration.CtNamedElement#getReference()
*/
@Override
@DerivedProperty
CtExecutableReference getReference();
/**
* Gets the body expression.
*/
@Override
CtBlock getBody();
/**
* Gets the parameters list.
*/
@PropertyGetter(role = PARAMETER)
List> getParameters();
/**
* Sets the parameters.
*/
@PropertySetter(role = PARAMETER)
> T setParameters(List> parameters);
/**
* Add a parameter for this executable
*
* @param parameter
* @return true if this element changed as a result of the call
*/
@PropertySetter(role = PARAMETER)
> T addParameter(CtParameter> parameter);
/**
* Add a parameter at a specific position in the executable.
*
* @param position index where the `parameter` needs to be inserted
* @param parameter parameter to be inserted
* @return an object or sub-type of {@link CtExecutable}
*/
@PropertySetter(role = PARAMETER)
> T addParameterAt(int position, CtParameter> parameter);
/**
* Remove a parameter for this executable
*
* @param parameter
* @return true if this element changed as a result of the call
*/
boolean removeParameter(CtParameter> parameter);
/**
* Returns the exceptions and other throwables listed in this method or
* constructor's throws clause.
*/
@PropertyGetter(role = THROWN)
Set> getThrownTypes();
/**
* Sets the thrown types.
*/
@PropertySetter(role = THROWN)
> T setThrownTypes(Set> thrownTypes);
/**
* add a thrown type.
*
* @param throwType
* @return true if this element changed as a result of the call
*/
@PropertySetter(role = THROWN)
> T addThrownType(CtTypeReference extends Throwable> throwType);
/**
* remove a thrown type.
*
* @param throwType
* @return true if this element changed as a result of the call
*/
@PropertySetter(role = THROWN)
boolean removeThrownType(CtTypeReference extends Throwable> throwType);
/**
* Gets the signature of this exectuable.
* The signature is composed of the method name and the parameter types, all fully-qualified, eg
* "{@code 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
*/
String getSignature();
@Override
CtExecutable clone();
}