llvm-capstone/clang/test/Templight/templight-memoization.cpp
Gabor Horvath 207e7b1fa1 [Templight] Template Instantiation Observer
This patch adds a base-class called TemplateInstantiationObserver which gets
notified whenever a template instantiation is entered or exited during
semantic analysis. This is a base class used to implement the template
profiling and debugging tool called
Templight (https://github.com/mikael-s-persson/templight).

The patch also makes a few more changes:

* ActiveTemplateInstantiation class is moved out of the Sema class (so it can be used with inclusion of Sema.h).
* CreateFrontendAction function in front-end utilities is given external linkage (not longer a hidden static function).
* TemplateInstObserverChain data member added to Sema class to hold the list of template-inst observers.
* Notifications to the template-inst observer are added at the key places where templates are instantiated.

Patch by: Abel Sinkovics!

Differential Revision: https://reviews.llvm.org/D5767

llvm-svn: 324808
2018-02-10 14:04:45 +00:00

43 lines
1.3 KiB
C++

// RUN: %clang_cc1 -templight-dump %s 2>&1 | FileCheck %s
template <class T>
struct foo {};
// CHECK-LABEL: {{^---$}}
// CHECK: {{^name:[ ]+'foo<int>'$}}
// CHECK: {{^kind:[ ]+TemplateInstantiation$}}
// CHECK: {{^event:[ ]+Begin$}}
// CHECK: {{^orig:[ ]+'.*templight-memoization.cpp:4:8'}}
// CHECK: {{^poi:[ ]+'.*templight-memoization.cpp:18:10'$}}
// CHECK-LABEL: {{^---$}}
// CHECK: {{^name:[ ]+'foo<int>'$}}
// CHECK: {{^kind:[ ]+TemplateInstantiation$}}
// CHECK: {{^event:[ ]+End$}}
// CHECK: {{^orig:[ ]+'.*templight-memoization.cpp:4:8'}}
// CHECK: {{^poi:[ ]+'.*templight-memoization.cpp:18:10'$}}
foo<int> x;
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK-LABEL: {{^---$}}
// CHECK: {{^name:[ ]+'foo<int>'$}}
// CHECK: {{^kind:[ ]+Memoization$}}
// CHECK: {{^event:[ ]+Begin$}}
// CHECK: {{^orig:[ ]+'.*templight-memoization.cpp:4:8'}}
// CHECK: {{^poi:[ ]+'.*templight-memoization.cpp:41:10'$}}
// CHECK-LABEL: {{^---$}}
// CHECK: {{^name:[ ]+'foo<int>'$}}
// CHECK: {{^kind:[ ]+Memoization$}}
// CHECK: {{^event:[ ]+End$}}
// CHECK: {{^orig:[ ]+'.*templight-memoization.cpp:4:8'}}
// CHECK: {{^poi:[ ]+'.*templight-memoization.cpp:41:10'$}}
foo<int> y;