diff options
-rw-r--r-- | include/llvm/Constants.h | 2 | ||||
-rw-r--r-- | lib/VMCore/Constants.cpp | 15 |
2 files changed, 15 insertions, 2 deletions
diff --git a/include/llvm/Constants.h b/include/llvm/Constants.h index c4768f8423..4ca22984b6 100644 --- a/include/llvm/Constants.h +++ b/include/llvm/Constants.h @@ -425,6 +425,8 @@ public: const std::vector<Constant*> &V, bool Packed); static Constant *get(LLVMContext &Context, Constant *const *Vals, unsigned NumVals, bool Packed); + static Constant *get(LLVMContext &Context, bool Packed, + Constant * Val, ...) END_WITH_NULL; /// Transparently provide more efficient getOperand methods. DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Constant); diff --git a/lib/VMCore/Constants.cpp b/lib/VMCore/Constants.cpp index 246fde1569..5468a4f1b4 100644 --- a/lib/VMCore/Constants.cpp +++ b/lib/VMCore/Constants.cpp @@ -33,6 +33,7 @@ #include "llvm/ADT/SmallVector.h" #include <algorithm> #include <map> +#include <cstdarg> using namespace llvm; //===----------------------------------------------------------------------===// @@ -596,8 +597,6 @@ Constant *ConstantArray::get(LLVMContext &Context, StringRef Str, return get(ATy, ElementVals); } - - ConstantStruct::ConstantStruct(const StructType *T, const std::vector<Constant*> &V) : Constant(T, ConstantStructVal, @@ -644,6 +643,18 @@ Constant *ConstantStruct::get(LLVMContext &Context, return get(Context, std::vector<Constant*>(Vals, Vals+NumVals), Packed); } +Constant* ConstantStruct::get(LLVMContext &Context, bool Packed, + Constant * Val, ...) { + va_list ap; + std::vector<Constant*> Values; + va_start(ap, Val); + while (Val) { + Values.push_back(Val); + Val = va_arg(ap, llvm::Constant*); + } + return get(Context, Values, Packed); +} + ConstantVector::ConstantVector(const VectorType *T, const std::vector<Constant*> &V) : Constant(T, ConstantVectorVal, |