From 26dc86a8bd71b8c113eb9c472370e3856e7abc06 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 4 Aug 2004 02:43:00 +0000 Subject: Now that ConstantPointerRef is gone, it is the case that all operands of constants are themselves constants. This should allow us to reduce a significant amount of casting in the sourcebase. llvm-svn: 15459 --- llvm/include/llvm/Constant.h | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'llvm') diff --git a/llvm/include/llvm/Constant.h b/llvm/include/llvm/Constant.h index fda1005..c765503 100644 --- a/llvm/include/llvm/Constant.h +++ b/llvm/include/llvm/Constant.h @@ -40,6 +40,18 @@ public: virtual void print(std::ostream &O) const; + // Specialize get/setOperand for Constant's as their operands are always + // constants as well. + Constant *getOperand(unsigned i) { + return static_cast(User::getOperand(i)); + } + const Constant *getOperand(unsigned i) const { + return static_cast(User::getOperand(i)); + } + void setOperand(unsigned i, Constant *C) { + User::setOperand(i, C); + } + /// destroyConstant - Called if some element of this constant is no longer /// valid. At this point only other constants may be on the use_list for this /// constant. Any constants on our Use list must also be destroy'd. The -- cgit v1.1