Static Value-Flow Analysis
Loading...
Searching...
No Matches
Public Types | Protected Member Functions | Private Attributes | List of all members
SVF::GraphReachSolver< GraphType, DPIm > Class Template Reference

#include <GraphReachSolver.h>

Inheritance diagram for SVF::GraphReachSolver< GraphType, DPIm >:
SVF::SrcSnkDDA SVF::LeakChecker SVF::DoubleFreeChecker SVF::FileChecker

Public Types

typedef SVF::GenericGraphTraits< GraphType > GTraits
 Define the GTraits and node iterator.
 
typedef GTraits::NodeType GNODE
 
typedef GTraits::EdgeType GEDGE
 
typedef GTraits::nodes_iterator node_iterator
 
typedef GTraits::ChildIteratorType child_iterator
 
typedef SVF::GenericGraphTraits< SVF::Inverse< GNODE * > > InvGTraits
 Define inverse GTraits and note iterator.
 
typedef InvGTraits::ChildIteratorType inv_child_iterator
 
typedef FIFOWorkList< DPIm > WorkList
 Define worklist.
 

Protected Member Functions

 GraphReachSolver ()
 Constructor.
 
virtual ~GraphReachSolver ()
 Destructor.
 
const GraphType graph () const
 Get/Set graph methods.
 
void setGraph (GraphType g)
 
GNODEgetNode (NodeID id) const
 
virtual NodeID getNodeIDFromItem (const DPIm &item) const
 
virtual void forwardTraverse (DPIm &it)
 CFL forward traverse solve.
 
virtual void backwardTraverse (DPIm &it)
 CFL forward traverse solve.
 
virtual void FWProcessCurNode (const DPIm &)
 Process the DP item.
 
virtual void BWProcessCurNode (const DPIm &)
 
virtual void FWProcessOutgoingEdge (const DPIm &item, GEDGE *edge)
 Propagation for the solving, to be implemented in the child class.
 
virtual void BWProcessIncomingEdge (const DPIm &item, GEDGE *edge)
 
DPIm popFromWorklist ()
 Worklist operations.
 
bool pushIntoWorklist (DPIm &item)
 
bool isWorklistEmpty ()
 
bool isInWorklist (DPIm &item)
 

Private Attributes

GraphType _graph
 Graph.
 
WorkList worklist
 Worklist for resolution.
 

Detailed Description

template<class GraphType, class DPIm = DPItem>
class SVF::GraphReachSolver< GraphType, DPIm >

Definition at line 44 of file GraphReachSolver.h.

Member Typedef Documentation

◆ child_iterator

template<class GraphType , class DPIm = DPItem>
typedef GTraits::ChildIteratorType SVF::GraphReachSolver< GraphType, DPIm >::child_iterator

Definition at line 53 of file GraphReachSolver.h.

◆ GEDGE

template<class GraphType , class DPIm = DPItem>
typedef GTraits::EdgeType SVF::GraphReachSolver< GraphType, DPIm >::GEDGE

Definition at line 51 of file GraphReachSolver.h.

◆ GNODE

template<class GraphType , class DPIm = DPItem>
typedef GTraits::NodeType SVF::GraphReachSolver< GraphType, DPIm >::GNODE

Definition at line 50 of file GraphReachSolver.h.

◆ GTraits

template<class GraphType , class DPIm = DPItem>
typedef SVF::GenericGraphTraits<GraphType> SVF::GraphReachSolver< GraphType, DPIm >::GTraits

Define the GTraits and node iterator.

Definition at line 49 of file GraphReachSolver.h.

◆ inv_child_iterator

template<class GraphType , class DPIm = DPItem>
typedef InvGTraits::ChildIteratorType SVF::GraphReachSolver< GraphType, DPIm >::inv_child_iterator

Definition at line 57 of file GraphReachSolver.h.

◆ InvGTraits

