public class UpSafetyAnalysis extends ForwardFlowAnalysis
filterUnitToAfterFlow, unitToAfterFlowfilterUnitToBeforeFlow, graph, unitToBeforeFlow| Constructor and Description |
|---|
UpSafetyAnalysis(DirectedGraph dg)
this constructor should not be used, and will throw a runtime-exception!
|
UpSafetyAnalysis(DirectedGraph dg,
java.util.Map unitToGen,
SideEffectTester sideEffect)
this constructor automaticly performs the UpSafety-analysis.
the result of the analysis is as usual in FlowBefore (getFlowBefore()) and FlowAfter (getFlowAfter()). |
UpSafetyAnalysis(DirectedGraph dg,
java.util.Map unitToGen,
SideEffectTester sideEffect,
BoundedFlowSet set)
this constructor automaticly performs the UpSafety-analysis.
the result of the analysis is as usual in FlowBefore (getFlowBefore()) and FlowAfter (getFlowAfter()). As usually flowset-operations are more efficient if shared, this allows to share sets over several analyses. |
| 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 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.
|
constructWorklist, doAnalysis, isForwardconstructOrderer, getFlowAftergetFlowBefore, merge, mergeInto, treatTrapHandlersAsEntriespublic UpSafetyAnalysis(DirectedGraph dg)
public UpSafetyAnalysis(DirectedGraph dg, java.util.Map unitToGen, SideEffectTester sideEffect)
dg - a ExceptionalUnitGraphunitToGen - the EquivalentValue of each unit.sideEffect - the SideEffectTester that will be used to perform kills.public UpSafetyAnalysis(DirectedGraph dg, java.util.Map unitToGen, SideEffectTester sideEffect, BoundedFlowSet set)
dg - a ExceptionalUnitGraphunitToGen - the EquivalentValue of each unit.sideEffect - the SideEffectTester that will be used to perform kills.set - a bounded flow-set.protected java.lang.Object newInitialFlow()
AbstractFlowAnalysisnewInitialFlow in class AbstractFlowAnalysisprotected java.lang.Object entryInitialFlow()
AbstractFlowAnalysisentryInitialFlow in class AbstractFlowAnalysisprotected void flowThrough(java.lang.Object inValue,
java.lang.Object unit,
java.lang.Object outValue)
FlowAnalysisout 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 FlowAnalysisprotected void merge(java.lang.Object in1,
java.lang.Object in2,
java.lang.Object out)
AbstractFlowAnalysisin1 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 AbstractFlowAnalysisprotected void copy(java.lang.Object source,
java.lang.Object dest)
AbstractFlowAnalysissource flow object in dest.copy in class AbstractFlowAnalysisCopyright © 2012-2019 RoboVM AB. All Rights Reserved.