diff options
author | Francois Pichet <pichet2000@gmail.com> | 2011-08-14 03:52:19 +0000 |
---|---|---|
committer | Francois Pichet <pichet2000@gmail.com> | 2011-08-14 03:52:19 +0000 |
commit | 00c7e6ceb1826baab50c02f8547e97bfcaf9641c (patch) | |
tree | 68edbf921c455305987d024f6fe9487d8ab6c318 /clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp | |
parent | ae13df60a69d93374c39c3457ba4b493da2ffc65 (diff) | |
download | bcm5719-llvm-00c7e6ceb1826baab50c02f8547e97bfcaf9641c.tar.gz bcm5719-llvm-00c7e6ceb1826baab50c02f8547e97bfcaf9641c.zip |
Implement function template specialization at class scope extension in Microsoft mode. A new AST node is introduced: ClassScopeFunctionSpecialization. This node holds a FunctionDecl that is not yet specialized; then during the class template instantiation the ClassScopeFunctionSpecialization will spawn the actual function specialization.
Example:
template <class T>
class A {
public:
template <class U> void f(U p) { }
template <> void f(int p) { } // <== class scope specialization
};
This extension is necessary to parse MSVC standard C++ headers, MFC and ATL code.
BTW, with this feature in, clang can parse (-fsyntax-only) all the MSVC 2010 standard header files without any error.
llvm-svn: 137573
Diffstat (limited to 'clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp')
-rw-r--r-- | clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp b/clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp new file mode 100644 index 00000000000..88215016009 --- /dev/null +++ b/clang/test/SemaTemplate/ms-function-specialization-class-scope.cpp @@ -0,0 +1,71 @@ +// RUN: %clang_cc1 -fms-extensions -fsyntax-only -verify %s + + +class A { +public: + template <class U> + A(U p) { + } + template <> + A(int p) { // expected-warning{{explicit specialization of 'A' within class scope in a Microsoft extension}} + } + + template <class U> + void f(U p) { + } + + template <> + void f(int p) { // expected-warning{{explicit specialization of 'f' within class scope in a Microsoft extension}} + } + + void f(int p) { + } +}; + +void test1() +{ + A a(3); + char* b ; + a.f(b); + a.f<int>(99); + a.f(100); +} + + + + +template <class T> +class B { +public: + template <class U> + B(U p) { + } + template <> + B(int p) { // expected-warning{{explicit specialization of 'B<T>' within class scope in a Microsoft extension}} + } + + template <class U> + void f(U p) { + T y = 9; + } + + + template <> + void f(int p) { // expected-warning{{explicit specialization of 'f' within class scope in a Microsoft extension}} + T a = 3; + } + + void f(int p) { + T a = 3; + } +}; + +void test2() +{ + B<char> b(3); + char* ptr; + b.f(ptr); + b.f<int>(99); + b.f(100); +} + |