]> granicus.if.org Git - llvm/commitdiff
Revert "llvm-cov: Remove an overly system specific test"
authorJustin Bogner <mail@justinbogner.com>
Thu, 11 Sep 2014 23:20:48 +0000 (23:20 +0000)
committerJustin Bogner <mail@justinbogner.com>
Thu, 11 Sep 2014 23:20:48 +0000 (23:20 +0000)
This fixes a call to sys::fs::equivalent that should've been to
CodeCoverageTool::equivalentFiles, which lets us restore the test of
r217476 that was removed in r217478.

This reverts r217478, but the test works this time.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@217646 91177308-0d34-0410-b5e6-96231b3b80d8

test/tools/llvm-cov/Inputs/showExpansions.covmapping
test/tools/llvm-cov/showExpansions.cpp [new file with mode: 0644]
tools/llvm-cov/CodeCoverage.cpp

index dd73090ccd9639b379dbf19ba1bf6e0ab6929c43..67337675cf43601873952ab7d04c3316ec43d6e3 100644 (file)
Binary files a/test/tools/llvm-cov/Inputs/showExpansions.covmapping and b/test/tools/llvm-cov/Inputs/showExpansions.covmapping differ
diff --git a/test/tools/llvm-cov/showExpansions.cpp b/test/tools/llvm-cov/showExpansions.cpp
new file mode 100644 (file)
index 0000000..db5786b
--- /dev/null
@@ -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
index 549af92f918dfe38f8981cef32a238fa8d6cad93..9330ea91ce953a46f77fbfbcba8f106546a9b459 100644 (file)
@@ -177,7 +177,7 @@ CodeCoverageTool::getSourceFile(StringRef SourceFile) {
   SmallString<256> Path(SourceFile);
   sys::fs::make_absolute(Path);
   for (const auto &Files : LoadedSourceFiles) {
-    if (sys::fs::equivalent(Path.str(), Files.first)) {
+    if (equivalentFiles(Path.str(), Files.first)) {
       return *Files.second;
     }
   }