]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: modules and tsubst_friend_class
authorJason Merrill <jason@redhat.com>
Wed, 20 Nov 2024 12:51:10 +0000 (13:51 +0100)
committerJason Merrill <jason@redhat.com>
Thu, 21 Nov 2024 18:37:23 +0000 (19:37 +0100)
In 20_util/function_objects/mem_fn/constexpr.cc we start to instantiate
_Mem_fn_base's friend declaration of _Bind_check_arity before we've loaded
the namespace-scope declaration, so lookup_imported_hidden_friend doesn't
find it.  But then we load the namespace-scope declaration in
lookup_template_class during substitution, and so when we get around to
pushing the result of substitution, they conflict.  Fixed by calling
lazy_load_pendings in lookup_imported_hidden_friend.

gcc/cp/ChangeLog:

* name-lookup.cc (lookup_imported_hidden_friend): Call
lazy_load_pendings.

gcc/cp/name-lookup.cc

index 2dca57a14fd832d5fb1d1224c535563be16af678..769879976420db7ab74c2e4b7fb51f5c2bf28258 100644 (file)
@@ -4569,6 +4569,8 @@ lookup_imported_hidden_friend (tree friend_tmpl)
       || !DECL_MODULE_IMPORT_P (inner))
     return NULL_TREE;
 
+  lazy_load_pendings (friend_tmpl);
+
   tree bind = get_mergeable_namespace_binding
     (current_namespace, DECL_NAME (inner), DECL_MODULE_ATTACH_P (inner));
   if (!bind)