From df159af353b284c3143ceade424a06663082799d Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 29 Apr 2002 18:46:22 +0000 Subject: [PATCH] Change to allow iMemory.h to avoid including DerivedTypes.h llvm-svn: 2403 --- llvm/include/llvm/iMemory.h | 30 +++++++++++------------------- 1 file changed, 11 insertions(+), 19 deletions(-) diff --git a/llvm/include/llvm/iMemory.h b/llvm/include/llvm/iMemory.h index b14023625ca3..8a88c321810c 100644 --- a/llvm/include/llvm/iMemory.h +++ b/llvm/include/llvm/iMemory.h @@ -9,7 +9,7 @@ #define LLVM_IMEMORY_H #include "llvm/Instruction.h" -#include "llvm/DerivedTypes.h" +class PointerType; //===----------------------------------------------------------------------===// // AllocationInst Class @@ -42,9 +42,8 @@ public: // getAllocatedType - Return the type that is being allocated by the // instruction. - inline const Type *getAllocatedType() const { - return getType()->getElementType(); - } + // + const Type *getAllocatedType() const; virtual Instruction *clone() const = 0; @@ -64,13 +63,12 @@ public: // MallocInst Class //===----------------------------------------------------------------------===// -class MallocInst : public AllocationInst { -public: +struct MallocInst : public AllocationInst { MallocInst(const Type *Ty, Value *ArraySize = 0, const std::string &Name = "") : AllocationInst(Ty, ArraySize, Malloc, Name) {} virtual Instruction *clone() const { - return new MallocInst(getType(), (Value*)Operands[0].get()); + return new MallocInst((Type*)getType(), (Value*)Operands[0].get()); } virtual const char *getOpcodeName() const { return "malloc"; } @@ -90,13 +88,12 @@ public: // AllocaInst Class //===----------------------------------------------------------------------===// -class AllocaInst : public AllocationInst { -public: +struct AllocaInst : public AllocationInst { AllocaInst(const Type *Ty, Value *ArraySize = 0, const std::string &Name = "") : AllocationInst(Ty, ArraySize, Alloca, Name) {} virtual Instruction *clone() const { - return new AllocaInst(getType(), (Value*)Operands[0].get()); + return new AllocaInst((Type*)getType(), (Value*)Operands[0].get()); } virtual const char *getOpcodeName() const { return "alloca"; } @@ -116,13 +113,8 @@ public: // FreeInst Class //===----------------------------------------------------------------------===// -class FreeInst : public Instruction { -public: - FreeInst(Value *Ptr) : Instruction(Type::VoidTy, Free, "") { - assert(Ptr->getType()->isPointerType() && "Can't free nonpointer!"); - Operands.reserve(1); - Operands.push_back(Use(Ptr, this)); - } +struct FreeInst : public Instruction { + FreeInst(Value *Ptr); virtual Instruction *clone() const { return new FreeInst(Operands[0]); } @@ -270,7 +262,7 @@ public: class GetElementPtrInst : public MemAccessInst { GetElementPtrInst(const GetElementPtrInst &EPI) - : MemAccessInst(EPI.getType(), GetElementPtr) { + : MemAccessInst((Type*)EPI.getType(), GetElementPtr) { Operands.reserve(EPI.Operands.size()); for (unsigned i = 0, E = EPI.Operands.size(); i != E; ++i) Operands.push_back(Use(EPI.Operands[i], this)); @@ -284,7 +276,7 @@ public: // getType - Overload to return most specific pointer type... inline const PointerType *getType() const { - return cast(Instruction::getType()); + return (PointerType*)Instruction::getType(); } // Methods for support type inquiry through isa, cast, and dyn_cast: