From eaceeb61fba5642289f28b54b1395027e9d05777 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 10 Feb 2007 19:33:15 +0000 Subject: [PATCH] Change TargetData::getIndexedOffset interface to not require indices in a vector. llvm-svn: 34153 --- include/llvm/Target/TargetData.h | 7 ++++++- lib/Target/TargetData.cpp | 16 ++++++++-------- 2 files changed, 14 insertions(+), 9 deletions(-) diff --git a/include/llvm/Target/TargetData.h b/include/llvm/Target/TargetData.h index e462814def2..d577de7c8a0 100644 --- a/include/llvm/Target/TargetData.h +++ b/include/llvm/Target/TargetData.h @@ -247,7 +247,12 @@ public: /// specified indices. This is used to implement getelementptr. /// uint64_t getIndexedOffset(const Type *Ty, - const std::vector &Indices) const; + Value* const* Indices, unsigned NumIndices) const; + + uint64_t getIndexedOffset(const Type *Ty, + const std::vector &Indices) const { + return getIndexedOffset(Ty, &Indices[0], Indices.size()); + } /// getStructLayout - Return a StructLayout object, indicating the alignment /// of the struct, its size, and the offsets of its fields. Note that this diff --git a/lib/Target/TargetData.cpp b/lib/Target/TargetData.cpp index aa32530d4b5..139ab002417 100644 --- a/lib/Target/TargetData.cpp +++ b/lib/Target/TargetData.cpp @@ -452,18 +452,18 @@ const Type *TargetData::getIntPtrType() const { } -uint64_t TargetData::getIndexedOffset(const Type *ptrTy, - const std::vector &Idx) const { +uint64_t TargetData::getIndexedOffset(const Type *ptrTy, Value* const* Indices, + unsigned NumIndices) const { const Type *Ty = ptrTy; assert(isa(Ty) && "Illegal argument for getIndexedOffset()"); uint64_t Result = 0; - generic_gep_type_iterator::const_iterator> - TI = gep_type_begin(ptrTy, Idx.begin(), Idx.end()); - for (unsigned CurIDX = 0; CurIDX != Idx.size(); ++CurIDX, ++TI) { + generic_gep_type_iterator + TI = gep_type_begin(ptrTy, Indices, Indices+NumIndices); + for (unsigned CurIDX = 0; CurIDX != NumIndices; ++CurIDX, ++TI) { if (const StructType *STy = dyn_cast(*TI)) { - assert(Idx[CurIDX]->getType() == Type::Int32Ty && "Illegal struct idx"); - unsigned FieldNo = cast(Idx[CurIDX])->getZExtValue(); + assert(Indices[CurIDX]->getType() == Type::Int32Ty &&"Illegal struct idx"); + unsigned FieldNo = cast(Indices[CurIDX])->getZExtValue(); // Get structure layout information... const StructLayout *Layout = getStructLayout(STy); @@ -479,7 +479,7 @@ uint64_t TargetData::getIndexedOffset(const Type *ptrTy, Ty = cast(Ty)->getElementType(); // Get the array index and the size of each array element. - int64_t arrayIdx = cast(Idx[CurIDX])->getSExtValue(); + int64_t arrayIdx = cast(Indices[CurIDX])->getSExtValue(); Result += arrayIdx * (int64_t)getTypeSize(Ty); } }