diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/CodeGen/functions.c | 4 | ||||
-rw-r--r-- | test/CodeGenCXX/implicit-instantiation-1.cpp | 29 | ||||
-rw-r--r-- | test/SemaCXX/default-constructor-initializers.cpp | 4 | ||||
-rw-r--r-- | test/SemaTemplate/class-template-decl.cpp | 6 | ||||
-rw-r--r-- | test/SemaTemplate/example-dynarray.cpp | 28 | ||||
-rw-r--r-- | test/SemaTemplate/implicit-instantiation-1.cpp | 16 |
6 files changed, 80 insertions, 7 deletions
diff --git a/test/CodeGen/functions.c b/test/CodeGen/functions.c index 9855992..12dff1b 100644 --- a/test/CodeGen/functions.c +++ b/test/CodeGen/functions.c @@ -33,3 +33,7 @@ void f1() {} // RUN: grep 'define .* @f3' %t | not grep -F '...' struct foo { int X, Y, Z; } f3() { } + +// PR4423 - This shouldn't crash in codegen +void f4() {} +void f5() { f4(42); } diff --git a/test/CodeGenCXX/implicit-instantiation-1.cpp b/test/CodeGenCXX/implicit-instantiation-1.cpp new file mode 100644 index 0000000..f6c6114 --- /dev/null +++ b/test/CodeGenCXX/implicit-instantiation-1.cpp @@ -0,0 +1,29 @@ +// RUN: clang-cc -emit-llvm %s -o %t && + +template<typename T> +struct X { + void f(T) { } + void f(char) { } + + void g(T) { } + + void h(T) { } +}; + +void foo(X<int> &xi, X<float> *xfp, int i, float f) { + // RUN: grep "linkonce_odr.*_ZN1XIiE1fEi" %t | count 1 && + xi.f(i); + + // RUN: grep "linkonce_odr.*_ZN1XIiE1gEi" %t | count 1 && + xi.g(f); + + // RUN: grep "linkonce_odr.*_ZN1XIfE1fEf" %t | count 1 && + xfp->f(f); + + // RUN: grep "linkonce_odr.*_ZN1XIfE1hEf" %t | count 0 && + + // RUN: true +} + + + diff --git a/test/SemaCXX/default-constructor-initializers.cpp b/test/SemaCXX/default-constructor-initializers.cpp index c5250f8..24c53839 100644 --- a/test/SemaCXX/default-constructor-initializers.cpp +++ b/test/SemaCXX/default-constructor-initializers.cpp @@ -11,7 +11,7 @@ struct X2 : X1 { // expected-note {{'struct X2' declared here}} \ struct X3 : public X2 { }; -X3 x3; // expected-error {{cannot define the default constructor for 'struct X3', because member 'struct X2' does not have any implicit default constructor}} +X3 x3; // expected-error {{cannot define the implicit default constructor for 'struct X3', because member 'struct X2' does not have any default constructor}} struct X4 { @@ -19,7 +19,7 @@ struct X4 { X2 & rx2; // expected-note {{declared at}} }; -X4 x4; // expected-error {{cannot define the default constructor for 'struct X4', because base class 'struct X2' does not have any implicit default constructor}} \ +X4 x4; // expected-error {{cannot define the implicit default constructor for 'struct X4', because base class 'struct X2' does not have any default constructor}} \ // expected-error {{cannot define the implicit default constructor for 'struct X4', because reference member rx2 cannot be default-initialized}} diff --git a/test/SemaTemplate/class-template-decl.cpp b/test/SemaTemplate/class-template-decl.cpp index c812677..d2e90c1 100644 --- a/test/SemaTemplate/class-template-decl.cpp +++ b/test/SemaTemplate/class-template-decl.cpp @@ -35,6 +35,12 @@ template<typename> class TemplateTemplateParm; // expected-error{{template param template<template<typename T, int> class X> class TemplateTemplateParm; // expected-error{{too many template parameters in template template parameter redeclaration}} +template<typename T> +struct test {}; // expected-note{{previous definition}} + +template<typename T> +struct test : T {}; // expected-error{{redefinition}} + #if 0 // FIXME: parse template declarations in these scopes, so that we can // complain about the one at function scope. diff --git a/test/SemaTemplate/example-dynarray.cpp b/test/SemaTemplate/example-dynarray.cpp index cca3709..680ee04 100644 --- a/test/SemaTemplate/example-dynarray.cpp +++ b/test/SemaTemplate/example-dynarray.cpp @@ -89,6 +89,21 @@ public: iterator end() { return Last; } const_iterator end() const { return Last; } + bool operator==(const dynarray &other) const { + if (size() != other.size()) + return false; + + for (unsigned I = 0, N = size(); I != N; ++I) + if ((*this)[I] != other[I]) + return false; + + return true; + } + + bool operator!=(const dynarray &other) const { + return !(*this == other); + } + public: T* Start, *Last, *End; }; @@ -100,11 +115,6 @@ struct Point { float x, y, z; }; -// FIXME: remove these when we have implicit instantiation for member -// functions of class templates. -template class dynarray<int>; -template class dynarray<Point>; - int main() { dynarray<int> di; di.push_back(0); @@ -146,5 +156,13 @@ int main() { I != IEnd; ++I) assert(*I == I - di4.begin()); + assert(di4 == di); + di4[3] = 17; + assert(di4 != di); + + dynarray<Point> dp; + dp.push_back(Point()); + assert(dp.size() == 1); + return 0; } diff --git a/test/SemaTemplate/implicit-instantiation-1.cpp b/test/SemaTemplate/implicit-instantiation-1.cpp new file mode 100644 index 0000000..eecaf2f --- /dev/null +++ b/test/SemaTemplate/implicit-instantiation-1.cpp @@ -0,0 +1,16 @@ +// RUN: clang-cc -fsyntax-only -verify %s + +template<typename T, typename U> +struct X { + T f(T x, U y) { return x + y; } + + unsigned g(T x, U y) { return sizeof(f(x, y)); } +}; + +void test(X<int, int> *xii, X<int*, int> *xpi, X<int, int*> *xip) { + (void)xii->f(1, 2); + (void)xpi->f(0, 2); + (void)sizeof(xip->f(2, 0)); // okay: does not instantiate + (void)xip->g(2, 0); // okay: does not instantiate +} + |