[llvm-commits] CVS: llvm/include/llvm/GlobalValue.h

LLVM llvm at cs.uiuc.edu
Sat Jul 17 16:28:38 PDT 2004


Changes in directory llvm/include/llvm:

GlobalValue.h updated: 1.15 -> 1.16

---
Log message:

bug 122: http://llvm.cs.uiuc.edu/PR122 :
- derive from Constant
- declare needed overrides from Constant class


---
Diffs of the changes:  (+18 -4)

Index: llvm/include/llvm/GlobalValue.h
diff -u llvm/include/llvm/GlobalValue.h:1.15 llvm/include/llvm/GlobalValue.h:1.16
--- llvm/include/llvm/GlobalValue.h:1.15	Sun Jul 11 20:17:52 2004
+++ llvm/include/llvm/GlobalValue.h	Sat Jul 17 18:28:28 2004
@@ -17,14 +17,14 @@
 #ifndef LLVM_GLOBALVALUE_H
 #define LLVM_GLOBALVALUE_H
 
-#include "llvm/User.h"
+#include "llvm/Constant.h"
 
 namespace llvm {
 
 class PointerType;
 class Module;
 
-class GlobalValue : public User {
+class GlobalValue : public Constant {
   GlobalValue(const GlobalValue &);             // do not implement
 public:
   enum LinkageTypes {
@@ -37,12 +37,19 @@
 protected:
   GlobalValue(const Type *Ty, ValueTy vty, LinkageTypes linkage,
 	      const std::string &name = "")
-    : User(Ty, vty, name), Linkage(linkage), Parent(0) {}
+    : Constant(Ty, vty, name), Linkage(linkage), Parent(0) { }
 
   LinkageTypes Linkage;   // The linkage of this global
   Module *Parent;
 public:
-  ~GlobalValue() {}
+  virtual ~GlobalValue();
+
+  /// If the usage is empty (except transitively dead constants), then this
+  /// global value can can be safely deleted since the destructor wll 
+  /// delete the dead constants as well.
+  /// @brief Determine if theusage of this global value is empty except 
+  /// for transitively dead constants.
+  bool use_empty_except_constants();
 
   /// getType - Global values are always pointers.
   inline const PointerType *getType() const {
@@ -56,6 +63,13 @@
   bool hasInternalLinkage()  const { return Linkage == InternalLinkage; }
   void setLinkage(LinkageTypes LT) { Linkage = LT; }
   LinkageTypes getLinkage() const { return Linkage; }
+
+  /// Override from Constant class. No GlobalValue's have null values so
+  /// this always returns false.
+  virtual bool isNullValue() const { return false; }
+
+  /// Override from Constant class.
+  virtual void destroyConstant();
 
   /// isExternal - Return true if the primary definition of this global value is
   /// outside of the current translation unit...





More information about the llvm-commits mailing list