From: Patrick Palka Date: Tue, 28 Jan 2025 14:27:02 +0000 (-0500) Subject: c++: friend vs inherited guide confusion [PR117855] X-Git-Tag: basepoints/gcc-16~2300 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=ea578dd251eaf6304b0c95acc107f9a4d63bee8f;p=thirdparty%2Fgcc.git c++: friend vs inherited guide confusion [PR117855] We recently started using the lang_decl_fn::context field to track inheritedness of a deduction guide (for C++23 inherited CTAD). This new overloading of the field accidentally made DECL_FRIEND_CONTEXT return non-NULL for inherited guides, which breaks the below testcase during overload resolution with an inherited guide. This patch fixes this by refining DECL_FRIEND_CONTEXT appropriately. PR c++/117855 gcc/cp/ChangeLog: * cp-tree.h (DECL_FRIEND_CONTEXT): Exclude deduction guides. gcc/testsuite/ChangeLog: * g++.dg/cpp23/class-deduction-inherited7.C: New test. Reviewed-by: Jason Merrill --- diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h index d3c573f064a..7bf95571bf6 100644 --- a/gcc/cp/cp-tree.h +++ b/gcc/cp/cp-tree.h @@ -3635,7 +3635,8 @@ struct GTY(()) lang_decl { the DECL_FRIEND_CONTEXT for `f' will be `S'. */ #define DECL_FRIEND_CONTEXT(NODE) \ ((DECL_DECLARES_FUNCTION_P (NODE) && !DECL_VIRTUAL_P (NODE) \ - && !DECL_CONSTRUCTOR_P (NODE)) \ + && !DECL_CONSTRUCTOR_P (NODE) \ + && (cxx_dialect < cxx23 || !deduction_guide_p (NODE))) \ ? LANG_DECL_FN_CHECK (NODE)->context \ : NULL_TREE) diff --git a/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited7.C b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited7.C new file mode 100644 index 00000000000..b1d5e89ad02 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp23/class-deduction-inherited7.C @@ -0,0 +1,12 @@ +// PR c++/117855 +// { dg-do compile { target c++20 } } + +template struct span { span(T&&);}; +template span(T &&) -> span; +template +struct this_span : span { + using span::span; +}; +template this_span(T &&) -> this_span; +int vec; +this_span a = vec;