template<class GraphType , class DPIm = DPItem>
typedef SVF::GenericGraphTraits<SVF::Inverse<GNODE *> > SVF::GraphReachSolver< GraphType, DPIm >::InvGTraits

Define inverse GTraits and note iterator.

Definition at line 56 of file GraphReachSolver.h.

◆ node_iterator

template<class GraphType , class DPIm = DPItem>
typedef GTraits::nodes_iterator SVF::GraphReachSolver< GraphType, DPIm >::node_iterator

Definition at line 52 of file GraphReachSolver.h.

◆ WorkList

template<class GraphType , class DPIm = DPItem>
typedef FIFOWorkList<DPIm> SVF::GraphReachSolver< GraphType, DPIm >::WorkList

Define worklist.

Definition at line 60 of file GraphReachSolver.h.

Constructor & Destructor Documentation

◆ GraphReachSolver()

template<class GraphType , class DPIm = DPItem>
SVF::GraphReachSolver< GraphType, DPIm >::GraphReachSolver ( )
inlineprotected

Constructor.

Definition at line 65 of file GraphReachSolver.h.

65 : _graph(nullptr)
66 {
67 }

◆ ~GraphReachSolver()

template<class GraphType , class DPIm = DPItem>
virtual SVF::GraphReachSolver< GraphType, DPIm >::~GraphReachSolver ( )
inlineprotectedvirtual

Destructor.

Definition at line 69 of file GraphReachSolver.h.

70 {
71 }

Member Function Documentation

◆ backwardTraverse()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::backwardTraverse ( DPIm &  it)
inlineprotectedvirtual

CFL forward traverse solve.

Definition at line 112 of file GraphReachSolver.h.

113 {
115
116 while (!isWorklistEmpty())
117 {
118 DPIm item = popFromWorklist();
120
122 inv_child_iterator EI = InvGTraits::child_begin(v);
123 inv_child_iterator EE = InvGTraits::child_end(v);
124 for (; EI != EE; ++EI)
125 {
126 BWProcessIncomingEdge(item,*(EI.getCurrent()) );
127 }
128 }
129 }
cJSON * item
Definition cJSON.h:222
DPIm popFromWorklist()
Worklist operations.
InvGTraits::ChildIteratorType inv_child_iterator
bool pushIntoWorklist(DPIm &item)
virtual void BWProcessCurNode(const DPIm &)
virtual NodeID getNodeIDFromItem(const DPIm &item) const
virtual void BWProcessIncomingEdge(const DPIm &item, GEDGE *edge)
GNODE * getNode(NodeID id) const
GTraits::NodeType GNODE
llvm::IRBuilder IRBuilder
Definition BasicTypes.h:74

◆ BWProcessCurNode()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::BWProcessCurNode ( const DPIm &  )
inlineprotectedvirtual

Definition at line 135 of file GraphReachSolver.h.

136 {
137 }

◆ BWProcessIncomingEdge()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::BWProcessIncomingEdge ( const DPIm &  item,
GEDGE edge 
)
inlineprotectedvirtual

Definition at line 147 of file GraphReachSolver.h.

148 {
149 DPIm newItem(item);
150 newItem.setCurNodeID(edge->getSrcID());
152 }

◆ forwardTraverse()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::forwardTraverse ( DPIm &  it)
inlineprotectedvirtual

CFL forward traverse solve.

Definition at line 93 of file GraphReachSolver.h.

94 {
96
97 while (!isWorklistEmpty())
98 {
99 DPIm item = popFromWorklist();
101
103 child_iterator EI = GTraits::child_begin(v);
104 child_iterator EE = GTraits::child_end(v);
105 for (; EI != EE; ++EI)
106 {
107 FWProcessOutgoingEdge(item,*(EI.getCurrent()) );
108 }
109 }
110 }
virtual void FWProcessOutgoingEdge(const DPIm &item, GEDGE *edge)
Propagation for the solving, to be implemented in the child class.
virtual void FWProcessCurNode(const DPIm &)
Process the DP item.
GTraits::ChildIteratorType child_iterator

