aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2010-03-24 22:43:31 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2010-03-24 22:43:31 +0000
commitf3eaf45bf3ebef039c99c1e9efb05b477b2a07aa (patch)
tree5be89b8980bacc71e4586896e7e748955fa1ec71
parent2c01676f4f613d884b174e8e19d6da0a3c45a23c (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);
+ }
+}