public interface Executor
ExecutingInvocationUnit
in order to extend its capabilities. An Executor
specifies which
method calls it supports, what methods return their own instance and how a method result is
calculated.Modifier and Type | Interface and Description |
---|---|
static interface |
Executor.Builder<T extends Executor>
A builder for the executor.
|
Modifier and Type | Method and Description |
---|---|
MethodResult |
getMethodResult(MethodExecutionInfo methodData,
ValueCalculator valueCalculator)
Calculate the result of a given method.
|
java.util.Set<MethodSignature> |
getSupportedMethodSignatures()
Get a list of method signatures that indicate which methods are supported by this executor.
|
MethodResult getMethodResult(MethodExecutionInfo methodData, ValueCalculator valueCalculator)
methodData
- Information about the called method.valueCalculator
- a function mapping the result of a method invocation (can be an Object
with the result if the executor calculates a real value or a Model
) to the appropriate Value
used by the
analysis. Should also be used to create values of unknown value since the executor might be
able to provide additional information on them even if the value itself is not known (e.g.,
on the identifier of the returned value).MethodResult.invalidResult()
, so that the caller can know that execution failed and
just provide its best approximation of the result.java.util.Set<MethodSignature> getSupportedMethodSignatures()
The returned methods should be exactly the ones that the executor is expected to be able to handle. The invocation unit does not make any additional assumption on the executors available to execute a method and will match them iff the signature of the target method matches exactly.
Only full method signatures should be returned, the invocation unit does not support wildcards.