From: Chris Lattner Date: Wed, 19 Mar 2008 05:06:05 +0000 (+0000) Subject: add some convenience methods for creating GEP instructions and X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=d8ff3caaa0d5dd4a7cbbe25c42d70af2e3caca7f;p=oota-llvm.git add some convenience methods for creating GEP instructions and struct types. Patch by David Chisnall, with some tweaks. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48531 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/DerivedTypes.h b/include/llvm/DerivedTypes.h index 457d37d1fa8..7fc7ed6a91c 100644 --- a/include/llvm/DerivedTypes.h +++ b/include/llvm/DerivedTypes.h @@ -220,6 +220,11 @@ public: static StructType *get(const std::vector &Params, bool isPacked=false); + /// StructType::get - This static method is a convenience method for + /// creating structure types by specifying the elements as arguments. Note + /// that this method always returns a non-packed struct. + static StructType *get(const Type *type, ...) END_WITH_NULL; + // Iterator access to the elements typedef Type::subtype_iterator element_iterator; element_iterator element_begin() const { return ContainedTys; } diff --git a/include/llvm/Support/LLVMBuilder.h b/include/llvm/Support/LLVMBuilder.h index 1757404ab4f..ef1817d3c16 100644 --- a/include/llvm/Support/LLVMBuilder.h +++ b/include/llvm/Support/LLVMBuilder.h @@ -226,6 +226,14 @@ public: GetElementPtrInst *CreateGEP(Value *Ptr, Value *Idx, const char *Name = "") { return Insert(new GetElementPtrInst(Ptr, Idx, Name)); } + GetElementPtrInst *CreateStructGEP(Value *Ptr, unsigned Idx, + const char *Name = "") { + llvm::Value *Idxs[] = { + ConstantInt::get(llvm::Type::Int32Ty, 0), + ConstantInt::get(llvm::Type::Int32Ty, Idx) + }; + return Insert(new GetElementPtrInst(Ptr, Idxs, Idxs+2, Name)); + } //===--------------------------------------------------------------------===// // Instruction creation methods: Cast/Conversion Operators diff --git a/lib/VMCore/Type.cpp b/lib/VMCore/Type.cpp index 6b884445ee8..4554826c34b 100644 --- a/lib/VMCore/Type.cpp +++ b/lib/VMCore/Type.cpp @@ -22,6 +22,7 @@ #include "llvm/Support/ManagedStatic.h" #include "llvm/Support/Debug.h" #include +#include using namespace llvm; // DEBUG_MERGE_TYPES - Enable this #define to see how and when derived types are @@ -1247,6 +1248,16 @@ StructType *StructType::get(const std::vector &ETypes, return ST; } +StructType *StructType::get(const Type *type, ...) { + va_list ap; + std::vector StructFields; + va_start(ap, type); + do { + StructFields.push_back(type); + } while ((type = va_arg(ap, llvm::Type*))); + return llvm::StructType::get(StructFields); +} + //===----------------------------------------------------------------------===//