Package proguard.analysis.cpa.jvm.cfa
Class JvmCfa
- java.lang.Object
- 
- proguard.analysis.cpa.defaults.Cfa<JvmCfaNode,JvmCfaEdge,MethodSignature>
- 
- proguard.analysis.cpa.jvm.cfa.JvmCfa
 
 
- 
 public class JvmCfa extends Cfa<JvmCfaNode,JvmCfaEdge,MethodSignature> A JVM specific implementation ofCfa.The keys of the function maps are the MethodSignatures.The nodes of a function are identified by the offset of the code location. Besides the normal exit node for return instructions, function can also have a special exit node for uncaught exceptions. An additional JvmCatchCfaNodeis added for each handler in the method exception table.A unique JvmUnknownCfaNodenode is used for instructions the successor of which is unknown.
- 
- 
Field Summary- 
Fields inherited from class proguard.analysis.cpa.defaults.CfafunctionNodes
 
- 
 - 
Constructor SummaryConstructors Constructor Description JvmCfa()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddFunctionCatchNode(MethodSignature signature, JvmCatchCfaNode node, int offset)Adds a catch node to the CFA (i.e.voidaddInterproceduralEdge(Call call)Adds a call node between two methods.JvmCfaNodeaddNodeIfAbsent(MethodSignature signature, int offset, Clazz clazz)If the requested function node is present in the graph return it.voidaddUnknownTargetInterproceduralEdge(Call call)Adds a call node between two methods.voidclear()Removes references to this CFA nodes from the singletonJvmUnknownCfaNodeand clears its node collections making it garbage collectable.booleancontainsFunctionCatchNode(MethodSignature signature, int offset)Returns true if the catch node of the specified method at the specified offset is present in the graph.java.util.stream.Stream<JvmCfaNode>getAllNodes()Returns a stream of all the nodes present in the graph.JvmCatchCfaNodegetFunctionCatchNode(MethodSignature signature, int offset)Returns the catch node of a method the handler of which begins at the specific code offset, returns null if the method or the specific catch node are not in the graph.java.util.Collection<JvmCatchCfaNode>getFunctionCatchNodes(MethodSignature signature)Returns all the catch nodes of a specific method, returns an empty collection if the function is not in the graph or if it has no catch nodes.JvmCfaNodegetFunctionExceptionExitNode(MethodSignature signature, Clazz clazz)Returns the exception exit node (i.e.JvmCfaNodegetFunctionReturnExitNode(MethodSignature signature, Clazz clazz)Returns the exit node of the specified method if present, otherwise creates the exit node for the method and returns it.- 
Methods inherited from class proguard.analysis.cpa.defaults.CfaaddFunctionEntryNode, addFunctionNode, getFunctionEntryNode, getFunctionEntryNodes, getFunctionNode, getFunctionNode, getFunctionNodes, isEmpty
 
- 
 
- 
- 
- 
Method Detail- 
getAllNodespublic java.util.stream.Stream<JvmCfaNode> getAllNodes() Description copied from class:CfaReturns a stream of all the nodes present in the graph.Note: a Streamis provided to avoid creating new collections unnecessarily.- Overrides:
- getAllNodesin class- Cfa<JvmCfaNode,JvmCfaEdge,MethodSignature>
 
 - 
getFunctionCatchNodespublic java.util.Collection<JvmCatchCfaNode> getFunctionCatchNodes(MethodSignature signature) Returns all the catch nodes of a specific method, returns an empty collection if the function is not in the graph or if it has no catch nodes.- Parameters:
- signature- The signature of the method.
 
 - 
getFunctionCatchNodepublic JvmCatchCfaNode getFunctionCatchNode(MethodSignature signature, int offset) Returns the catch node of a method the handler of which begins at the specific code offset, returns null if the method or the specific catch node are not in the graph.- Parameters:
- signature- The signature of the method, might be different for different domains.
- offset- The offset of the catch handler represented by the node.
 
 - 
addFunctionCatchNodepublic void addFunctionCatchNode(MethodSignature signature, JvmCatchCfaNode node, int offset) Adds a catch node to the CFA (i.e. a node indicating the beginning of an exception handler).
 - 
containsFunctionCatchNodepublic boolean containsFunctionCatchNode(MethodSignature signature, int offset) Returns true if the catch node of the specified method at the specified offset is present in the graph.
 - 
getFunctionReturnExitNodepublic JvmCfaNode getFunctionReturnExitNode(MethodSignature signature, Clazz clazz) Returns the exit node of the specified method if present, otherwise creates the exit node for the method and returns it.
 - 
getFunctionExceptionExitNodepublic JvmCfaNode getFunctionExceptionExitNode(MethodSignature signature, Clazz clazz) Returns the exception exit node (i.e. the exit node in case of not caught exception) of the specified method if present, otherwise creates the exit node for the method and returns it.
 - 
addNodeIfAbsentpublic JvmCfaNode addNodeIfAbsent(MethodSignature signature, int offset, Clazz clazz) If the requested function node is present in the graph return it. If the node is not present add it to the graph and return the new node.
 - 
addInterproceduralEdgepublic void addInterproceduralEdge(Call call) Adds a call node between two methods.
 - 
addUnknownTargetInterproceduralEdgepublic void addUnknownTargetInterproceduralEdge(Call call) Adds a call node between two methods. This is used when the target method has noCodeAttribute, which means the target method is not present in the CFA. The unknown node is set as the call target.
 - 
clearpublic void clear() Removes references to this CFA nodes from the singletonJvmUnknownCfaNodeand clears its node collections making it garbage collectable.
 
- 
 
-