+2020-05-19 Nathan Sidwell <nathan@acm.org>
+
+ * pt.c (lookup_template_class_1): Do not reinit template_info of an
+ alias here.
+
2020-05-18 Martin Sebor <msebor@redhat.com>
PR c++/94923
}
}
- // Build template info for the new specialization.
- SET_TYPE_TEMPLATE_INFO (t, build_template_info (found, arglist));
+ /* Build template info for the new specialization. This can
+ overwrite the existing TEMPLATE_INFO for T (that points to
+ its instantiated TEMPLATE_DECL), with this one that points to
+ the most general template, but that's what we want. */
+
+ if (TYPE_ALIAS_P (t))
+ {
+ /* This should already have been constructed during
+ instantiation of the alias decl. */
+ tree ti = DECL_TEMPLATE_INFO (TYPE_NAME (t));
+ gcc_checking_assert (template_args_equal (TI_ARGS (ti), arglist)
+ && TI_TEMPLATE (ti) == found);
+ }
+ else
+ SET_TYPE_TEMPLATE_INFO (t, build_template_info (found, arglist));
elt.spec = t;
slot = type_specializations->find_slot_with_hash (&elt, hash, INSERT);