diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-02-17 01:05:43 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-02-17 01:05:43 +0000 |
commit | 264ec4f2377624a9ef3418d40de67b7579b5c5f5 (patch) | |
tree | bedec96157245add7a32443c991ec4b06740ff9b /clang/test/SemaTemplate/class-template-id.cpp | |
parent | 3c50922ea02b8f23fa306c7e695f9eaefe8b602a (diff) | |
download | bcm5719-llvm-264ec4f2377624a9ef3418d40de67b7579b5c5f5.tar.gz bcm5719-llvm-264ec4f2377624a9ef3418d40de67b7579b5c5f5.zip |
Added ClassTemplateSpecializationDecl, which is a subclass of
CXXRecordDecl that is used to represent class template
specializations. These are canonical declarations that can refer to
either an actual class template specialization in the code, e.g.,
template<> class vector<bool> { };
or to a template instantiation. However, neither of these features is
actually implemented yet, so really we're just using (and uniqing) the
declarations to make sure that, e.g., A<int> is a different type from
A<float>. Note that we carefully distinguish between what the user
wrote in the source code (e.g., "A<FLOAT>") and the semantic entity it
represents (e.g., "A<float, int>"); the former is in the sugared Type,
the latter is an actual Decl.
llvm-svn: 64716
Diffstat (limited to 'clang/test/SemaTemplate/class-template-id.cpp')
-rw-r--r-- | clang/test/SemaTemplate/class-template-id.cpp | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/clang/test/SemaTemplate/class-template-id.cpp b/clang/test/SemaTemplate/class-template-id.cpp index 0bdc3e98759..39dc29796b0 100644 --- a/clang/test/SemaTemplate/class-template-id.cpp +++ b/clang/test/SemaTemplate/class-template-id.cpp @@ -1,17 +1,29 @@ // RUN: clang -fsyntax-only -verify %s -template<typename T> struct A { }; +template<typename T, typename U = float> struct A { }; typedef A<int> A_int; -float *foo(A<int> *ptr, A<int> const *ptr2) { +typedef float FLOAT; + +A<int, FLOAT> *foo(A<int> *ptr, A<int> const *ptr2, A<int, double> *ptr3) { if (ptr) - return ptr; // expected-error{{incompatible type returning 'A<int> *', expected 'float *'}} + return ptr; // okay else if (ptr2) - return ptr2; // expected-error{{incompatible type returning 'A<int> const *', expected 'float *'}} + return ptr2; // expected-error{{incompatible type returning 'A<int> const *', expected 'A<int, FLOAT> *'}} else { - // FIXME: This is completely bogus, but we're using it temporarily - // to test the syntactic sugar for class template specializations. - int *ip = ptr; - return 0; + return ptr3; // expected-error{{incompatible type returning 'A<int, double> *', expected 'A<int, FLOAT> *'}} } } + +template<int I> struct B; + +const int value = 12; +B<17 + 2> *bar(B<(19)> *ptr1, B< (::value + 7) > *ptr2, B<19 - 3> *ptr3) { + if (ptr1) + return ptr1; + else if (ptr2) + return ptr2; + else + return ptr3; // expected-error{{incompatible type returning 'B<19 - 3> *', expected 'B<17 + 2> *'}} +} + |