[llvm-commits] CVS: llvm/include/llvm/Analysis/DSNode.h
Chris Lattner
lattner at cs.uiuc.edu
Tue Jan 27 15:51:03 PST 2004
Changes in directory llvm/include/llvm/Analysis:
DSNode.h updated: 1.34 -> 1.35
---
Log message:
Add comments, allow DSNode "copy ctor" to ignore outgoing links, add more
structured access to the globals list, add a couple helper methods.
---
Diffs of the changes: (+20 -3)
Index: llvm/include/llvm/Analysis/DSNode.h
diff -u llvm/include/llvm/Analysis/DSNode.h:1.34 llvm/include/llvm/Analysis/DSNode.h:1.35
--- llvm/include/llvm/Analysis/DSNode.h:1.34 Thu Jan 22 10:08:51 2004
+++ llvm/include/llvm/Analysis/DSNode.h Tue Jan 27 15:49:25 2004
@@ -97,9 +97,16 @@
private:
unsigned short NodeType;
public:
-
+
+ /// DSNode ctor - Create a node of the specified type, inserting it into the
+ /// specified graph.
DSNode(const Type *T, DSGraph *G);
- DSNode(const DSNode &, DSGraph *G);
+
+ /// DSNode "copy ctor" - Copy the specified node, inserting it into the
+ /// specified graph. If NullLinks is true, then null out all of the links,
+ /// but keep the same number of them. This can be used for efficiency if the
+ /// links are just going to be clobbered anyway.
+ DSNode(const DSNode &, DSGraph *G, bool NullLinks = false);
~DSNode() {
dropAllReferences();
@@ -241,14 +248,24 @@
/// also marks the node with the 'G' flag if it does not already have it.
///
void addGlobal(GlobalValue *GV);
+ void mergeGlobals(const std::vector<GlobalValue*> &RHS);
const std::vector<GlobalValue*> &getGlobals() const { return Globals; }
+ typedef std::vector<GlobalValue*>::const_iterator global_iterator;
+ global_iterator global_begin() const { return Globals.begin(); }
+ global_iterator global_end() const { return Globals.end(); }
+
+
/// maskNodeTypes - Apply a mask to the node types bitfield.
///
void maskNodeTypes(unsigned Mask) {
NodeType &= Mask;
}
+ void mergeNodeFlags(unsigned RHS) {
+ NodeType |= RHS;
+ }
+
/// getNodeFlags - Return all of the flags set on the node. If the DEAD flag
/// is set, hide it from the caller.
unsigned getNodeFlags() const { return NodeType & ~DEAD; }
@@ -320,7 +337,7 @@
inline DSNode *DSNodeHandle::getNode() const {
assert((!N || Offset < N->Size || (N->Size == 0 && Offset == 0) ||
!N->ForwardNH.isNull()) && "Node handle offset out of range!");
- if (!N || N->ForwardNH.isNull())
+ if (N == 0 || N->ForwardNH.isNull())
return N;
return HandleForwarding();
More information about the llvm-commits
mailing list