From: Mehdi Amini Date: Wed, 9 Sep 2015 20:08:39 +0000 (+0000) Subject: Bitcode Writer: EmitRecordWith* takes an ArrayRef instead of a SmallVector (NFC) X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=9e472a180010a8801e6379f542c2ee2a96894945;p=oota-llvm.git Bitcode Writer: EmitRecordWith* takes an ArrayRef instead of a SmallVector (NFC) From: Mehdi Amini git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@247178 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/Bitcode/BitstreamWriter.h b/include/llvm/Bitcode/BitstreamWriter.h index 9f23023a141..076ebd63d6c 100644 --- a/include/llvm/Bitcode/BitstreamWriter.h +++ b/include/llvm/Bitcode/BitstreamWriter.h @@ -15,6 +15,7 @@ #ifndef LLVM_BITCODE_BITSTREAMWRITER_H #define LLVM_BITCODE_BITSTREAMWRITER_H +#include "llvm/ADT/ArrayRef.h" #include "llvm/ADT/SmallVector.h" #include "llvm/ADT/StringRef.h" #include "llvm/Bitcode/BitCodes.h" @@ -286,8 +287,8 @@ private: /// emission code. If BlobData is non-null, then it specifies an array of /// data that should be emitted as part of the Blob or Array operand that is /// known to exist at the end of the record. - template - void EmitRecordWithAbbrevImpl(unsigned Abbrev, SmallVectorImpl &Vals, + template + void EmitRecordWithAbbrevImpl(unsigned Abbrev, const ArrayRef &Vals, StringRef Blob) { const char *BlobData = Blob.data(); unsigned BlobLen = (unsigned) Blob.size(); @@ -398,14 +399,14 @@ public: // Insert the code into Vals to treat it uniformly. Vals.insert(Vals.begin(), Code); - EmitRecordWithAbbrev(Abbrev, Vals); + EmitRecordWithAbbrev(Abbrev, makeArrayRef(Vals)); } /// EmitRecordWithAbbrev - Emit a record with the specified abbreviation. /// Unlike EmitRecord, the code for the record should be included in Vals as /// the first entry. - template - void EmitRecordWithAbbrev(unsigned Abbrev, SmallVectorImpl &Vals) { + template + void EmitRecordWithAbbrev(unsigned Abbrev, const ArrayRef &Vals) { EmitRecordWithAbbrevImpl(Abbrev, Vals, StringRef()); } @@ -414,27 +415,27 @@ public: /// specified by the pointer and length specified at the end. In contrast to /// EmitRecord, this routine expects that the first entry in Vals is the code /// of the record. - template - void EmitRecordWithBlob(unsigned Abbrev, SmallVectorImpl &Vals, + template + void EmitRecordWithBlob(unsigned Abbrev, const ArrayRef &Vals, StringRef Blob) { EmitRecordWithAbbrevImpl(Abbrev, Vals, Blob); } - template - void EmitRecordWithBlob(unsigned Abbrev, SmallVectorImpl &Vals, + template + void EmitRecordWithBlob(unsigned Abbrev, const ArrayRef &Vals, const char *BlobData, unsigned BlobLen) { return EmitRecordWithAbbrevImpl(Abbrev, Vals, StringRef(BlobData, BlobLen)); } /// EmitRecordWithArray - Just like EmitRecordWithBlob, works with records /// that end with an array. - template - void EmitRecordWithArray(unsigned Abbrev, SmallVectorImpl &Vals, - StringRef Array) { + template + void EmitRecordWithArray(unsigned Abbrev, const ArrayRef &Vals, + StringRef Array) { EmitRecordWithAbbrevImpl(Abbrev, Vals, Array); } - template - void EmitRecordWithArray(unsigned Abbrev, SmallVectorImpl &Vals, - const char *ArrayData, unsigned ArrayLen) { + template + void EmitRecordWithArray(unsigned Abbrev, const ArrayRef &Vals, + const char *ArrayData, unsigned ArrayLen) { return EmitRecordWithAbbrevImpl(Abbrev, Vals, StringRef(ArrayData, ArrayLen)); }