diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2010-03-24 22:43:31 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2010-03-24 22:43:31 +0000 |
commit | f3eaf45bf3ebef039c99c1e9efb05b477b2a07aa (patch) | |
tree | 5be89b8980bacc71e4586896e7e748955fa1ec71 | |
parent | 2c01676f4f613d884b174e8e19d6da0a3c45a23c (diff) |
Discussing with dgregor we decided that we should not force the emission of
implicit methods on explicit template instantiation definitions. As a
consequence, we should emit them at every use, even if we see a explicit
template instantiation declaration.
This is already the current behaviour, but it is good to test for that :-)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@99443 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/CodeGenCXX/template-instantiation.cpp (renamed from test/CodeGenCXX/PR6677.cpp) | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/test/CodeGenCXX/PR6677.cpp b/test/CodeGenCXX/template-instantiation.cpp index 8d168f1106..9e0593998b 100644 --- a/test/CodeGenCXX/PR6677.cpp +++ b/test/CodeGenCXX/template-instantiation.cpp @@ -3,6 +3,10 @@ // CHECK-NOT: @_ZTVN5test118stdio_sync_filebufIwEE = constant // CHECK: @_ZTVN5test018stdio_sync_filebufIwEE = constant +// CHECK: define linkonce_odr void @_ZN5test21CIiEC1Ev( +// CHECK: define linkonce_odr void @_ZN5test21CIiE6foobarIdEEvT_( +// CHECK: define available_externally void @_ZN5test21CIiE6zedbarEd( + namespace test0 { struct basic_streambuf { virtual ~basic_streambuf(); @@ -31,3 +35,28 @@ namespace test1 { // Just a declaration should not force the vtable to be emitted. template<> void stdio_sync_filebuf<wchar_t>::xsgetn(); } + +namespace test2 { + template<typename T1> + class C { + virtual ~C(); + void zedbar(double) { + } + template<typename T2> + void foobar(T2 foo) { + } + }; + extern template class C<int>; + void g() { + // The extern template declaration should not prevent us from producing + // the implicit constructor (test at the top). + C<int> a; + + // or foobar(test at the top). + a.foobar(0.0); + + // But it should prevent zebbar + // (test at the top). + a.zedbar(0.0); + } +} |