diff options
| author | Ted Kremenek <kremenek@apple.com> | 2011-11-11 15:19:48 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2011-11-11 15:19:48 +0000 |
| commit | 70394cf76ce4d092217cef6bb92632b7ded2c484 (patch) | |
| tree | 702e89555475f9c73957f2ab2dfdb017e0e9bcd3 /clang/tools/libclang | |
| parent | 089cc5323220c2d94c9dce918b8ef2f35d3fe6cf (diff) | |
| download | bcm5719-llvm-70394cf76ce4d092217cef6bb92632b7ded2c484.tar.gz bcm5719-llvm-70394cf76ce4d092217cef6bb92632b7ded2c484.zip | |
Tweak CXLoadedDiagnosticSetImpl::makeString() to include an extra null character, and change the creation of the FixIT's string to again just rely on this string (instead of duplicating it when calling createCXString).
llvm-svn: 144389
Diffstat (limited to 'clang/tools/libclang')
| -rw-r--r-- | clang/tools/libclang/CXLoadedDiagnostic.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/clang/tools/libclang/CXLoadedDiagnostic.cpp b/clang/tools/libclang/CXLoadedDiagnostic.cpp index 607f3bb362e..510f617c589 100644 --- a/clang/tools/libclang/CXLoadedDiagnostic.cpp +++ b/clang/tools/libclang/CXLoadedDiagnostic.cpp @@ -55,8 +55,11 @@ public: llvm::StringRef CXLoadedDiagnosticSetImpl::makeString(const char *blob, unsigned bloblen) { - char *mem = Alloc.Allocate<char>(bloblen); + char *mem = Alloc.Allocate<char>(bloblen + 1); memcpy(mem, blob, bloblen); + // Add a null terminator for those clients accessing the buffer + // like a c-string. + mem[bloblen] = '\0'; return llvm::StringRef(mem, bloblen); } @@ -100,7 +103,7 @@ CXSourceLocation CXLoadedDiagnostic::getLocation() const { } CXString CXLoadedDiagnostic::getSpelling() const { - return cxstring::createCXString(Spelling, false); + return cxstring::createCXString(Spelling, false); } CXString CXLoadedDiagnostic::getDiagnosticOption(CXString *Disable) const { @@ -242,7 +245,7 @@ public: if (errorString) *errorString = createCXString(""); } - + CXDiagnosticSet load(const char *file); }; } @@ -626,8 +629,8 @@ LoadResult DiagLoader::readDiagnosticBlock(llvm::BitstreamCursor &Stream, llvm::StringRef RetStr; if (readString(TopDiags, RetStr, "FIXIT", Record, BlobStart, BlobLen)) return Failure; - D->FixIts.push_back(std::make_pair(SR, createCXString(RetStr))); - continue; + D->FixIts.push_back(std::make_pair(SR, createCXString(RetStr, false))); + continue; } case serialized_diags::RECORD_DIAG: { |

