diff --git a/test/tools/llvm-cov/Inputs/showExpansions.covmapping b/test/tools/llvm-cov/Inputs/showExpansions.covmapping new file mode 100644 index 00000000000..dd73090ccd9 Binary files /dev/null and b/test/tools/llvm-cov/Inputs/showExpansions.covmapping differ diff --git a/test/tools/llvm-cov/Inputs/showExpansions.profdata b/test/tools/llvm-cov/Inputs/showExpansions.profdata new file mode 100644 index 00000000000..7925c602068 Binary files /dev/null and b/test/tools/llvm-cov/Inputs/showExpansions.profdata differ diff --git a/test/tools/llvm-cov/showExpansions.cpp b/test/tools/llvm-cov/showExpansions.cpp new file mode 100644 index 00000000000..db5786b9892 --- /dev/null +++ b/test/tools/llvm-cov/showExpansions.cpp @@ -0,0 +1,31 @@ +// RUN: llvm-cov show %S/Inputs/showExpansions.covmapping -instr-profile %S/Inputs/showExpansions.profdata -dump -show-expansions -filename-equivalence %s | FileCheck %s + +#define DO_SOMETHING_ELSE() \ + do { \ + } while (0) +#define ANOTHER_THING() \ + do { \ + if (0) { \ + } \ + } while (0) + +#define DO_SOMETHING(x) \ + do { \ + if (x) \ + DO_SOMETHING_ELSE(); \ + else \ + ANOTHER_THING(); \ + } while (0) + +int main(int argc, const char *argv[]) { + for (int i = 0; i < 100; ++i) + DO_SOMETHING(i); + return 0; +} + +// CHECK: Expansion of {{[0-9]+}}:13 -> 18 @ {{[0-9]+}}, 22:5 +// CHECK: Expansion of {{[0-9]+}}:4 -> 5 @ {{[0-9]+}}, 15:7 +// CHECK: Expansion of {{[0-9]+}}:7 -> 10 @ {{[0-9]+}}, 17:7 + +// llvm-cov doesn't work on big endian yet +// XFAIL: powerpc64-, s390x, mips-, mips64-, sparc diff --git a/tools/llvm-cov/SourceCoverageView.cpp b/tools/llvm-cov/SourceCoverageView.cpp index 5f873acba0d..159d74adf38 100644 --- a/tools/llvm-cov/SourceCoverageView.cpp +++ b/tools/llvm-cov/SourceCoverageView.cpp @@ -206,7 +206,7 @@ gatherLineSubViews(size_t &CurrentIdx, while (CurrentIdx < E && Items[CurrentIdx]->getSubViewsExpansionLine() == LineNo) ++CurrentIdx; - return Items.slice(PrevIdx, CurrentIdx); + return Items.slice(PrevIdx, CurrentIdx - PrevIdx); } void SourceCoverageView::render(raw_ostream &OS, unsigned Offset) {