public class DownSafetyAnalysis extends BackwardFlowAnalysis<Unit,FlowSet<EquivalentValue>>
FlowAnalysis.Flow
filterUnitToAfterFlow, unitToAfterFlow
filterUnitToBeforeFlow, graph, unitToBeforeFlow
Constructor and Description |
---|
DownSafetyAnalysis(DirectedGraph<Unit> dg)
This constructor should not be used, and will throw a runtime-exception!
|
DownSafetyAnalysis(DirectedGraph<Unit> dg,
java.util.Map<Unit,EquivalentValue> unitToGen,
SideEffectTester sideEffect)
This constructor automatically performs the DownSafety-analysis.
the result of the analysis is as usual in FlowBefore (getFlowBefore()) and FlowAfter (getFlowAfter()). |
DownSafetyAnalysis(DirectedGraph<Unit> dg,
java.util.Map<Unit,EquivalentValue> unitToGen,
SideEffectTester sideEffect,
BoundedFlowSet<EquivalentValue> set)
This constructor automatically performs the DownSafety-analysis.
the result of the analysis is as usual in FlowBefore (getFlowBefore()) and FlowAfter (getFlowAfter()). as sets-operations are usually more efficient, if the original set comes from the same source, this allows to share sets. |
Modifier and Type | Method and Description |
---|---|
protected void |
copy(FlowSet<EquivalentValue> source,
FlowSet<EquivalentValue> dest)
Creates a copy of the
source flow object in dest . |
protected FlowSet<EquivalentValue> |
entryInitialFlow()
Returns the initial flow value for entry/exit graph nodes.
|
protected void |
flowThrough(FlowSet<EquivalentValue> in,
Unit u,
FlowSet<EquivalentValue> out)
Given the merge of the
out sets, compute the in
set for s (or in to out, depending on direction). |
protected void |
merge(FlowSet<EquivalentValue> in1,
FlowSet<EquivalentValue> in2,
FlowSet<EquivalentValue> out)
Compute the merge of the
in1 and in2 sets, putting the result into out . |
protected FlowSet<EquivalentValue> |
newInitialFlow()
Returns the flow object corresponding to the initial values for
each graph node.
|
doAnalysis, isForward
getFlow, getFlowAfter, getFlowBefore, omissible
merge, mergeInto, treatTrapHandlersAsEntries
public DownSafetyAnalysis(DirectedGraph<Unit> dg)
public DownSafetyAnalysis(DirectedGraph<Unit> dg, java.util.Map<Unit,EquivalentValue> unitToGen, SideEffectTester sideEffect)
dg
- a ExceptionalUnitGraph.unitToGen
- the equivalentValue of each unit.sideEffect
- the SideEffectTester that performs kills.public DownSafetyAnalysis(DirectedGraph<Unit> dg, java.util.Map<Unit,EquivalentValue> unitToGen, SideEffectTester sideEffect, BoundedFlowSet<EquivalentValue> set)
dg
- a ExceptionalUnitGraph.unitToGen
- the equivalentValue of each unit.sideEffect
- the SideEffectTester that performs kills.BoundedFlowSet
- the shared set.protected FlowSet<EquivalentValue> newInitialFlow()
AbstractFlowAnalysis
newInitialFlow
in class AbstractFlowAnalysis<Unit,FlowSet<EquivalentValue>>
protected FlowSet<EquivalentValue> entryInitialFlow()
AbstractFlowAnalysis
AbstractFlowAnalysis.newInitialFlow()
entryInitialFlow
in class AbstractFlowAnalysis<Unit,FlowSet<EquivalentValue>>
protected void flowThrough(FlowSet<EquivalentValue> in, Unit u, FlowSet<EquivalentValue> out)
FlowAnalysis
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,FlowSet<EquivalentValue>>
in
- the input flowu
- the current nodeout
- the returned flowprotected void merge(FlowSet<EquivalentValue> in1, FlowSet<EquivalentValue> in2, FlowSet<EquivalentValue> out)
AbstractFlowAnalysis
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,FlowSet<EquivalentValue>>
protected void copy(FlowSet<EquivalentValue> source, FlowSet<EquivalentValue> dest)
AbstractFlowAnalysis
source
flow object in dest
.copy
in class AbstractFlowAnalysis<Unit,FlowSet<EquivalentValue>>