diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-06-23 15:45:29 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-06-23 15:45:29 +0000 |
commit | e67068c5f90d7cbc39f970e951d7e8622c485838 (patch) | |
tree | 24f40726a751600285ec3a82aee4c9184a300524 | |
parent | 33a3907db98dd79728f8f887f0468d3d98c49fcf (diff) |
Add a test illustrating our current inability to properly cope with the point of instantation of a member function of a class template specialization
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@73956 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/CXX/temp/temp.res/temp.dep.res/temp.point/p1.cpp | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/test/CXX/temp/temp.res/temp.dep.res/temp.point/p1.cpp b/test/CXX/temp/temp.res/temp.dep.res/temp.point/p1.cpp new file mode 100644 index 0000000000..650501069c --- /dev/null +++ b/test/CXX/temp/temp.res/temp.dep.res/temp.point/p1.cpp @@ -0,0 +1,32 @@ +// RUN: clang-cc -fsyntax-only -verify %s +// XFAIL + +// Note: we fail this test because we perform template instantiation +// at the end of the translation unit, so argument-dependent lookup +// finds functions that occur after the point of instantiation. Note +// that GCC fails this test; EDG passes the test in strict mode, but +// not in relaxed mode. +namespace N { + struct A { }; + struct B : public A { }; + + int& f0(A&); +} + +template<typename T, typename Result> +struct X0 { + void test_f0(T t) { + Result r = f0(t); + }; +}; + +void test_f0() { + X0<N::A, int&> xA; + xA.test_f0(N::A()); + X0<N::B, int&> xB; + xB.test_f0(N::B()); +} + +namespace N { + char& f0(B&); +} |