public class NullnessAssumptionAnalysis extends BackwardFlowAnalysis
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 java.lang.Object |
BOTTOM |
protected static java.lang.Object |
NON_NULL |
protected static java.lang.Object |
NULL |
protected static java.lang.Object |
TOP |
filterUnitToAfterFlow, unitToAfterFlow
filterUnitToBeforeFlow, 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(java.lang.Object source,
java.lang.Object dest)
Creates a copy of the
source flow object in dest . |
protected java.lang.Object |
entryInitialFlow()
Returns the initial flow value for entry/exit graph nodes.
|
protected void |
flowThrough(java.lang.Object inValue,
java.lang.Object unit,
java.lang.Object 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(java.lang.Object in1,
java.lang.Object in2,
java.lang.Object out)
Compute the merge of the
in1 and in2 sets, putting the result into out . |
protected java.lang.Object |
newInitialFlow()
Returns the flow object corresponding to the initial values for
each graph node.
|
doAnalysis, isForward
getFlow, getFlowAfter, getFlowBefore, omissible
merge, mergeInto, treatTrapHandlersAsEntries
protected static final java.lang.Object BOTTOM
protected static final java.lang.Object NULL
protected static final java.lang.Object NON_NULL
protected static final java.lang.Object TOP
public NullnessAssumptionAnalysis(UnitGraph graph)
graph
- any unit graphprotected void flowThrough(java.lang.Object inValue, java.lang.Object unit, java.lang.Object 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
inValue
- the input flowunit
- the current nodeoutValue
- the returned flowprotected boolean isAlwaysNonNull(Value v)
v
- any valueprotected void copy(java.lang.Object source, java.lang.Object dest)
source
flow object in dest
.copy
in class AbstractFlowAnalysis
protected java.lang.Object entryInitialFlow()
AbstractFlowAnalysis.newInitialFlow()
entryInitialFlow
in class AbstractFlowAnalysis
protected void merge(java.lang.Object in1, java.lang.Object in2, java.lang.Object 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
protected java.lang.Object newInitialFlow()
newInitialFlow
in class AbstractFlowAnalysis
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 body