◆ FWProcessCurNode()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::FWProcessCurNode ( const DPIm &  )
inlineprotectedvirtual

Process the DP item.

Definition at line 132 of file GraphReachSolver.h.

133 {
134 }

◆ FWProcessOutgoingEdge()

template<class GraphType , class DPIm = DPItem>
virtual void SVF::GraphReachSolver< GraphType, DPIm >::FWProcessOutgoingEdge ( const DPIm &  item,
GEDGE edge 
)
inlineprotectedvirtual

Propagation for the solving, to be implemented in the child class.

Definition at line 141 of file GraphReachSolver.h.

142 {
143 DPIm newItem(item);
144 newItem.setCurNodeID(edge->getDstID());
146 }

◆ getNode()

template<class GraphType , class DPIm = DPItem>
GNODE * SVF::GraphReachSolver< GraphType, DPIm >::getNode ( NodeID  id) const
inlineprotected

Definition at line 84 of file GraphReachSolver.h.

85 {
86 return _graph->getGNode(id);
87 }

◆ getNodeIDFromItem()

template<class GraphType , class DPIm = DPItem>
virtual NodeID SVF::GraphReachSolver< GraphType, DPIm >::getNodeIDFromItem ( const DPIm &  item) const
inlineprotectedvirtual

Definition at line 88 of file GraphReachSolver.h.

89 {
90 return item.getCurNodeID();
91 }

◆ graph()

template<class GraphType , class DPIm = DPItem>
const GraphType SVF::GraphReachSolver< GraphType, DPIm >::graph ( ) const
inlineprotected

Get/Set graph methods.

Definition at line 74 of file GraphReachSolver.h.

75 {
76 return _graph;
77 }

◆ isInWorklist()

template<class GraphType , class DPIm = DPItem>
bool SVF::GraphReachSolver< GraphType, DPIm >::isInWorklist ( DPIm &  item)
inlineprotected

Definition at line 168 of file GraphReachSolver.h.

169 {
170 return worklist.find(item);
171 }
WorkList worklist
Worklist for resolution.

◆ isWorklistEmpty()

template<class GraphType , class DPIm = DPItem>
bool SVF::GraphReachSolver< GraphType, DPIm >::isWorklistEmpty ( )
inlineprotected

Definition at line 164 of file GraphReachSolver.h.

165 {
166 return worklist.empty();
167 }

◆ popFromWorklist()

template<class GraphType , class DPIm = DPItem>
DPIm SVF::GraphReachSolver< GraphType, DPIm >::popFromWorklist ( )
inlineprotected

Worklist operations.

Definition at line 156 of file GraphReachSolver.h.

157 {
158 return worklist.pop();
159 }

◆ pushIntoWorklist()

template<class GraphType , class DPIm = DPItem>
bool SVF::GraphReachSolver< GraphType, DPIm >::pushIntoWorklist ( DPIm &  item)
inlineprotected

Definition at line 160 of file GraphReachSolver.h.

161 {
162 return worklist.push(item);
163 }

◆ setGraph()

template<class GraphType , class DPIm = DPItem>
void SVF::GraphReachSolver< GraphType, DPIm >::setGraph ( GraphType  g)
inlineprotected

Definition at line 78 of file GraphReachSolver.h.

79 {
80 _graph = g;
81 }

Member Data Documentation

◆ _graph

template<class GraphType , class DPIm = DPItem>
GraphType SVF::GraphReachSolver< GraphType, DPIm >::_graph
private

Graph.

Definition at line 177 of file GraphReachSolver.h.

◆ worklist

template<class GraphType , class DPIm = DPItem>
WorkList SVF::GraphReachSolver< GraphType, DPIm >::worklist
private

Worklist for resolution.

Definition at line 180 of file GraphReachSolver.h.


The documentation for this class was generated from the following file: