mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
add a new CallGraphNode::removeCallEdgeFor method, tidy some comments.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49617 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f99b286154
commit
75caee2419
@ -103,13 +103,13 @@ public:
|
|||||||
return I->second;
|
return I->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Returns the CallGraphNode which is used to represent undetermined calls
|
/// Returns the CallGraphNode which is used to represent undetermined calls
|
||||||
// into the callgraph. Override this if you want behavioural inheritance.
|
/// into the callgraph. Override this if you want behavioral inheritance.
|
||||||
virtual CallGraphNode* getExternalCallingNode() const { return 0; }
|
virtual CallGraphNode* getExternalCallingNode() const { return 0; }
|
||||||
|
|
||||||
//Return the root/main method in the module, or some other root node, such
|
/// Return the root/main method in the module, or some other root node, such
|
||||||
// as the externalcallingnode. Overload these if you behavioural
|
/// as the externalcallingnode. Overload these if you behavioral
|
||||||
// inheritance.
|
/// inheritance.
|
||||||
virtual CallGraphNode* getRoot() { return 0; }
|
virtual CallGraphNode* getRoot() { return 0; }
|
||||||
virtual const CallGraphNode* getRoot() const { return 0; }
|
virtual const CallGraphNode* getRoot() const { return 0; }
|
||||||
|
|
||||||
@ -227,6 +227,11 @@ public:
|
|||||||
/// used sparingly.
|
/// used sparingly.
|
||||||
void removeCallEdgeTo(CallGraphNode *Callee);
|
void removeCallEdgeTo(CallGraphNode *Callee);
|
||||||
|
|
||||||
|
/// removeCallEdgeFor - This method removes the edge in the node for the
|
||||||
|
/// specified call site. Note that this method takes linear time, so it
|
||||||
|
/// should be used sparingly.
|
||||||
|
void removeCallEdgeFor(CallSite CS);
|
||||||
|
|
||||||
/// removeAnyCallEdgeTo - This method removes any call edges from this node to
|
/// removeAnyCallEdgeTo - This method removes any call edges from this node to
|
||||||
/// the specified callee function. This takes more time to execute than
|
/// the specified callee function. This takes more time to execute than
|
||||||
/// removeCallEdgeTo, so it should not be used unless necessary.
|
/// removeCallEdgeTo, so it should not be used unless necessary.
|
||||||
|
@ -293,6 +293,20 @@ void CallGraphNode::removeCallEdgeTo(CallGraphNode *Callee) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// removeCallEdgeFor - This method removes the edge in the node for the
|
||||||
|
/// specified call site. Note that this method takes linear time, so it
|
||||||
|
/// should be used sparingly.
|
||||||
|
void CallGraphNode::removeCallEdgeFor(CallSite CS) {
|
||||||
|
for (unsigned i = CalledFunctions.size(); ; --i) {
|
||||||
|
assert(i && "Cannot find callee to remove!");
|
||||||
|
if (CalledFunctions[i-1].first == CS) {
|
||||||
|
CalledFunctions.erase(CalledFunctions.begin()+i-1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// removeAnyCallEdgeTo - This method removes any call edges from this node to
|
// removeAnyCallEdgeTo - This method removes any call edges from this node to
|
||||||
// the specified callee function. This takes more time to execute than
|
// the specified callee function. This takes more time to execute than
|
||||||
// removeCallEdgeTo, so it should not be used unless necessary.
|
// removeCallEdgeTo, so it should not be used unless necessary.
|
||||||
|
Loading…
Reference in New Issue
Block a user