Package edu.umd.cs.findbugs.ba
Class LiveLocalStoreAnalysis
- java.lang.Object
-
- edu.umd.cs.findbugs.ba.BasicAbstractDataflowAnalysis<Fact>
-
- edu.umd.cs.findbugs.ba.AbstractDataflowAnalysis<Fact>
-
- edu.umd.cs.findbugs.ba.BackwardDataflowAnalysis<java.util.BitSet>
-
- edu.umd.cs.findbugs.ba.LiveLocalStoreAnalysis
-
- All Implemented Interfaces:
DataflowAnalysis<java.util.BitSet>
,Debug
public class LiveLocalStoreAnalysis extends BackwardDataflowAnalysis<java.util.BitSet> implements Debug
Dataflow analysis to find live stores of locals. This is just a backward analysis to see which loads reach stores of the same local.This analysis also computes which stores that were killed by a subsequent store on any subsequent reachable path. (The FindDeadLocalStores detector uses this information to reduce false positives.)
- Author:
- David Hovemeyer
-
-
Field Summary
-
Fields inherited from interface edu.umd.cs.findbugs.ba.Debug
VERIFY_INTEGRITY
-
-
Constructor Summary
Constructors Constructor Description LiveLocalStoreAnalysis(org.apache.bcel.generic.MethodGen methodGen, ReverseDepthFirstSearch rdfs, DepthFirstSearch dfs)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
copy(java.util.BitSet source, java.util.BitSet dest)
Copy dataflow facts.java.util.BitSet
createFact()
Create empty (uninitialized) dataflow facts for one program point.java.lang.String
factToString(java.util.BitSet fact)
Return a String representation of given Fact.void
initEntryFact(java.util.BitSet result)
Initialize the "entry" fact for the graph.boolean
isFactValid(java.util.BitSet fact)
Determine whether the given fact is valid (neither top nor bottom).boolean
isStoreAlive(java.util.BitSet fact, int local)
Return whether or not a store of given local is alive.boolean
isTop(java.util.BitSet fact)
Return whether or not given fact is the special TOP value.boolean
killedByStore(java.util.BitSet fact, int local)
Return whether or not a store of given local was killed by a subsequent (dominated) store.void
makeFactTop(java.util.BitSet fact)
Make given fact the top value.void
meetInto(java.util.BitSet fact, Edge edge, java.util.BitSet result)
Meet a dataflow fact associated with an incoming edge into another fact.boolean
same(java.util.BitSet fact1, java.util.BitSet fact2)
Are given dataflow facts the same?void
transferInstruction(org.apache.bcel.generic.InstructionHandle handle, BasicBlock basicBlock, java.util.BitSet fact)
Transfer function for a single instruction.-
Methods inherited from class edu.umd.cs.findbugs.ba.BackwardDataflowAnalysis
getBlockOrder, getReverseDepthFirstSearch, isForwards
-
Methods inherited from class edu.umd.cs.findbugs.ba.AbstractDataflowAnalysis
getFactAfterLocation, getFactAtLocation, transfer
-
Methods inherited from class edu.umd.cs.findbugs.ba.BasicAbstractDataflowAnalysis
edgeTransfer, finishIteration, getFactOnEdge, getLastUpdateTimestamp, getResultFact, getStartFact, resultFactIterator, setLastUpdateTimestamp, startIteration
-
-
-
-
Constructor Detail
-
LiveLocalStoreAnalysis
public LiveLocalStoreAnalysis(org.apache.bcel.generic.MethodGen methodGen, ReverseDepthFirstSearch rdfs, DepthFirstSearch dfs)
-
-
Method Detail
-
createFact
public java.util.BitSet createFact()
Description copied from interface:DataflowAnalysis
Create empty (uninitialized) dataflow facts for one program point. A valid value will be copied into it before it is used.- Specified by:
createFact
in interfaceDataflowAnalysis<java.util.BitSet>
-
copy
public void copy(java.util.BitSet source, java.util.BitSet dest)
Description copied from interface:DataflowAnalysis
Copy dataflow facts.- Specified by:
copy
in interfaceDataflowAnalysis<java.util.BitSet>
-
initEntryFact
public void initEntryFact(java.util.BitSet result) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysis
Initialize the "entry" fact for the graph.- Specified by:
initEntryFact
in interfaceDataflowAnalysis<java.util.BitSet>
- Throws:
DataflowAnalysisException
-
makeFactTop
public void makeFactTop(java.util.BitSet fact)
Description copied from interface:DataflowAnalysis
Make given fact the top value.- Specified by:
makeFactTop
in interfaceDataflowAnalysis<java.util.BitSet>
-
same
public boolean same(java.util.BitSet fact1, java.util.BitSet fact2)
Description copied from interface:DataflowAnalysis
Are given dataflow facts the same?- Specified by:
same
in interfaceDataflowAnalysis<java.util.BitSet>
-
meetInto
public void meetInto(java.util.BitSet fact, Edge edge, java.util.BitSet result) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysis
Meet a dataflow fact associated with an incoming edge into another fact. This is used to determine the start fact for a basic block.- Specified by:
meetInto
in interfaceDataflowAnalysis<java.util.BitSet>
- Parameters:
fact
- the predecessor fact (incoming edge)edge
- the edge from the predecessorresult
- the result fact- Throws:
DataflowAnalysisException
-
transferInstruction
public void transferInstruction(org.apache.bcel.generic.InstructionHandle handle, BasicBlock basicBlock, java.util.BitSet fact) throws DataflowAnalysisException
Description copied from class:AbstractDataflowAnalysis
Transfer function for a single instruction.- Specified by:
transferInstruction
in classAbstractDataflowAnalysis<java.util.BitSet>
- Parameters:
handle
- the instructionbasicBlock
- the BasicBlock containing the instruction; needed to disambiguate instructions in inlined JSR subroutinesfact
- which should be modified based on the instruction- Throws:
DataflowAnalysisException
-
isFactValid
public boolean isFactValid(java.util.BitSet fact)
Description copied from class:AbstractDataflowAnalysis
Determine whether the given fact is valid (neither top nor bottom).- Specified by:
isFactValid
in classAbstractDataflowAnalysis<java.util.BitSet>
-
factToString
public java.lang.String factToString(java.util.BitSet fact)
Description copied from interface:DataflowAnalysis
Return a String representation of given Fact. For debugging purposes.- Specified by:
factToString
in interfaceDataflowAnalysis<java.util.BitSet>
- Overrides:
factToString
in classBasicAbstractDataflowAnalysis<java.util.BitSet>
- Parameters:
fact
- a dataflow fact- Returns:
- String representation of the fact
-
isTop
public boolean isTop(java.util.BitSet fact)
Return whether or not given fact is the special TOP value.- Specified by:
isTop
in interfaceDataflowAnalysis<java.util.BitSet>
-
isStoreAlive
public boolean isStoreAlive(java.util.BitSet fact, int local)
Return whether or not a store of given local is alive.- Parameters:
fact
- a dataflow fact created by this analysislocal
- the local
-
killedByStore
public boolean killedByStore(java.util.BitSet fact, int local)
Return whether or not a store of given local was killed by a subsequent (dominated) store.
-
-