pt.c (instantiate_decl): Tell the repository code about the clones, not the cloned...
authorMark Mitchell <mark@codesourcery.com>
Wed, 6 Jun 2001 03:15:33 +0000 (03:15 +0000)
committerMark Mitchell <mmitchel@gcc.gnu.org>
Wed, 6 Jun 2001 03:15:33 +0000 (03:15 +0000)
* pt.c (instantiate_decl): Tell the repository code about the
clones, not the cloned functions.
* repo.c (repo_template_used): Explicitly instantiate the cloned
function, not the clones.

From-SVN: r42931

gcc/cp/ChangeLog
gcc/cp/pt.c
gcc/cp/repo.c
gcc/testsuite/g++.old-deja/g++.pt/repo4.C [new file with mode: 0644]

index f4e08d603f39163285480ed54be134ce694ecd2c..7c0ebc5f754f89d9a8437e823e6718f01dd079ba 100644 (file)
@@ -1,3 +1,10 @@
+2001-06-05  Mark Mitchell  <mark@codesourcery.com>
+
+       * pt.c (instantiate_decl): Tell the repository code about the
+       clones, not the cloned functions.
+       * repo.c (repo_template_used): Explicitly instantiate the cloned
+       function, not the clones.
+
 2001-06-05  Nathan Sidwell  <nathan@codesourcery.com>
 
        * call.c (build_user_type_conversion_1): Set ICS_USER_FLAG and
index 19de9614e44dac96cd921055042c78dcaf499a89..b82ac028f64fbc6e5006da13d80a231a4f147a96 100644 (file)
@@ -9821,7 +9821,25 @@ instantiate_decl (d, defer_ok)
 
   if (pattern_defined)
     {
-      repo_template_used (d);
+      /* Let the repository code that this template definition is
+        available.
+
+        The repository doesn't need to know about cloned functions
+        because they never actually show up in the object file.  It
+        does need to know about the clones; those are the symbols
+        that the linker will be emitting error messages about.  */
+      if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (d)
+         || DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (d))
+       {
+         tree t;
+
+         for (t = TREE_CHAIN (d);
+              t && DECL_CLONED_FUNCTION_P (t); 
+              t = TREE_CHAIN (t))
+           repo_template_used (t);
+       }
+      else
+       repo_template_used (d);
 
       if (flag_external_templates && ! DECL_INTERFACE_KNOWN (d))
        {
index 6dfcafc24f326dd4f108ed3fc0a2f5f66219ab5f..f2f95919d56ee0088fa1088d13edcbf151f6c1bc 100644 (file)
@@ -137,7 +137,13 @@ repo_template_used (t)
   else if (DECL_P (t))
     {
       if (IDENTIFIER_REPO_CHOSEN (id))
-       mark_decl_instantiated (t, 0);
+       /* It doesn't make sense to instantiate a clone, so we
+          instantiate the cloned function instead.  Note that this
+          approach will not work correctly if collect2 assigns
+          different clones to different files -- but it shouldn't.  */
+       mark_decl_instantiated (DECL_CLONED_FUNCTION_P (t)
+                               ? DECL_CLONED_FUNCTION (t) : t, 
+                               0);
     }
   else
     my_friendly_abort (1);
diff --git a/gcc/testsuite/g++.old-deja/g++.pt/repo4.C b/gcc/testsuite/g++.old-deja/g++.pt/repo4.C
new file mode 100644 (file)
index 0000000..6180acb
--- /dev/null
@@ -0,0 +1,15 @@
+// Build then link:
+// Special g++ Options: -frepo
+
+template <class T>
+struct S {
+  ~S ();
+};
+
+template <class T>
+S<T>::~S () {}
+
+int main ()
+{
+  S<int> s;
+}