diff options
author | Vedant Kumar <vsk@apple.com> | 2016-09-23 18:57:32 +0000 |
---|---|---|
committer | Vedant Kumar <vsk@apple.com> | 2016-09-23 18:57:32 +0000 |
commit | bc6479850e1d4a4522c6d195f93704d3e78e54e3 (patch) | |
tree | a62afdc088765fcce12312bec7d6ff6d785b044a /llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp | |
parent | 224ef8d73bb49c765ac8d7a352b244ec7c24807e (diff) | |
download | llvm-bc6479850e1d4a4522c6d195f93704d3e78e54e3.zip llvm-bc6479850e1d4a4522c6d195f93704d3e78e54e3.tar.gz llvm-bc6479850e1d4a4522c6d195f93704d3e78e54e3.tar.bz2 |
[llvm-cov] Get rid of all invalid filename references
We used to append filenames into a vector of std::string, and then
append a reference to each string into a separate vector. This made it
easier to work with the getUniqueSourceFiles API. But it's buggy.
std::string has a small-string optimization, so you can't expect to
capture a reference to one if you're copying it into a growing vector.
Add a test that triggers this invalid reference to std::string scenario,
and kill the issue with fire by just using ArrayRef<std::string>
everywhere.
llvm-svn: 282281
Diffstat (limited to 'llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp')
-rw-r--r-- | llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp b/llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp index 1cb283c..2707260 100644 --- a/llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp +++ b/llvm/tools/llvm-cov/SourceCoverageViewHTML.cpp @@ -347,7 +347,7 @@ void CoveragePrinterHTML::emitFileSummary(raw_ostream &OS, StringRef SF, } Error CoveragePrinterHTML::createIndexFile( - ArrayRef<StringRef> SourceFiles, + ArrayRef<std::string> SourceFiles, const coverage::CoverageMapping &Coverage) { // Emit the default stylesheet. auto CSSOrErr = createOutputStream("style", "css", /*InToplevel=*/true); |