From 77b50e1126b8699a170c48cef8a91f80a1127f25 Mon Sep 17 00:00:00 2001 From: Douglas Gregor Date: Mon, 22 Jun 2009 23:06:13 +0000 Subject: Implement implicit instantiation of the member functions of a class template specialization. At present, all implicit instantiations occur at the end of the translation unit. llvm-svn: 73915 --- clang/test/SemaTemplate/example-dynarray.cpp | 28 +++++++++++++++++++++++----- 1 file changed, 23 insertions(+), 5 deletions(-) (limited to 'clang/test/SemaTemplate/example-dynarray.cpp') diff --git a/clang/test/SemaTemplate/example-dynarray.cpp b/clang/test/SemaTemplate/example-dynarray.cpp index cca3709bebb..680ee04ba18 100644 --- a/clang/test/SemaTemplate/example-dynarray.cpp +++ b/clang/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; -template class dynarray; - int main() { dynarray 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 dp; + dp.push_back(Point()); + assert(dp.size() == 1); + return 0; } -- cgit v1.2.3