Package edu.umd.cs.findbugs.ba.obl
Class ObligationAnalysis
- java.lang.Object
-
- edu.umd.cs.findbugs.ba.BasicAbstractDataflowAnalysis<Fact>
-
- edu.umd.cs.findbugs.ba.AbstractDataflowAnalysis<Fact>
-
- edu.umd.cs.findbugs.ba.ForwardDataflowAnalysis<StateSet>
-
- edu.umd.cs.findbugs.ba.obl.ObligationAnalysis
-
- All Implemented Interfaces:
DataflowAnalysis<StateSet>
public class ObligationAnalysis extends ForwardDataflowAnalysis<StateSet>
Dataflow analysis to track obligations (i/o streams and other resources which must be closed).See Weimer and Necula, Finding and preventing run-time error handling mistakes, OOPSLA 2004.
- Author:
- David Hovemeyer
-
-
Constructor Summary
Constructors Constructor Description ObligationAnalysis(DepthFirstSearch dfs, XMethod xmethod, org.apache.bcel.generic.ConstantPoolGen cpg, ObligationFactory factory, ObligationPolicyDatabase database, TypeDataflow typeDataflow, IsNullValueDataflow invDataflow, IErrorLogger errorLogger)Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidcopy(StateSet src, StateSet dest)Copy dataflow facts.StateSetcreateFact()Create empty (uninitialized) dataflow facts for one program point.voidedgeTransfer(Edge edge, StateSet fact)Edge transfer function.InstructionActionCachegetActionCache()voidinitEntryFact(StateSet fact)Initialize the "entry" fact for the graph.booleanisFactValid(StateSet fact)Determine whether the given fact is valid (neither top nor bottom).booleanisTop(StateSet fact)Is the given fact the top value.voidmakeFactTop(StateSet fact)Make given fact the top value.voidmeetInto(StateSet fact, Edge edge, StateSet result)Meet a dataflow fact associated with an incoming edge into another fact.booleansame(StateSet a, StateSet b)Are given dataflow facts the same?voidtransfer(BasicBlock basicBlock, org.apache.bcel.generic.InstructionHandle end, StateSet start, StateSet result)Transfer function for the analysis.voidtransferInstruction(org.apache.bcel.generic.InstructionHandle handle, BasicBlock basicBlock, StateSet fact)Transfer function for a single instruction.-
Methods inherited from class edu.umd.cs.findbugs.ba.ForwardDataflowAnalysis
getBlockOrder, getDepthFirstSearch, isForwards
-
Methods inherited from class edu.umd.cs.findbugs.ba.AbstractDataflowAnalysis
getFactAfterLocation, getFactAtLocation
-
Methods inherited from class edu.umd.cs.findbugs.ba.BasicAbstractDataflowAnalysis
factToString, finishIteration, getFactOnEdge, getLastUpdateTimestamp, getResultFact, getStartFact, resultFactIterator, setLastUpdateTimestamp, startIteration
-
-
-
-
Constructor Detail
-
ObligationAnalysis
public ObligationAnalysis(DepthFirstSearch dfs, XMethod xmethod, org.apache.bcel.generic.ConstantPoolGen cpg, ObligationFactory factory, ObligationPolicyDatabase database, TypeDataflow typeDataflow, IsNullValueDataflow invDataflow, IErrorLogger errorLogger)
Constructor.- Parameters:
dfs- a DepthFirstSearch on the method to be analyzedxmethod- method to analyzecpg- ConstantPoolGen of the method to be analyzedfactory- the ObligationFactory defining the obligation typesdatabase- the PolicyDatabase defining the methods which add and delete obligationserrorLogger- callback to use when reporting missing classes
-
-
Method Detail
-
getActionCache
public InstructionActionCache getActionCache()
-
createFact
public StateSet createFact()
Description copied from interface:DataflowAnalysisCreate empty (uninitialized) dataflow facts for one program point. A valid value will be copied into it before it is used.
-
isFactValid
public boolean isFactValid(StateSet fact)
Description copied from class:AbstractDataflowAnalysisDetermine whether the given fact is valid (neither top nor bottom).- Specified by:
isFactValidin classAbstractDataflowAnalysis<StateSet>
-
transferInstruction
public void transferInstruction(org.apache.bcel.generic.InstructionHandle handle, BasicBlock basicBlock, StateSet fact) throws DataflowAnalysisExceptionDescription copied from class:AbstractDataflowAnalysisTransfer function for a single instruction.- Specified by:
transferInstructionin classAbstractDataflowAnalysis<StateSet>- 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
-
transfer
public void transfer(BasicBlock basicBlock, @CheckForNull org.apache.bcel.generic.InstructionHandle end, StateSet start, StateSet result) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysisTransfer function for the analysis. Taking dataflow facts at start (which might be either the entry or exit of the block, depending on whether the analysis is forwards or backwards), modify result to be the facts at the other end of the block.- Specified by:
transferin interfaceDataflowAnalysis<StateSet>- Overrides:
transferin classAbstractDataflowAnalysis<StateSet>- Parameters:
basicBlock- the basic blockend- if nonnull, stop before considering this instruction; otherwise, consider all of the instructions in the basic blockstart- dataflow facts at beginning of block (if forward analysis) or end of block (if backwards analysis)result- resulting dataflow facts at other end of block- Throws:
DataflowAnalysisException
-
edgeTransfer
public void edgeTransfer(Edge edge, StateSet fact) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysisEdge transfer function. Modify the given fact that is true on the (logical) edge source to modify it so that it is true at the (logical) edge target.A do-nothing implementation is legal, and appropriate for analyses where branches are not significant.
- Specified by:
edgeTransferin interfaceDataflowAnalysis<StateSet>- Overrides:
edgeTransferin classBasicAbstractDataflowAnalysis<StateSet>- Parameters:
edge- the Edgefact- a dataflow fact- Throws:
DataflowAnalysisException
-
copy
public void copy(StateSet src, StateSet dest)
Description copied from interface:DataflowAnalysisCopy dataflow facts.
-
initEntryFact
public void initEntryFact(StateSet fact) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysisInitialize the "entry" fact for the graph.- Throws:
DataflowAnalysisException
-
makeFactTop
public void makeFactTop(StateSet fact)
Description copied from interface:DataflowAnalysisMake given fact the top value.
-
isTop
public boolean isTop(StateSet fact)
Description copied from interface:DataflowAnalysisIs the given fact the top value.
-
same
public boolean same(StateSet a, StateSet b)
Description copied from interface:DataflowAnalysisAre given dataflow facts the same?
-
meetInto
public void meetInto(StateSet fact, Edge edge, StateSet result) throws DataflowAnalysisException
Description copied from interface:DataflowAnalysisMeet a dataflow fact associated with an incoming edge into another fact. This is used to determine the start fact for a basic block.- Parameters:
fact- the predecessor fact (incoming edge)edge- the edge from the predecessorresult- the result fact- Throws:
DataflowAnalysisException
-
-