public class NullnessAssumptionAnalysis extends BackwardFlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>
| Modifier and Type | Class and Description |
|---|---|
protected static class |
NullnessAssumptionAnalysis.AnalysisInfo
The analysis info is a simple mapping of type
Value to any of the constants BOTTOM, NON_NULL, NULL or TOP. |
FlowAnalysis.Flow| Modifier and Type | Field and Description |
|---|---|
protected static Object |
BOTTOM |
protected static Object |
NON_NULL |
protected static Object |
NULL |
protected static Object |
TOP |
filterUnitToAfterFlow, unitToAfterFlowfilterUnitToBeforeFlow, graph, unitToBeforeFlow| Constructor and Description |
|---|
NullnessAssumptionAnalysis(UnitGraph graph)
Creates a new analysis for the given graph/
|
| Modifier and Type | Method and Description |
|---|---|
protected void |
copy(NullnessAssumptionAnalysis.AnalysisInfo source,
NullnessAssumptionAnalysis.AnalysisInfo dest)
Creates a copy of the
source flow object in dest. |
protected NullnessAssumptionAnalysis.AnalysisInfo |
entryInitialFlow()
Returns the initial flow value for entry/exit graph nodes.
|
protected void |
flowThrough(NullnessAssumptionAnalysis.AnalysisInfo in,
Unit unit,
NullnessAssumptionAnalysis.AnalysisInfo outValue)
Given the merge of the
out sets, compute the in set for s (or in to out,
depending on direction). |
protected boolean |
isAlwaysNonNull(Value v)
This can be overridden by sublasses to mark a certain value as constantly non-null.
|
boolean |
isAssumedNonNullBefore(Unit s,
Immediate i)
Returns
true if the analysis could determine that i is always treated as non-null after and including the
statement s. |
boolean |
isAssumedNullBefore(Unit s,
Immediate i)
Returns
true if the analysis could determine that i is always treated as null after and including the
statement s. |
protected void |
merge(NullnessAssumptionAnalysis.AnalysisInfo in1,
NullnessAssumptionAnalysis.AnalysisInfo in2,
NullnessAssumptionAnalysis.AnalysisInfo out)
Compute the merge of the
in1 and in2 sets, putting the result into out. |
protected NullnessAssumptionAnalysis.AnalysisInfo |
newInitialFlow()
Returns the flow object corresponding to the initial values for each graph node.
|
doAnalysis, isForwardcopyFreshToExisting, getFlow, getFlowAfter, getFlowBefore, omissiblemerge, mergeInto, treatTrapHandlersAsEntriesprotected static final Object BOTTOM
protected static final Object NULL
protected static final Object NON_NULL
protected static final Object TOP
public NullnessAssumptionAnalysis(UnitGraph graph)
graph - any unit graphprotected void flowThrough(NullnessAssumptionAnalysis.AnalysisInfo in, Unit unit, NullnessAssumptionAnalysis.AnalysisInfo outValue)
out sets, compute the in set for s (or in to out,
depending on direction).
This function often causes confusion, because the same interface is used for both forward and backward flow analyses.
The first parameter is always the argument to the flow function (i.e. it is the "in" set in a forward analysis and the
"out" set in a backward analysis), and the third parameter is always the result of the flow function (i.e. it is the
"out" set in a forward analysis and the "in" set in a backward analysis).flowThrough in class FlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>in - the input flowunit - the current nodeoutValue - the returned flowprotected boolean isAlwaysNonNull(Value v)
v - any valueprotected void copy(NullnessAssumptionAnalysis.AnalysisInfo source, NullnessAssumptionAnalysis.AnalysisInfo dest)
source flow object in dest.copy in class AbstractFlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>protected NullnessAssumptionAnalysis.AnalysisInfo entryInitialFlow()
AbstractFlowAnalysis.newInitialFlow()entryInitialFlow in class AbstractFlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>protected void merge(NullnessAssumptionAnalysis.AnalysisInfo in1, NullnessAssumptionAnalysis.AnalysisInfo in2, NullnessAssumptionAnalysis.AnalysisInfo out)
in1 and in2 sets, putting the result into out. The
behavior of this function depends on the implementation ( it may be necessary to check whether in1 and
in2 are equal or aliased ). Used by the doAnalysis method.merge in class AbstractFlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>protected NullnessAssumptionAnalysis.AnalysisInfo newInitialFlow()
newInitialFlow in class AbstractFlowAnalysis<Unit,NullnessAssumptionAnalysis.AnalysisInfo>public boolean isAssumedNullBefore(Unit s, Immediate i)
true if the analysis could determine that i is always treated as null after and including the
statement s.s - a statement of the respective bodyi - a local or constant of that bodypublic boolean isAssumedNonNullBefore(Unit s, Immediate i)
true if the analysis could determine that i is always treated as non-null after and including the
statement s.s - a statement of the respective bodyi - a local of that bodyCopyright © 2024 Soot OSS. All rights reserved.