diff options
author | Vedant Kumar <vsk@apple.com> | 2016-06-22 19:57:58 +0000 |
---|---|---|
committer | Vedant Kumar <vsk@apple.com> | 2016-06-22 19:57:58 +0000 |
commit | 049908b2969f56aba6daf6fb4eb98a4a518ef13a (patch) | |
tree | a1ba3c2c8e2ba4c3feafbe2a9267cc3d84775937 /clang | |
parent | 30afae1a75ea895b3be6bd5f04d8f3c6f6703617 (diff) | |
download | bcm5719-llvm-049908b2969f56aba6daf6fb4eb98a4a518ef13a.tar.gz bcm5719-llvm-049908b2969f56aba6daf6fb4eb98a4a518ef13a.zip |
[Coverage] Push a new region when handling CXXTryStmts
Push a new region for the try block and propagate execution counts
through it. This ensures that catch statements get a region counter
distinct from the try block's counter.
llvm-svn: 273463
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/CodeGen/CoverageMappingGen.cpp | 7 | ||||
-rw-r--r-- | clang/test/CoverageMapping/trycatch.cpp | 2 | ||||
-rw-r--r-- | clang/test/CoverageMapping/trymacro.cpp | 19 |
3 files changed, 26 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CoverageMappingGen.cpp b/clang/lib/CodeGen/CoverageMappingGen.cpp index 12bad4b03f7..b56cd077c8b 100644 --- a/clang/lib/CodeGen/CoverageMappingGen.cpp +++ b/clang/lib/CodeGen/CoverageMappingGen.cpp @@ -867,7 +867,12 @@ struct CounterCoverageMappingBuilder void VisitCXXTryStmt(const CXXTryStmt *S) { extendRegion(S); - Visit(S->getTryBlock()); + // Handle macros that generate the "try" but not the rest. + extendRegion(S->getTryBlock()); + + Counter ParentCount = getRegion().getCounter(); + propagateCounts(ParentCount, S->getTryBlock()); + for (unsigned I = 0, E = S->getNumHandlers(); I < E; ++I) Visit(S->getHandler(I)); diff --git a/clang/test/CoverageMapping/trycatch.cpp b/clang/test/CoverageMapping/trycatch.cpp index e3a3f09c9f9..01d8fb93074 100644 --- a/clang/test/CoverageMapping/trycatch.cpp +++ b/clang/test/CoverageMapping/trycatch.cpp @@ -23,7 +23,7 @@ void func(int i) { // CHECK-NEXT: File 0, [[@LINE]]:18 -> {{[ // CHECK-NEXT: main int main() { // CHECK-NEXT: File 0, [[@LINE]]:12 -> [[@LINE+13]]:2 = #0 int j = 1; - try { + try { // CHECK-NEXT: File 0, [[@LINE]]:7 -> [[@LINE+2]]:4 = #0 func(j); } catch(const Error &e) { // CHECK-NEXT: File 0, [[@LINE]]:27 -> [[@LINE+2]]:4 = #2 j = 1; diff --git a/clang/test/CoverageMapping/trymacro.cpp b/clang/test/CoverageMapping/trymacro.cpp index 1fe668353fa..32f44381b93 100644 --- a/clang/test/CoverageMapping/trymacro.cpp +++ b/clang/test/CoverageMapping/trymacro.cpp @@ -17,8 +17,27 @@ catch(...) {} // CHECK: [[@LINE]]:12 -> [[@LINE]]:14 = #2 void fn3() TRY { return; } // CHECK: [[@LINE]]:15 -> [[@LINE+1]]:14 = #1 CATCH(...) {} // CHECK: [[@LINE]]:12 -> [[@LINE]]:14 = #2 +// CHECK: Z3fn4v: +#define TRY2 try { // CHECK-DAG: File 1, [[@LINE]]:18 -> [[@LINE]]:19 = #1 +void fn4() TRY2 // CHECK-DAG: Expansion,File 0, [[@LINE]]:12 -> [[@LINE]]:16 = #1 (Expanded file = 1) + for (;;) + return; +} +catch (...) {} + +// CHECK: Z3fn5v: +#define TRY3 try { return; } catch (...) // CHECK-DAG: File 2, [[@LINE]]:18 -> [[@LINE]]:29 = #1 +#define TRY4 try { TRY3 { return; } } catch (...) // CHECK-DAG: Expansion,File 1, [[@LINE]]:20 -> [[@LINE]]:24 = #1 (Expanded file = 2) +void fn5() { + for (;;) { + TRY4 { return; } // CHECK-DAG: Expansion,File 0, [[@LINE]]:5 -> [[@LINE]]:9 = #1 (Expanded file = 1) + } // CHECK-DAG: File 0, [[@LINE-1]]:10 -> [[@LINE-1]]:21 = #5 +} + int main() { fn1(); fn2(); fn3(); + fn4(); + fn5(); } |