summaryrefslogtreecommitdiff
path: root/include/llvm/iMemory.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-04-29 18:46:22 +0000
committerChris Lattner <sabre@nondot.org>2002-04-29 18:46:22 +0000
commitee9c7d528d96207153e88dac58125f11cf71702c (patch)
treea8adfbdc9316f8103e2c13a7b1eced2c769394bc /include/llvm/iMemory.h
parent924025e9ad431f87a24b8f4bad32543a77acca87 (diff)
downloadllvm-ee9c7d528d96207153e88dac58125f11cf71702c.tar.gz
llvm-ee9c7d528d96207153e88dac58125f11cf71702c.tar.bz2
llvm-ee9c7d528d96207153e88dac58125f11cf71702c.tar.xz
Change to allow iMemory.h to avoid including DerivedTypes.h
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2403 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/iMemory.h')
-rw-r--r--include/llvm/iMemory.h30
1 files changed, 11 insertions, 19 deletions
diff --git a/include/llvm/iMemory.h b/include/llvm/iMemory.h
index b14023625c..8a88c32181 100644
--- a/include/llvm/iMemory.h
+++ b/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<const PointerType>(Instruction::getType());
+ return (PointerType*)Instruction::getType();
}
// Methods for support type inquiry through isa, cast, and dyn_cast: