PR libstdc++/86751 default assignment operators for std::pair
authorJonathan Wakely <jwakely@redhat.com>
Tue, 31 Jul 2018 22:31:20 +0000 (23:31 +0100)
committerJonathan Wakely <redi@gcc.gnu.org>
Tue, 31 Jul 2018 22:31:20 +0000 (23:31 +0100)
commite182158261869320bc6fb1e972fd5a142359965e
treed7eb7ca6f086116d8255266c60687c914c552802
parentff273400466f44c64a19b917151641706318c268
PR libstdc++/86751 default assignment operators for std::pair

The solution for PR 77537 causes ambiguities due to the extra copy
assignment operator taking a __nonesuch_no_braces parameter. By making
the base class non-assignable we don't need the extra deleted overload
in std::pair. The copy assignment operator will be implicitly deleted
(and the move assignment operator not declared) as needed. Without the
additional user-provided operator in std::pair the ambiguity is avoided.

PR libstdc++/86751
* include/bits/stl_pair.h (__pair_base): New class with deleted copy
assignment operator.
(pair): Derive from __pair_base.
(pair::operator=): Remove deleted overload.
* python/libstdcxx/v6/printers.py (StdPairPrinter): New pretty printer
so that new base class isn't shown in GDB.
* testsuite/20_util/pair/86751.cc: New test.
* testsuite/20_util/pair/ref_assign.cc: New test.

From-SVN: r263185
libstdc++-v3/ChangeLog
libstdc++-v3/include/bits/stl_pair.h
libstdc++-v3/python/libstdcxx/v6/printers.py
libstdc++-v3/testsuite/20_util/pair/86751.cc [new file with mode: 0644]
libstdc++-v3/testsuite/20_util/pair/ref_assign.cc [new file with mode: 0644]