[committed] libstdc++: Fix std::get<T> for std::tuple [PR101427]
Jonathan Wakely
jwakely@redhat.com
Thu Jul 15 15:26:51 GMT 2021
On 15/07/21 16:26 +0100, Jonathan Wakely wrote:
>The std::get<T> functions relied on deduction failing if more than one
>base class existed for the type T. However the implementation of Core
>DR 2303 (in r11-4693) made deduction succeed (and select the
>more-derived base class).
>
>This rewrites the implementation of std::get<T> to explicitly check for
>more than one occurrence of T in the tuple elements, making it
>ill-formed again. Additionally, the large wall of overload resolution
>errors described in PR c++/101460 is avoided by making std::get<T> use
>__get_helper<I> directly instead of calling std::get<I>, and by adding a
>deleted overload of __get_helper<N> for out-of-range N.
>
>Signed-off-by: Jonathan Wakely <jwakely@redhat.com>
>
>libstdc++-v3/ChangeLog:
>
> PR libstdc++/101427
> * include/std/tuple (tuple_element): Improve static_assert text.
> (__get_helper): Add deleted overload.
> (get<i>(tuple<T...>&&), get<i>(const tuple<T...>&&)): Use
> __get_helper directly.
> (__get_helper2): Remove.
> (__find_uniq_type_in_pack): New constexpr helper function.
> (get<T>): Use __find_uniq_type_in_pack and __get_helper instead
> of __get_helper2.
> * testsuite/20_util/tuple/element_access/get_neg.cc: Adjust
> expected errors.
> * testsuite/20_util/tuple/element_access/101427.cc: New test.
>
>Tested powerpc64le-linux. Committed to trunk.
This should be backported to gcc-11 in time for 11.2 as well. If you
see any problems with it please let me know ASAP.
More information about the Libstdc++
mailing list