]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/ChangeLog
Explicitly link with libatomic when needed.
[thirdparty/gcc.git] / libstdc++-v3 / ChangeLog
CommitLineData
bd55ce63
JDA
12020-02-29 John David Anglin <danglin@gcc.gnu.org>
2
3 * testsuite/30_threads/condition_variable_any/stop_token/wait_on.cc:
4 Add libatomic option.
5 * testsuite/30_threads/jthread/jthread.cc: Likewise.
6
44c85722
FD
72020-02-29 François Dumont <fdumont@gcc.gnu.org>
8
9 * include/bits/stl_algo.h
10 (__find_if, __count_if, __is_permutation, std::is_permutation): Move...
11 * include/bits/stl_algobase.h: ...here.
12 * include/bits/hashtable_policy.h: Remove <bits/stl_algo.h> include.
13
d4912dc7
JDA
142020-02-29 John David Anglin <danglin@gcc.gnu.org>
15
68a1a11f
JDA
16 * testsuite/30_threads/stop_token/stop_callback.cc: Add libatomic
17 option.
18 * testsuite/30_threads/stop_token/stop_callback/deadlock-mt.cc:
19 Likewise.
20 * testsuite/30_threads/stop_token/stop_callback/deadlock.cc: Likewise.
21 * testsuite/30_threads/stop_token/stop_callback/destroy.cc: Likewise.
22 * testsuite/30_threads/stop_token/stop_callback/invoke.cc: Likewise.
23 * testsuite/30_threads/stop_token/stop_source.cc: Likewise.
24 * testsuite/30_threads/stop_token/stop_source/assign.cc: Likewise.
25 * testsuite/30_threads/stop_token/stop_token.cc: Likewise.
26 * testsuite/30_threads/stop_token/stop_token/stop_possible.cc:
27 Likewise.
28
d4912dc7
JDA
29 PR libstdc++/92906
30 * config/abi/post/hppa-linux-gnu/baseline_symbols.txt: Update.
31
799270b4
PP
322020-02-28 Patrick Palka <ppalka@redhat.com>
33
ce33801f
PP
34 PR libstdc++/93972
35 * include/bits/ranges_algo.h (__lexicographical_compare_fn::operator()):
36 Fix condition for when to use memcmp, making it consistent with the
37 corresponding condition used in std::lexicographical_compare.
38 * testsuite/25_algorithms/lexicographical_compare/93972.cc: New test.
39
799270b4
PP
40 * testsuite/26_numerics/headers/numeric/synopsis.cc: Add signatures for
41 functions introduced in C++11, C++17 and C++2a. Add 'constexpr' to
42 existing signatures for C++2a.
43
4735f92d
JW
442020-02-28 Jonathan Wakely <jwakely@redhat.com>
45
46 * testsuite/24_iterators/range_operations/advance_debug_neg.cc: Run
47 test instead of just compiling it.
48
a1535015
PP
492020-02-28 Patrick Palka <ppalka@redhat.com>
50
77e596cf
PP
51 * include/std/ranges (reverse_view::_S_needs_cached_begin): Set to false
52 whenever the underlying range models common_range.
53
a1535015
PP
54 * include/std/ranges (__detail::_CachedPosition): New struct.
55 (views::filter_view::_S_needs_cached_begin): New member variable.
56 (views::filter_view::_M_cached_begin): New member variable.
57 (views::filter_view::begin): Use _M_cached_begin to cache its
58 result.
59 (views::drop_view::_S_needs_cached_begin): New static member variable.
60 (views::drop_view::_M_cached_begin): New member variable.
61 (views::drop_view::begin): Use _M_cached_begin to cache its result
62 when _S_needs_cached_begin.
63 (views::drop_while_view::_M_cached_begin): New member variable.
64 (views::drop_while_view::begin): Use _M_cached_begin to cache its
65 result.
66 (views::reverse_view::_S_needs_cached_begin): New static member
67 variable.
68 (views::reverse_view::_M_cached_begin): New member variable.
69 (views::reverse_view::begin): Use _M_cached_begin to cache its result
70 when _S_needs_cached_begin.
71 * testsuite/std/ranges/adaptors/drop.cc: Augment test to check that
72 drop_view::begin caches its result.
73 * testsuite/std/ranges/adaptors/drop_while.cc: Augment test to check
74 that drop_while_view::begin caches its result.
75 * testsuite/std/ranges/adaptors/filter.cc: Augment test to check that
76 filter_view::begin caches its result.
77 * testsuite/std/ranges/adaptors/reverse.cc: Augment test to check that
78 reverse_view::begin caches its result.
79
86e2dc22
JW
802020-02-28 Jonathan Wakely <jwakely@redhat.com>
81
a51a546c
JW
82 * testsuite/27_io/filesystem/operations/last_write_time.cc: Fixes for
83 filesystems that silently truncate timestamps.
84 * testsuite/experimental/filesystem/operations/last_write_time.cc:
85 Likewise.
86
86e2dc22
JW
87 * testsuite/21_strings/basic_string/cons/char/1.cc: Disable
88 -Wstringop-overflow warnings.
89
44949494
JW
902020-02-27 Jonathan Wakely <jwakely@redhat.com>
91
92 * testsuite/lib/libstdc++.exp (v3_target_compile): Add
93 -fdiagnostics-urls=never to options.
94
10a32d47
PP
952020-02-27 Patrick Palka <ppalka@redhat.com>
96
ba49e9eb
PP
97 * include/std/ranges (transform_view::_Iterator<_Const>): Befriend
98 _Iterator<!_Const>.
99 (transform_view::_Sentinel<_Const>): Befriend _Sentinel<!_Const>.
100 (take_view::_Sentinel<_Const>): Likewise.
101 (take_while_view::_Sentinel<_Const>): Likewise.
102 (split_view::_OuterIter<_Const>): Befriend _OuterIter<!_Const>.
103 * testsuite/std/ranges/adaptors/split.cc: Augment test.
104 * testsuite/std/ranges/adaptors/take.cc: Augment test.
105 * testsuite/std/ranges/adaptors/take_while.cc: Augment test.
106 * testsuite/std/ranges/adaptors/transform.cc: Augment test.
107
10a32d47
PP
108 * testsuite/25_algorithms/copy/constrained.cc: Don't assume that the
109 base() of a vector<>::iterator is a pointer.
110 * testsuite/25_algorithms/copy_backward/constrained.cc: Likewise.
111 * testsuite/25_algorithms/move/constrained.cc: Likewise.
112 * testsuite/25_algorithms/move_backward/constrained.cc: Likewise.
113 * testsuite/25_algorithms/inplace_merge/constrained.cc: Use foo.data()
114 instead of &foo[0].
115 * testsuite/25_algorithms/partial_sort/constrained.cc: Likewise.
116 * testsuite/25_algorithms/partial_sort_copy/constrained.cc: Likewise.
117 * testsuite/25_algorithms/shuffle/constrained.cc: Likewise.
118 * testsuite/25_algorithms/sort/constrained.cc: Likewise.
119 * testsuite/25_algorithms/stable_sort/constrained.cc: Likewise.
120
eb8e6a30
JW
1212020-02-27 Jonathan Wakely <jwakely@redhat.com>
122
ae705159
JW
123 * include/debug/array (operator<=>): Define for C++20.
124 * testsuite/23_containers/array/tuple_interface/get_debug_neg.cc:
125 Adjust dg-error line numbers.
126 * testsuite/23_containers/array/tuple_interface/
127 tuple_element_debug_neg.cc: Likewise.
128
b112e3cb
JW
129 * testsuite/23_containers/span/back_assert_neg.cc: Add #undef before
130 defining _GLIBCXX_ASSERTIONS.
131 * testsuite/23_containers/span/first_2_assert_neg.cc: Likewise.
132 * testsuite/23_containers/span/first_assert_neg.cc: Likewise.
133 * testsuite/23_containers/span/front_assert_neg.cc: Likewise.
134 * testsuite/23_containers/span/index_op_assert_neg.cc: Likewise.
135 * testsuite/23_containers/span/last_2_assert_neg.cc: Likewise.
136 * testsuite/23_containers/span/last_assert_neg.cc: Likewise.
137 * testsuite/23_containers/span/subspan_2_assert_neg.cc: Likewise.
138 * testsuite/23_containers/span/subspan_3_assert_neg.cc: Likewise.
139 * testsuite/23_containers/span/subspan_4_assert_neg.cc: Likewise.
140 * testsuite/23_containers/span/subspan_5_assert_neg.cc: Likewise.
141 * testsuite/23_containers/span/subspan_6_assert_neg.cc: Likewise.
142 * testsuite/23_containers/span/subspan_assert_neg.cc: Likewise.
143
f32a3662
JW
144 * include/debug/string (__gnu_debug::basic_string::insert): Fix for
145 C++98 where the member function of the base class returns void.
146
e94f2542
JW
147 * testsuite/util/testsuite_iterators.h (forward_iterator_wrapper): Add
148 equality comparisons that support value-initialized iterators.
149
eb8e6a30
JW
150 * include/bits/boost_concept_check.h (__function_requires): Add
151 _GLIBCXX14_CONSTEXPR.
152 * testsuite/25_algorithms/min/concept_checks.cc: New test.
153
fd335985
PP
1542020-02-26 Patrick Palka <ppalka@redhat.com>
155
8ce13842
PP
156 PR libstdc++/93936
157 * include/std/ranges (split_view::_InnerIter::operator==): Compare
158 the operands' _M_i rather than their _M_i.current().
159 * testsuite/std/ranges/adaptors/split.cc: Augment test.
160
fd335985
PP
161 P1645R1 constexpr for <numeric> algorithms
162 * include/bits/stl_numeric.h (iota, accumulate, inner_product,
163 partial_sum, adjacent_difference): Make conditionally constexpr for
164 C++20.
165 * include/std/numeric (__cpp_lib_constexpr_numeric): Define this feature
166 test macro.
167 (reduce, transform_reduce, exclusive_scan, inclusive_scan,
168 transform_exclusive_scan, transform_inclusive_scan): Make conditionally
169 constexpr for C++20.
170 * include/std/version (__cpp_lib_constexpr_numeric): Define.
171 * testsuite/26_numerics/accumulate/constexpr.cc: New test.
172 * testsuite/26_numerics/adjacent_difference/constexpr.cc: Likewise.
173 * testsuite/26_numerics/exclusive_scan/constexpr.cc: Likewise.
174 * testsuite/26_numerics/inclusive_scan/constexpr.cc: Likewise.
175 * testsuite/26_numerics/inner_product/constexpr.cc: Likewise.
176 * testsuite/26_numerics/iota/constexpr.cc: Likewise.
177 * testsuite/26_numerics/partial_sum/constexpr.cc: Likewise.
178 * testsuite/26_numerics/reduce/constexpr.cc: Likewise.
179 * testsuite/26_numerics/transform_exclusive_scan/constexpr.cc: Likewise.
180 * testsuite/26_numerics/transform_inclusive_scan/constexpr.cc: Likewise.
181 * testsuite/26_numerics/transform_reduce/constexpr.cc: Likewise.
182
8017d95c
JW
1832020-02-26 Jonathan Wakely <jwakely@redhat.com>
184
113f0a63
JW
185 * include/bits/ranges_algo.h (__lexicographical_compare_fn): Declare
186 variables in smaller scope and avoid calling ranges::distance when we
187 know they are pointers. Remove statically-unreachable use of
188 __builtin_unreachable().
189 * include/bits/stl_algobase.h (__lexicographical_compare::__lc):
190 Define inline.
191
8017d95c
JW
192 * include/std/ranges (__detail::__maybe_empty_t): Define new helper
193 alias.
194 (__detail::__maybe_const_t): Likewise.
195 (__adaptor::_RangeAdaptor): Use __maybe_empty_t.
196 (transform_view, take_view, take_while_view, elements_view): Use
197 __maybe_const_t.
198 (join_view, split_view): Use both.
199
7f0f1083
PP
2002020-02-25 Patrick Palka <ppalka@redhat.com>
201
76a8c0f6
PP
202 LWG 3397 basic_istream_view::iterator should not provide
203 iterator_category
204 * include/std/ranges (basic_istream_view:_Iterator::iterator_category):
205 Rename to ...
206 (basic_istream_view:_Iterator::iterator_concept): ... this.
207 * testsuite/std/ranges/istream_view.cc: Augment test.
208
ec15da7c
PP
209 LWG 3325 Constrain return type of transformation function for
210 transform_view
211 * include/std/ranges (transform_view): Constrain the return type of the
212 transformation function as per LWG 3325.
213 * testsuite/std/ranges/adaptors/lwg3325_neg.cc: New test.
214
55c4b3f4
PP
215 LWG 3313 join_view::_Iterator::operator-- is incorrectly constrained
216 * include/std/ranges (join_view::_Iterator::operator--): Require that
217 range_reference_t<_Base> models common_range.
218 * testsuite/std/ranges/adaptors/lwg3313_neg.cc: New test.
219
510bd1c1
PP
220 LWG 3301 transform_view::_Iterator has incorrect iterator_category
221 * include/std/ranges (transform_view::_Iterator::_S_iter_cat): Adjust
222 determination of iterator_category as per LWG 3301.
223 * testsuite/std/ranges/adaptors/transform.cc: Augment test.
224
7f0f1083
PP
225 LWG 3292 iota_view is under-constrained
226 * include/std/ranges (iota_view): Require that _Winc models semiregular
227 as per LWG 3292.
228 * testsuite/std/ranges/iota/lwg3292_neg.cc: New test.
229
dfb93d05 2302020-02-25 Jonathan Wakely <jwakely@redhat.com>
5b904f17 231
490350a1
JW
232 * include/bits/ranges_algobase.h (__copy_or_move): Do not use memmove
233 during constant evaluation. Call __builtin_memmove directly instead of
234 __memmove.
235 (__copy_or_move_backward): Likewise.
236 * include/bits/stl_algobase.h (__memmove): Remove.
237 (__copy_move<M, true, random_access_iterator_tag>::__copy_m)
238 (__copy_move_backward<M, true, random_access_iterator_tag>::__copy_m):
239 Use __builtin_memmove directly instead of __memmove.
240 (__copy_move_a2): Do not use memmove during constant evaluation.
241 (__copy_move_backward_a2): Use _IsMove constant to select correct
242 __copy_move_backward specialization.
243 * testsuite/25_algorithms/copy_backward/constexpr.cc: Check for copies
244 begin turned into moves during constant evaluation.
245
6de946e6
JW
246 * testsuite/25_algorithms/move_backward/93872.cc: Add test left out of
247 previous commit.
248
5b904f17
JW
249 PR libstdc++/93872
250 * include/bits/stl_algobase.h (__memmove): Cast away const before
251 doing move assignment.
252 * testsuite/25_algorithms/move/93872.cc: New test.
253 * testsuite/25_algorithms/move_backward/93872.cc: New test.
254
c5eab4ed
PP
2552020-02-24 Patrick Palka <ppalka@redhat.com>
256
85c143d0
PP
257 PR libstdc++/93884
258 * include/bits/ranges_algobase.h (__copy_or_move,
259 __copy_or_move_backward): Don't inspect the iter_value_t of the output
260 iterator, instead inspect its iterator_traits directly.
261 * include/bits/stl_iterator.h (back_insert_iterator::container):
262 Conditionally initialize.
263 (back_insert_iterator::difference_type): Conditionally define.
264 (back_insert_iterator::back_insert_iterator): Conditionally define this
265 default constructor.
266 (front_insert_iterator::container): Conditionally initialize.
267 (front_insert_iterator::difference_type): Conditionally define.
268 (front_insert_iterator::front_insert_iterator): Conditionally define
269 this default constructor.
270 * 24_iterators/back_insert_iterator/pr93884.cc: New test.
271 * 24_iterators/front_insert_iterator/pr93884.cc: New test.
272
c5eab4ed
PP
273 P0769R2 Add shift to <algorithm>
274 * include/bits/ranges_algo.h (shift_left, shift_right): New.
275 * testsuite/25_algorithms/shift_left/1.cc: New test.
276 * testsuite/25_algorithms/shift_right/1.cc: New test.
277
3841739c
JW
2782020-02-24 Jonathan Wakely <jwakely@redhat.com>
279
8566286e
JW
280 * include/bits/stream_iterator.h (istream_iterator(default_sentinel_t)):
281 Make noexcept-specifier conditional.
282 * testsuite/24_iterators/istream_iterator/cons/sentinel.cc: Check
283 noexcept-specifier.
284
120e8734
JW
285 * include/bits/stream_iterator.h (istream_iterator(default_sentinel_t)):
286 Add constructor.
287 (operator==(istream_iterator, default_sentinel_t)): Add operator.
288 (ostream_iterator::difference_type): Define to ptrdiff_t for C++20.
289 * include/bits/streambuf_iterator.h
290 (istreambuf_iterator(default_sentinel_t)): Add constructor.
291 (operator==(istreambuf_iterator, default_sentinel_t)): Add operator.
292 * testsuite/24_iterators/istream_iterator/cons/sentinel.cc:
293 New test.
294 * testsuite/24_iterators/istream_iterator/sentinel.cc: New test.
295 * testsuite/24_iterators/istreambuf_iterator/cons/sentinel.cc:
296 New test.
297 * testsuite/24_iterators/istreambuf_iterator/sentinel.cc: New test.
298
3841739c
JW
299 * include/std/ranges (__deep_const_range, __enable_view_impl): Remove.
300 (ranges::enable_view): Simplify (LWG 3326).
301 * include/bits/range_access.h (ranges::enable_view): Declare.
302 * include/bits/regex.h (__enable_view_impl): Remove partial
303 specialization.
304 * include/bits/stl_multiset.h (__enable_view_impl): Likewise.
305 * include/bits/stl_set.h (__enable_view_impl): Likewise.
306 * include/bits/unordered_set.h (__enable_view_impl): Likewise.
307 * include/debug/multiset.h (__enable_view_impl): Likewise.
308 * include/debug/set.h (__enable_view_impl): Likewise.
309 * include/debug/unordered_set (__enable_view_impl): Likewise.
310 * include/experimental/string_view (ranges::enable_view): Define
311 partial specialization.
312 * include/std/span (ranges::enable_view): Likewise.
313 * include/std/string_view (ranges::enable_view): Likewise.
314 * testsuite/std/ranges/view.cc: Check satisfaction of updated concept.
315
9e589880
JW
3162020-02-21 Jonathan Wakely <jwakely@redhat.com>
317
318 * include/std/optional (operator<=>(optional<T>, optional<U>))
319 (operator<=>(optional<T>, nullopt), operator<=>(optional<T>, U)):
320 Define for C++20.
321 * include/std/tuple (__tuple_cmp): New helper function for <=>.
322 (operator<=>(tuple<T...>, tuple<U>...)): Define for C++20.
323 * include/std/variant (operator<=>(variant<T...>, variant<T...>))
324 (operator<=>(monostate, monostate)): Define for C++20.
325 * testsuite/20_util/optional/relops/three_way.cc: New test.
326 * testsuite/20_util/tuple/comparison_operators/three_way.cc: New test.
327 * testsuite/20_util/variant/89851.cc: Move to ...
328 * testsuite/20_util/variant/relops/89851.cc: ... here.
329 * testsuite/20_util/variant/90008.cc: Move to ...
330 * testsuite/20_util/variant/relops/90008.cc: ... here.
331 * testsuite/20_util/variant/relops/three_way.cc: New test.
332
5586e506
PP
3332020-02-20 Patrick Palka <ppalka@redhat.com>
334
6e63438a
PP
335 * include/std/ranges (views::__adaptor::__maybe_refwrap): New utility
336 function.
337 (views::__adaptor::_RangeAdaptor::operator()): Add comments. Use
338 __maybe_refwrap to capture lvalue references by reference, and then use
339 unwrap_reference_t to forward the by-reference captures as references.
340 * testsuite/std/ranges/adaptors/split.cc: Augment test.
341 * testsuite/std/ranges/adaptors/split_neg.cc: New test.
342
5586e506
PP
343 * include/std/ranges (iota_view): Forward declare _Sentinel.
344 (iota_view::_Iterator): Befriend _Sentinel.
345 (iota_view::_Sentinel::_M_equal): New member function.
346 (iota_view::_Sentinel::operator==): Use it.
347 (views::_Iota::operator()): Forward __f using the correct type.
348 * testsuite/std/ranges/access/ssize.cc (test06): Don't call views::iota
349 with integers of different signedness, to appease iota_view's deduction
350 guide.
351 * testsuite/std/ranges/iota/iota_view.cc: Augment test.
352
c7b591f3
JW
3532020-02-20 Jonathan Wakely <jwakely@redhat.com>
354
e817c23f
JW
355 * include/bits/range_access.h (ranges::begin): Reject array of
356 incomplete type.
357 (ranges::end, ranges::size): Require arrays to be bounded.
358 (ranges::data): Require lvalue or borrowed_range.
359 (ranges::iterator_t): Remove constraint.
360 * testsuite/std/ranges/access/begin.cc: Do not check array of
361 incomplete type.
362 * testsuite/std/ranges/access/begin_neg.cc: New test.
363 * testsuite/std/ranges/access/end_neg.cc: Adjust expected error.
364 * testsuite/std/ranges/access/size_neg.cc: Adjust expected error.
365 * testsuite/std/ranges/access/ssize.cc: Do not check array of
366 incomplete type.
367
4be779f5
JW
368 * include/std/system_error (error_category::operator<=>)
369 (operator<=>(const error_code&, const error_code&))
370 (operator<=>(const error_condition&, const error_condition&)): Define
371 for C++20.
372 * testsuite/19_diagnostics/error_category/operators/less.cc: New test.
373 * testsuite/19_diagnostics/error_category/operators/three_way.cc: New
374 test.
375 * testsuite/19_diagnostics/error_code/operators/equal.cc: Remove
376 incorrect comment.
377 * testsuite/19_diagnostics/error_code/operators/less.cc: New test.
378 * testsuite/19_diagnostics/error_code/operators/not_equal.cc: Remove
379 incorrect comment.
380 * testsuite/19_diagnostics/error_code/operators/three_way.cc: New test.
381 * testsuite/19_diagnostics/error_condition/operators/equal.cc: Remove
382 incorrect comment.
383 * testsuite/19_diagnostics/error_condition/operators/less.cc: New test.
384 * testsuite/19_diagnostics/error_condition/operators/not_equal.cc:
385 Remove incorrect comment.
386 * testsuite/19_diagnostics/error_condition/operators/three_way.cc: New
387 test.
388
20fa41e6
JW
389 * libsupc++/typeinfo (type_info::operator!=): Remove for C++20.
390
c7b591f3
JW
391 * include/std/thread (thread::id::operator<=>): Define for C++20.
392 * testsuite/30_threads/thread/id/70294.cc: Do not take addresses of
393 functions in namespace std.
394 * testsuite/30_threads/thread/id/operators_c++20.cc: New test.
395
38c7b74d
PP
3962020-02-19 Patrick Palka <ppalka@redhat.com>
397
398 * testsuite/std/ranges/adaptors/split.cc (test03): Don't include the
399 null terminator of the underlying string as part of the test_range.
400 (main): Call test03.
401
a45fb21a
JW
4022020-02-19 Jonathan Wakely <jwakely@redhat.com>
403
1b425f3a
JW
404 * include/bits/stl_iterator.h (common_iterator): Add copyable<I>
405 requirement (LWG 3385).
406 * testsuite/24_iterators/headers/iterator/synopsis_c++20.cc: Adjust
407 expected declaration.
408
7433536b
JW
409 * include/std/ranges (take_while_view, drop_view, drop_while_view)
410 (elements_view:_Iterator): Initialize data members (LWG 3364).
411
256f67aa
JW
412 * libsupc++/compare (three_way_comparable): Remove always-false check
413 that should have been removed with weak_equality (P1959R0).
414 (three_way_comparable_with): Likewise. Reorder requirements (LWG 3360).
415
0294dc5f
JW
416 * include/std/concepts (__detail::__partially_ordered_with): Move here
417 from <compare>.
418 (totally_ordered, totally_ordered_with): Use __partially_ordered_with
419 to simplify definition (LWG 3331).
420 * libsupc++/compare (__detail::__partially_ordered_with): Move to
421 <concepts>.
422
241ed965
JW
423 * include/std/concepts (totally_ordered_with): Remove redundant
424 requirement (LWG 3329).
425
77f5310f
JW
426 * include/std/ranges (__detail::__convertible_to_non_slicing): New
427 helper concept.
428 (__detail::__pair_like_convertible_to): Remove.
429 (__detail::__pair_like_convertible_from): Add requirements for
430 non-slicing conversions.
431 (subrange): Constrain constructors with __convertible_to_non_slicing.
432 Remove constructors from pair-like types. Add new deduction guide.
433 * testsuite/std/ranges/subrange/lwg3282_neg.cc: New test.
434
59aa9e57
JW
435 * include/bits/iterator_concepts.h (iter_move): Add declaration to
436 prevent unqualified lookup finding a suitable declaration (LWG 3247).
437
e89100ef
JW
438 * include/std/memory_resource (polymorphic_allocator::allocate)
439 (polymorphic_allocator::allocate_object): Change type of exception to
440 bad_array_new_length (LWG 3237).
441 * testsuite/20_util/polymorphic_allocator/lwg3237.cc: New test.
442
bb54e0b8
JW
443 * include/std/type_traits (__cpp_lib_unwrap_ref): Define (LWG 3348).
444 * include/std/version (__cpp_lib_unwrap_ref): Likewise.
445 * testsuite/20_util/unwrap_reference/1.cc: Check macro.
446 * testsuite/20_util/unwrap_reference/3.cc: New test.
447
5f031f97
JW
448 * include/std/numeric (midpoint(T8, T*)): Do not check for complete
449 type during overload resolution, use static assert instead (LWG 3200).
450 * testsuite/26_numerics/midpoint/pointer.cc: Do not test with
451 incomplete type.
452 * testsuite/26_numerics/midpoint/pointer_neg.cc: New test.
453
66ae31eb
JW
454 * include/std/span (span(T (&)[N])): Use non-deduced context to
455 prevent first parameter from interfering with class template argument
456 deduction (LWG 3369).
457 * testsuite/23_containers/span/deduction.cc: Add missing 'const'.
458 * testsuite/23_containers/span/lwg3255.cc: Check for construction from
459 rvalues.
460
247f410b
JW
461 * include/std/span (span::const_iterator, span::const_reverse_iterator)
462 (span::cbegin(), span::cend(), span::crbegin(), span::crend()):
463 Remove (LWG 3320).
464 * testsuite/23_containers/span/everything.cc: Replace uses of cbegin
465 and cend.
466 * testsuite/20_util/specialized_algorithms/destroy/constrained.cc:
467 Likewise.
468 * testsuite/20_util/specialized_algorithms/uninitialized_copy/
469 constrained.cc: Likewise.
470 * testsuite/20_util/specialized_algorithms/
471 uninitialized_default_construct/constrained.cc: Likewise.
472 * testsuite/20_util/specialized_algorithms/uninitialized_fill/
473 constrained.cc: Likewise.
474 * testsuite/20_util/specialized_algorithms/uninitialized_move/
475 constrained.cc: Likewise.
476 * testsuite/20_util/specialized_algorithms/
477 uninitialized_value_construct/constrained.cc: Likewise.
478
aca60ecf
JW
479 * include/bits/range_access.h (range_size_t): Define alias template.
480 * include/std/ranges (all_view): Rename to views::all_t (LWG 3335).
481 * testsuite/std/ranges/adaptors/filter.cc: Adjust to new name.
482
4cc3b275
JW
483 * include/std/ranges (filter_view, transform_view, take_view)
484 (join_view, split_view, reverse_view): Remove commented-out converting
485 constructors (LWG 3280).
486
5f3641d0
JW
487 * include/std/memory (uninitialized_construct_using_allocator): Use
488 std::construct_at (LWG 3321).
489
020a03ee
JW
490 * include/std/memory_resource (polymorphic_allocator::allocate_bytes)
491 (polymorphic_allocator::allocate_object)
492 (polymorphic_allocator::new_object): Add nodiscard attribute (LWG3304).
493
15411a64
JW
494 LWG 3379. "safe" in several library names is misleading
495 * include/bits/range_access.h (enable_safe_range): Rename to
496 enable_borrowed_range.
497 (__detail::__maybe_safe_range): Rename to __maybe_borrowed_range.
498 (safe_range): Rename to borrowed_range.
499 * include/bits/ranges_algo.h: Adjust to use new names.
500 * include/bits/ranges_algobase.h: Likewise.
501 * include/bits/ranges_uninitialized.h: Likewise.
502 * include/std/ranges: Likewise.
503 (safe_iterator_t): Rename to borrowed_iterator_t.
504 (safe_subrange_t): Rename to borrowed_subrange_t.
505 * include/std/span: Adjust to use new names.
506 * include/std/string_view: Likewise.
507 * include/experimental/string_view: Likewise.
508 * testsuite/std/ranges/access/begin.cc: Likewise.
509 * testsuite/std/ranges/access/cbegin.cc: Likewise.
510 * testsuite/std/ranges/access/cdata.cc: Likewise.
511 * testsuite/std/ranges/access/cend.cc: Likewise.
512 * testsuite/std/ranges/access/crbegin.cc: Likewise.
513 * testsuite/std/ranges/access/crend.cc: Likewise.
514 * testsuite/std/ranges/access/data.cc: Likewise.
515 * testsuite/std/ranges/access/end.cc: Likewise.
516 * testsuite/std/ranges/access/rbegin.cc: Likewise.
517 * testsuite/std/ranges/access/rend.cc: Likewise.
518 * testsuite/std/ranges/safe_range.cc: Likewise.
519 * testsuite/std/ranges/safe_range_types.cc: Likewise.
520 * testsuite/util/testsuite_iterators.h: Likewise.
521
fa89adaa
JW
522 * include/std/ranges (tuple_element<0, const subrange<I, S, K>>)
523 (tuple_element<1, const subrange<I, S, K>>): Add partial
524 specializations (LWG 3398).
525 * testsuite/std/ranges/subrange/tuple_like.cc: New test.
526
a45fb21a
JW
527 * include/bits/ranges_algo.h (__find_fn, __find_first_of_fn)
528 (__adjacent_find_fn, __remove_if_fn, __remove_copy_if_fn)
529 (__unique_fn, __unique_copy_fn): Remove redundant conversions to bool.
530
242b4fb7
PP
5312020-02-18 Patrick Palka <ppalka@redhat.com>
532
533 P1983R0 Wording for GB301, US296, US292, US291, and US283
534 * include/std/ranges (filter_view::pred): New member function.
535 (join_view::_Iterator::_Iterator): Remove now-redundant comment since
536 P1983R0 fixes the highlighted issue in the same way.
537 (join_view::_Iterator<_Const>): Add friend
538 join_view::_Iterator<!_Const>.
539 (join_view::_M_inner): Remove mutable specifier, effectively reverting
540 the proposed wording changes of P3278.
541 (join_view::begin): Refine the condition for when to return a const
542 iterator.
543 (split_view::_OuterIter::_OuterIter): Adjust constraints.
544 * testsuite/std/ranges/adaptors/filter.cc: Test that filter_view::pred
545 exists and works.
546
f5b4dc38
JW
5472020-02-18 Jonathan Wakely <jwakely@redhat.com>
548
a5b213dd
JW
549 PR libstdc++/93818
550 * include/std/ranges (_RangeAdaptor): Add deduction guide.
551 (filter_view::_Iterator): Add alias _Vp_iter and use in place of
552 iterator_t<_Vp>.
553 (filter_view::_Iterator::_S_iter_cat()): Add 'typename'.
554 (transform_view::_Iterator): Add alias _Base_iter and use in place of
555 iterator_t<_Base>.
556 (transform_view::_Iterator::_S_iter_cat()): Add 'typename'.
557 (join_view::_Iterator): Add _Outer_iter and _Inner_iter aliases.
558 (join_view::_Iterator::_S_iter_cat()): Add 'typename'.
559 (split_view::_InnerIter::_S_iter_cat()): Likewise.
560
ce7b39d0
JW
561 * testsuite/20_util/integer_comparisons/equal.cc: Fix invalid
562 assumption that long is wider than int.
563 * testsuite/20_util/integer_comparisons/greater_equal.cc: Likewise.
564 * testsuite/20_util/integer_comparisons/less.cc: Likewise.
565 * testsuite/20_util/integer_comparisons/less_equal.cc: Likewise.
566 * testsuite/20_util/integer_comparisons/not_equal.cc: Likewise.
567
9b8e2dea
JW
568 P1976R2 Fixed-size span construction from dynamic range
569 * include/std/span (__cpp_lib_span): Update value.
570 (span(It, size_type), span(It, End)): Make conditionally explicit. Add
571 assertion.
572 (span(R&&), span(const span<OType, OExtent>&)): Likewise and relax
573 constraints.
574 (span::first<Count>(), span::last<Count>()): Use explicit type in
575 return statement.
576 (as_bytes, as_writable_bytes): Likewise.
577 * include/std/version (__cpp_lib_span): Update value.
578 * testsuite/23_containers/span/1.cc: Check new value.
579 * testsuite/23_containers/span/2.cc: Check new value.
580 * testsuite/23_containers/span/explicit.cc: New test.
581
d6c9e372
JW
582 * include/std/span (span::__is_compatible_array): Simplify alias
583 template by using requires-clause.
584 (span::__is_compatible_ref): New alias template for constraining
585 constructors.
586 (span::__is_compatible_iterator, span::__is_compatible_range): Remove.
587 (span(It, size_type), span(It, End)): Use __is_compatible_ref.
588 (span(T(&)[N], span(array<T, N>&), span(const array<T, N>&)): Remove
589 redundant parentheses.
590 (span(R&&)): Add missing constraints.
591
f09f3242
JW
592 * include/std/span (span): Reorder members and rename template
593 parameters to match declarations in the C++2a working paper.
594
f5b4dc38
JW
595 P2116R0 Remove tuple-like protocol support from fixed-extent span
596 * include/std/span (get, tuple_size, tuple_element): Remove.
597 * testsuite/23_containers/span/everything.cc: Remove checks for
598 tuple-like API.
599 * testsuite/23_containers/span/get_neg.cc: Remove.
600 * testsuite/23_containers/span/tuple_element_dynamic_neg.cc: Remove.
601 * testsuite/23_containers/span/tuple_element_oob_neg.cc: Remove.
602 * testsuite/23_containers/span/tuple_size_neg.cc: Remove.
603
f3169941
PP
6042020-02-17 Patrick Palka <ppalka@redhat.com>
605
aa667c3f
PP
606 P2106R0 Alternative wording for GB315 and GB316
607 * include/bits/ranges_algo.h (in_fun_result): New.
608 (for_each_result, for_each_n_result): Change into an alias of
609 in_fun_result.
610 (in_in_result): New.
611 (mismatch_result): Change into an alias of in_in_result.
612 (copy_if_result): Change into an alias of in_out_result.
613 (swap_ranges_result): Change into an alias of in_in_result.
614 (unary_transform_result): Change into an alias of in_out_result.
615 (in_in_out_result): New.
616 (binary_transform_result): Change into an alias of in_in_out_result.
617 (replace_copy_result, replace_copy_if_result, remove_copy_if_result,
618 remove_copy_result, unique_copy_result, reverse_copy_result,
619 rotate_copy_result, partial_sort_copy_result): Change into an alias of
620 in_out_result.
621 (in_out_out_result): New.
622 (partition_copy_result, merge_result): Change into an alias of
623 in_out_out_result.
624 (set_union_result, set_intersection_result): Change into an alias of
625 in_in_out_result.
626 (set_difference_result): Change into an alias of in_out_result.
627 (set_symmetric_difference): Change into an alias of in_in_out_result.
628 (min_max_result): New.
629 (minmax_result, minmax_element_result): Change into an alias of
630 min_max_result.
631 (in_found_result): New.
632 (next_permutation_result, prev_permutation_result): Change into an alias
633 of in_found_result.
634 (__next_permutation_fn::operator(), __prev_permutation_fn::operator()):
635 Adjust following changes to next_permutation_result and
636 prev_permutation_result.
637 * include/bits/ranges_algobase.h (in_out_result): New.
638 (copy_result, move_result, move_backward_result, copy_backward_result,
639 copy_n_result): Change into an alias of in_out_result.
640 * include/bits/ranges_uninitialized.h (uninitialized_copy_result,
641 uninitialized_copy_n_result, uninitialized_move_result,
642 uninitialized_move_n_result): Likewise.
643 * testsuite/25_algorithms/next_permutation/constrained.cc: Adjust uses of
644 structured bindings.
645 * testsuite/25_algorithms/prev_permutation/constrained.cc: Likewise.
646
f3169941
PP
647 P1243R4 Rangify new algorithms
648 * include/bits/ranges_algo.h (for_each_n_result, __for_each_n_fn,
649 for_each_n, __sample_fn, sample, __clamp_fn, clamp): New.
650 * testsuite/25_algorithms/clamp/constrained.cc: New test.
651 * testsuite/25_algorithms/for_each/constrained.cc: Augment test.
652 * testsuite/25_algorithms/sample/constrained.cc: New test.
653
98cf2c26
JW
6542020-02-17 Jonathan Wakely <jwakely@redhat.com>
655
c5e1c1d3
JW
656 P1964R2 Wording for boolean-testable
657 * include/bits/ranges_algo.h (__find_fn, __find_first_of_fn)
658 (__adjacent_find_fn): Cast result of predicate to bool.
659 * include/std/concepts (__boolean): Remove.
660 (__detail::__boolean_testable_impl, __detail::__boolean_testable): Add
661 new helper concepts.
662 (__detail::__weakly_eq_cmp_with, totally_ordered, totally_ordered_with)
663 (predicate): Use __boolean_testable instead of boolean.
664 * libsupc++/compare (__detail::__partially_ordered, _Synth3way):
665 Likewise.
666
7ab36231
JW
667 P1970R2 Consistency for size() functions: Add ranges::ssize
668 * include/bits/range_access.h (_SSize, ssize): Define for C++20.
669 * testsuite/std/ranges/access/ssize.cc: New test.
670
9866abe3
JW
671 P1956R1 On the names of low-level bit manipulation functions
672 * include/bits/hashtable_policy.h: Update comment.
673 * include/std/bit (__ispow2, __ceil2, __floor2, __log2p1): Rename.
674 (ispow2, ceil2, floor2, log2p1): Likewise.
675 (__cpp_lib_int_pow2): Add feature test macro.
676 * include/std/charconv (__to_chars_len_2): Adjust use of __log2p1.
677 * include/std/memory (assume_aligned): Adjust use of ispow2.
678 * include/std/version (__cpp_lib_int_pow2): Add.
679 * libsupc++/new_opa.cc: Adjust use of __ispow2.
680 * src/c++17/memory_resource.cc: Likewise, and for __ceil2 and __log2p1.
681 * testsuite/17_intro/freestanding.cc: Adjust use of ispow2.
682 * testsuite/26_numerics/bit/bit.pow.two/ceil2.cc: Rename to ...
683 * testsuite/26_numerics/bit/bit.pow.two/bit_ceil.cc: ... here.
684 * testsuite/26_numerics/bit/bit.pow.two/ceil2_neg.cc: Rename to ...
685 * testsuite/26_numerics/bit/bit.pow.two/bit_ceil_neg.cc: ... here.
686 * testsuite/26_numerics/bit/bit.pow.two/floor2.cc: Rename to ...
687 * testsuite/26_numerics/bit/bit.pow.two/bit_floor.cc: ... here.
688 * testsuite/26_numerics/bit/bit.pow.two/log2p1.cc: Rename to ...
689 * testsuite/26_numerics/bit/bit.pow.two/bit_width.cc: ... here.
690 * testsuite/26_numerics/bit/bit.pow.two/ispow2.cc: Rename to ...
691 * testsuite/26_numerics/bit/bit.pow.two/has_single_bit.cc: ... here.
692
cfbc8fbb
JW
693 * include/std/charconv: Add comment.
694
9cd4eeef
JW
695 PR libstdc++/92546 (partial)
696 * include/bits/random.h (uniform_random_bit_generator): Move definition
697 to <bits/uniform_int_dist.h>.
698 * include/bits/ranges_algo.h: Include <bits/uniform_int_dist.h> instead
699 of <bits/random.h>.
700 * include/bits/ranges_algobase.h: Do not include <cmath>.
701 * include/bits/uniform_int_dist.h (uniform_random_bit_generator):
702 Move here.
703 * include/std/ranges: Do not include <limits>.
704 * testsuite/26_numerics/random/pr60037-neg.cc: Adjust dg-error lineno.
705
c03b53da
JW
706 PR libstdc++/92546 (partial)
707 * include/Makefile.am: Add new header.
708 * include/Makefile.in: Regenerate.
709 * include/bits/int_limits.h: New header.
710 * include/bits/parse_numbers.h (__select_int::_Select_int): Replace
711 numeric_limits with __detail::__int_limits.
712 * include/std/bit (__rotl, __rotr, __countl_zero, __countl_one)
713 (__countr_zero, __countr_one, __popcount, __ceil2, __floor2, __log2p1):
714 Likewise.
715 * include/std/charconv (__to_chars_8, __from_chars_binary)
716 (__from_chars_alpha_to_num, from_chars): Likewise.
717 * include/std/memory_resource (polymorphic_allocator::allocate)
718 (polymorphic_allocator::allocate_object): Likewise.
719 * include/std/string_view (basic_string_view::_S_compare): Likewise.
720 * include/std/utility (in_range): Likewise.
721 * testsuite/20_util/integer_comparisons/in_range_neg.cc: Adjust for
722 extra error about incomplete type __int_limits<bool>.
723 * testsuite/26_numerics/bit/bit.count/countl_one.cc: Include <limits>.
724 * testsuite/26_numerics/bit/bit.count/countl_zero.cc: Likewise.
725 * testsuite/26_numerics/bit/bit.count/countr_one.cc: Likewise.
726 * testsuite/26_numerics/bit/bit.count/countr_zero.cc: Likewise.
727 * testsuite/26_numerics/bit/bit.count/popcount.cc: Likewise.
728 * testsuite/26_numerics/bit/bit.pow.two/ceil2_neg.cc: Likewise.
729 * testsuite/26_numerics/bit/bit.pow.two/ceil2.cc: Likewise.
730 * testsuite/26_numerics/bit/bit.pow.two/floor2.cc: Likewise.
731 * testsuite/26_numerics/bit/bit.pow.two/ispow2.cc: Likewise.
732 * testsuite/26_numerics/bit/bit.pow.two/log2p1.cc: Likewise.
733 * testsuite/26_numerics/bit/bit.rotate/rotl.cc: Likewise.
734 * testsuite/26_numerics/bit/bit.rotate/rotr.cc: Likewise.
735
4540ef78
JW
736 * python/libstdcxx/v6/printers.py (StdCmpCatPrinter.to_string): Update
737 value for partial_ordering::unordered.
738
d6dfa3da
JW
739 * include/bits/iterator_concepts.h (indirectly_copyable_storable): Add
740 const-qualified expression variations.
741 * include/std/concepts (copyable): Likewise.
742
98cf2c26
JW
743 * include/std/type_traits (__is_standard_integer): New helper trait.
744 * include/std/utility (cmp_equal, cmp_not_equal, cmp_less, cmp_greater)
745 (cmp_less_equal, cmp_greater_equal, in_range): Define for C++20.
746 * include/std/version (__cpp_lib_integer_comparison_functions): Define.
747 * testsuite/20_util/integer_comparisons/1.cc: New test.
748 * testsuite/20_util/integer_comparisons/2.cc: New test.
749 * testsuite/20_util/integer_comparisons/equal.cc: New test.
750 * testsuite/20_util/integer_comparisons/equal_neg.cc: New test.
751 * testsuite/20_util/integer_comparisons/greater_equal.cc: New test.
752 * testsuite/20_util/integer_comparisons/greater_equal_neg.cc: New test.
753 * testsuite/20_util/integer_comparisons/greater_neg.cc: New test.
754 * testsuite/20_util/integer_comparisons/in_range.cc: New test.
755 * testsuite/20_util/integer_comparisons/in_range_neg.cc: New test.
756 * testsuite/20_util/integer_comparisons/less.cc: New test.
757 * testsuite/20_util/integer_comparisons/less_equal.cc: New test.
758 * testsuite/20_util/integer_comparisons/less_equal_neg.cc: New test.
759 * testsuite/20_util/integer_comparisons/less_neg.cc: New test.
760 * testsuite/20_util/integer_comparisons/not_equal.cc: New test.
761 * testsuite/20_util/integer_comparisons/not_equal_neg.cc: New test.
762
93b8cfce
PP
7632020-02-16 Patrick Palka <ppalka@redhat.com>
764
765 * include/bits/ranges_algo.h (__lexicographical_compare_fn::operator()):
766 Move code after an early exit constexpr if to under an else branch.
767 * include/bits/ranges_algobase.h (__equal_fn::operator()): Likewise.
768
90b7eb65
PP
7692020-02-15 Patrick Palka <ppalka@redhat.com>
770
55992626
PP
771 * include/bits/ranges_algo.h: Adjust whitespace and formatting.
772 * include/bits/ranges_algobase.h: Likewise.
773 * include/bits/ranges_uninitialized.h: Likewise.
774
b40c57bd
PP
775 * include/bits/ranges_algo.h: (adjacent_find, all_of, any_of,
776 binary_search, copy_if, count, count_if, equal_range, find, find_end,
777 find_first_of, find_if, find_if_not, for_each, generate, generate_n,
778 includes, inplace_merge, is_heap, is_heap_until, is_partitioned,
779 is_permutation, is_sorted, is_sorted_until, lexicographical_compare,
780 lower_bound, make_heap, max, max_element, merge, min, min_element,
781 minmax, minmax_element, mismatch, next_permutation, none_of,
782 nth_element, partial_sort, partial_sort_copy, partition, partition_copy,
783 partition_point, pop_heap, prev_permutation, push_heap, remove,
784 remove_copy, remove_copy_if, remove_if, replace, replace_copy,
785 replace_copy_if, replace_if, reverse, reverse_copy, rotate, rotate_copy,
786 search, search_n, set_difference, set_intersection,
787 set_symmetric_difference, set_union, shuffle, sort, sort_heap,
788 stable_partition, stable_sort, swap_ranges, transform, unique,
789 unique_copy, upper_bound): Convert into function objects.
790 * include/bits/ranges_algobase.h: (equal, copy, move, copy_n, fill_n,
791 fill, move_backward, copy_backward): Likewise.
792 * include/bits/ranges_uninitialized.h (uninitialized_default_construct,
793 uninitialized_default_construct_n, uninitialized_value_construct,
794 uninitialized_value_construct_n, uninitialized_copy,
795 uninitialized_copy_n, uninitialized_move, uninitialized_move_n,
796 uninitialized_fill, uninitialized_fill_n, construct_at, destroy_at,
797 destroy, destroy_n): Likewise.
798
90b7eb65
PP
799 * include/bits/ranges_algo.h (ranges::__find_end): Fold into ...
800 (ranges::find_end): ... here.
801 (ranges::__lexicographical_compare): Fold into ...
802 (ranges::lexicographical_compare): ... here.
803 * include/bits/ranges_algobase.h (ranges::__equal): Fold into ...
804 (ranges::equal): ... here.
805
55b00d14
JW
8062020-02-15 Jonathan Wakely <jwakely@redhat.com>
807
808 * include/bits/erase_if.h (__cpp_lib_erase_if): Define to 202002L.
809 * include/std/deque: Likewise.
810 * include/std/forward_list: Likewise.
811 * include/std/list: Likewise.
812 * include/std/string: Likewise.
813 * include/std/vector: Likewise.
814 * include/std/version: Likewise.
815 * testsuite/23_containers/deque/erasure.cc: Test for new value.
816 * testsuite/23_containers/forward_list/erasure.cc: Likewise.
817 * testsuite/23_containers/list/erasure.cc: Likewise.
818 * testsuite/23_containers/map/erasure.cc: Likewise.
819 * testsuite/23_containers/set/erasure.cc: Likewise.
820 * testsuite/23_containers/unordered_map/erasure.cc: Likewise.
821 * testsuite/23_containers/unordered_set/erasure.cc: Likewise.
822 * testsuite/23_containers/vector/erasure.cc: Likewise.
823
5b1d5885
JW
8242020-02-15 Jonathan Wakely <jwakely@redhat.com>
825
826 * include/bits/random.h (uniform_random_bit_generator): Require min()
827 and max() to be constant expressions and min() to be less than max().
828 * testsuite/26_numerics/random/concept.cc: Check additional cases.
829 * testsuite/26_numerics/random/pr60037-neg.cc: Adjust dg-error lineno.
830
90fc7b3c
PP
8312020-02-13 Patrick Palka <ppalka@redhat.com>
832
613c932f
PP
833 * include/Makefile.am: Add <bits/ranges_uninitialized.h>.
834 * include/Makefile.in: Regenerate.
835 * include/bits/ranges_uninitialized.h: New header.
836 * include/std/memory: Include it.
837 * testsuite/20_util/specialized_algorithms/destroy/constrained.cc: New
838 test.
839 * .../uninitialized_copy/constrained.cc: New test.
840 * .../uninitialized_default_construct/constrained.cc: New test.
841 * .../uninitialized_fill/constrained.cc: New test.
842 * .../uninitialized_move/constrained.cc: New test.
843 * .../uninitialized_value_construct/constrained.cc: New test.
844
90fc7b3c
PP
845 * include/Makefile.am: Add bits/ranges_algobase.h
846 * include/Makefile.in: Regenerate.
847 * bits/ranges_algo.h: Include <bits/ranges_algobase.h> and refactor
848 existing #includes.
849 (__detail::__is_normal_iterator, __detail::is_reverse_iterator,
850 __detail::__is_move_iterator, copy_result, move_result,
851 __equal, equal, copy_result, move_result, move_backward_result,
852 copy_backward_result, __copy_or_move_backward, __copy_or_move, copy,
853 move, copy_backward, move_backward, copy_n_result, copy_n, fill_n,
854 fill): Split out into ...
855 * bits/range_algobase.h: ... this new header.
856
99bbab9f
PP
8572020-02-12 Patrick Palka <ppalka@redhat.com>
858
859 LWG 3389 and LWG 3390
860 * include/bits/stl_iterator.h (move_move_iterator): Use std::move when
861 constructing the move_iterator with __i.
862 (counted_iterator::counted_iterator): Use std::move when initializing
863 M_current with __i.
864 * testsuite/24_iterators/counted_iterator/lwg3389.cc: New test.
865 * testsuite/24_iterators/move_iterator/lwg3390.cc: New test.
866
02ce382c
SL
8672020-02-12 Sandra Loosemore <sandra@codesourcery.com>
868
869 PR libstdc++/79193
870 PR libstdc++/88999
871
872 * configure: Regenerated.
873
b32a3f32
FD
8742020-02-12 François Dumont <fdumont@gcc.gnu.org>
875
876 * include/bits/hashtable.h
877 (_Hashtable<>(_Hashtable&&, std::allocator_type&)): Add
878 missing std namespace qualification to forward call.
879
dcda050e
JW
8802020-02-09 Jonathan Wakely <jwakely@redhat.com>
881
38660e87
JW
882 * testsuite/20_util/function_objects/range.cmp/equal_to.cc: Fix
883 comment.
884 * testsuite/20_util/function_objects/range.cmp/less.ccL Likewise.
885
97a7c229
JW
886 * include/std/ranges: Fix non-ASCII characters in comment.
887
dcda050e
JW
888 * include/bits/range_cmp.h (__detail::__eq_builtin_ptr_cmp): Require
889 equality comparison to be valid and return bool.
890 (__detail::__less_builtin_ptr_cmp): Likewise for less-than comparison.
891 * testsuite/20_util/function_objects/range.cmp/equal_to.cc: Check
892 type with ambiguous conversion to fundamental types.
893 * testsuite/20_util/function_objects/range.cmp/less.cc: Likewise.
894
d222d8ec
JW
8952020-02-07 Jonathan Wakely <jwakely@redhat.com>
896
c8dd2446
JW
897 * include/bits/iterator_concepts.h (iter_difference_t, iter_value_t):
898 Use remove_cvref_t.
899 (readable_traits): Rename to indirectly_readable_traits.
900 (readable): Rename to indirectly_readable.
901 (writable): Rename to indirectly_writable.
902 (__detail::__iter_exchange_move): Do not use remove_reference_t.
903 (indirectly_swappable): Adjust requires expression parameter types.
904 expression.
905 * include/bits/ranges_algo.h (ranges::transform, ranges::replace)
906 (ranges::replace_if, ranges::generate_n, ranges::generate)
907 (ranges::remove): Use new name for writable.
908 * include/bits/stl_iterator.h (__detail::__common_iter_has_arrow):
909 Use new name for readable.
910 * include/ext/pointer.h (readable_traits<_Pointer_adapter<P>>): Use
911 new name for readable_traits.
912 * testsuite/24_iterators/associated_types/readable.traits.cc: Likewise.
913 * testsuite/24_iterators/indirect_callable/projected.cc: Adjust for
914 new definition of indirectly_readable.
915
d222d8ec
JW
916 * include/bits/stl_iterator.h (__detail::__common_iter_ptr): Change
917 to take parameters of common_iterator, instead of the common_iterator
918 type itself. Fix argument for __common_iter_has_arrow constraint.
919 (iterator_traits<common_iterator<I, S>>::pointer): Adjust.
920
572992c8
JW
9212020-02-07 Jonathan Wakely <jwakely@redhat.com>
922
923 * include/std/ranges (iota_view): Add braces to prevent -Wempty-body
924 warning.
925 (basic_istream_view::_Iterator::operator++()): Add missing return.
926
cba9ef06
PP
9272020-02-07 Patrick Palka <ppalka@redhat.com>
928
a04f635d
PP
929 * include/bits/ranges_algo.h: Remove extraneous &&.
930
b7903d9f
PP
931 * include/std/ranges (ranges::__detail::__stream_extractable,
932 ranges::basic_istream_view, ranges::istream_view): Define.
933 * testsuite/std/ranges/istream_view: New test.
934
cba9ef06
PP
935 Implement C++20 range adaptors
936 * include/std/ranges: Include <bits/refwrap.h> and <tuple>.
937 (subrange::_S_store_size): Mark as const instead of constexpr to
938 avoid what seems to be a bug in GCC.
939 (__detail::__box): Give it defaulted copy and move constructors.
55d4cbcb
PP
940 (ranges::views::_Single::operator()): Mark constexpr.
941 (ranges::views::_Iota::operator()): Mark constexpr.
cba9ef06 942 (__detail::Empty): Define.
55d4cbcb
PP
943 (ranges::views::__closure::_RangeAdaptor,
944 ranges::views::__closure::_RangeAdaptorClosure, ref_view, all_view,
945 ranges::views::all, ranges::__detail::find_if,
946 ranges::__detail::find_if_not, ranges::__detail::mismatch,
947 ranges::detail::min, filter_view, ranges::views::filter, transform_view,
948 ranges::views::transform, take_view, ranges::views::take,
949 take_while_view, ranges::views::take_while, drop_view,
950 ranges::views::drop, join_view, ranges::views::join,
cba9ef06 951 __detail::require_constant, __detail::tiny_range, split_view,
55d4cbcb
PP
952 ranges::views::split, ranges::views::_Counted, ranges::views::counted,
953 common_view, ranges::views::common, reverse_view,
954 ranges::views::reverse,
955 ranges::views::__detail::__is_reversible_subrange,
956 ranges::views::__detail::__is_reverse_view, reverse_view,
957 ranges::views::reverse, __detail::__has_tuple_element, elements_view,
958 ranges::views::elements, ranges::views::keys, ranges::views::values):
959 Define.
960 (views): Alias for ranges::views.
961 (tuple_size<ranges::subrange<>>, tuple_element<0, ranges::subrange>,
962 tuple_element<1, ranges::subrange>): New partial specializations.
cba9ef06
PP
963 * testsuite/std/ranges/adaptors/all.cc: New test.
964 * testsuite/std/ranges/adaptors/common.cc: Likewise.
965 * testsuite/std/ranges/adaptors/counted.cc: Likewise.
966 * testsuite/std/ranges/adaptors/drop.cc: Likewise.
967 * testsuite/std/ranges/adaptors/drop_while.cc: Likewise.
968 * testsuite/std/ranges/adaptors/elements.cc: Likewise.
969 * testsuite/std/ranges/adaptors/filter.cc: Likewise.
970 * testsuite/std/ranges/adaptors/join.cc: Likewise.
971 * testsuite/std/ranges/adaptors/reverse.cc: Likewise.
972 * testsuite/std/ranges/adaptors/split.cc: Likewise.
973 * testsuite/std/ranges/adaptors/take.cc: Likewise.
974 * testsuite/std/ranges/adaptors/take_while.cc: Likewise.
975 * testsuite/std/ranges/adaptors/transform.cc: Likewise.
976
5713834e
JW
9772020-02-07 Jonathan Wakely <jwakely@redhat.com>
978
0d57370c
JW
979 * libsupc++/compare (__cmp_cat::type): Define typedef for underlying
980 type of enumerations and comparison category types.
981 (__cmp_cat::_Ord, __cmp_cat::_Ncmp): Add underlying type.
982 (__cmp_cat::_Ncmp::unordered): Change value to 2.
983 (partial_ordering::_M_value, weak_ordering::_M_value)
984 (strong_ordering::_M_value): Change type to __cmp_cat::type.
985 (partial_ordering::_M_is_ordered): Remove data member.
986 (partial_ordering): Use second bit of _M_value for unordered. Adjust
987 comparison operators.
988 (weak_ordering::operator partial_ordering): Simplify to remove
989 branches.
990 (operator<=>(unspecified, weak_ordering)): Likewise.
991 (strong_ordering::operator partial_ordering): Likewise.
992 (strong_ordering::operator weak_ordering): Likewise.
993 (operator<=>(unspecified, strong_ordering)): Likewise.
994 * testsuite/18_support/comparisons/categories/partialord.cc: New test.
995 * testsuite/18_support/comparisons/categories/strongord.cc: New test.
996 * testsuite/18_support/comparisons/categories/weakord.cc: New test.
997
5713834e
JW
998 * include/std/ranges (iota_view::_Iterator): Fix typo in name of
999 __cpp_lib_three_way_comparison macro and use deduced return type for
1000 operator<=>.
1001 * testsuite/std/ranges/iota/iterator.cc: New test.
1002
bc464641
PP
10032020-02-07 Patrick Palka <ppalka@redhat.com>
1004 Jonathan Wakely <jwakely@redhat.com>
1005
1006 Implement C++20 constrained algorithms
1007 * include/Makefile.am: Add new header.
1008 * include/Makefile.in: Regenerate.
1009 * include/std/algorithm: Include <bits/ranges_algo.h>.
1010 * include/bits/ranges_algo.h: New file.
1011 * testsuite/25_algorithms/adjacent_find/constrained.cc: New test.
1012 * testsuite/25_algorithms/all_of/constrained.cc: New test.
1013 * testsuite/25_algorithms/any_of/constrained.cc: New test.
1014 * testsuite/25_algorithms/binary_search/constrained.cc: New test.
1015 * testsuite/25_algorithms/copy/constrained.cc: New test.
1016 * testsuite/25_algorithms/copy_backward/constrained.cc: New test.
1017 * testsuite/25_algorithms/copy_if/constrained.cc: New test.
1018 * testsuite/25_algorithms/copy_n/constrained.cc: New test.
1019 * testsuite/25_algorithms/count/constrained.cc: New test.
1020 * testsuite/25_algorithms/count_if/constrained.cc: New test.
1021 * testsuite/25_algorithms/equal/constrained.cc: New test.
1022 * testsuite/25_algorithms/equal_range/constrained.cc: New test.
1023 * testsuite/25_algorithms/fill/constrained.cc: New test.
1024 * testsuite/25_algorithms/fill_n/constrained.cc: New test.
1025 * testsuite/25_algorithms/find/constrained.cc: New test.
1026 * testsuite/25_algorithms/find_end/constrained.cc: New test.
1027 * testsuite/25_algorithms/find_first_of/constrained.cc: New test.
1028 * testsuite/25_algorithms/find_if/constrained.cc: New test.
1029 * testsuite/25_algorithms/find_if_not/constrained.cc: New test.
1030 * testsuite/25_algorithms/for_each/constrained.cc: New test.
1031 * testsuite/25_algorithms/generate/constrained.cc: New test.
1032 * testsuite/25_algorithms/generate_n/constrained.cc: New test.
1033 * testsuite/25_algorithms/heap/constrained.cc: New test.
1034 * testsuite/25_algorithms/includes/constrained.cc: New test.
1035 * testsuite/25_algorithms/inplace_merge/constrained.cc: New test.
1036 * testsuite/25_algorithms/is_partitioned/constrained.cc: New test.
1037 * testsuite/25_algorithms/is_permutation/constrained.cc: New test.
1038 * testsuite/25_algorithms/is_sorted/constrained.cc: New test.
1039 * testsuite/25_algorithms/is_sorted_until/constrained.cc: New test.
1040 * testsuite/25_algorithms/lexicographical_compare/constrained.cc: New
1041 test.
1042 * testsuite/25_algorithms/lower_bound/constrained.cc: New test.
1043 * testsuite/25_algorithms/max/constrained.cc: New test.
1044 * testsuite/25_algorithms/max_element/constrained.cc: New test.
1045 * testsuite/25_algorithms/merge/constrained.cc: New test.
1046 * testsuite/25_algorithms/min/constrained.cc: New test.
1047 * testsuite/25_algorithms/min_element/constrained.cc: New test.
1048 * testsuite/25_algorithms/minmax/constrained.cc: New test.
1049 * testsuite/25_algorithms/minmax_element/constrained.cc: New test.
1050 * testsuite/25_algorithms/mismatch/constrained.cc: New test.
1051 * testsuite/25_algorithms/move/constrained.cc: New test.
1052 * testsuite/25_algorithms/move_backward/constrained.cc: New test.
1053 * testsuite/25_algorithms/next_permutation/constrained.cc: New test.
1054 * testsuite/25_algorithms/none_of/constrained.cc: New test.
1055 * testsuite/25_algorithms/nth_element/constrained.cc: New test.
1056 * testsuite/25_algorithms/partial_sort/constrained.cc: New test.
1057 * testsuite/25_algorithms/partial_sort_copy/constrained.cc: New test.
1058 * testsuite/25_algorithms/partition/constrained.cc: New test.
1059 * testsuite/25_algorithms/partition_copy/constrained.cc: New test.
1060 * testsuite/25_algorithms/partition_point/constrained.cc: New test.
1061 * testsuite/25_algorithms/prev_permutation/constrained.cc: New test.
1062 * testsuite/25_algorithms/remove/constrained.cc: New test.
1063 * testsuite/25_algorithms/remove_copy/constrained.cc: New test.
1064 * testsuite/25_algorithms/remove_copy_if/constrained.cc: New test.
1065 * testsuite/25_algorithms/remove_if/constrained.cc: New test.
1066 * testsuite/25_algorithms/replace/constrained.cc: New test.
1067 * testsuite/25_algorithms/replace_copy/constrained.cc: New test.
1068 * testsuite/25_algorithms/replace_copy_if/constrained.cc: New test.
1069 * testsuite/25_algorithms/replace_if/constrained.cc: New test.
1070 * testsuite/25_algorithms/reverse/constrained.cc: New test.
1071 * testsuite/25_algorithms/reverse_copy/constrained.cc: New test.
1072 * testsuite/25_algorithms/rotate/constrained.cc: New test.
1073 * testsuite/25_algorithms/rotate_copy/constrained.cc: New test.
1074 * testsuite/25_algorithms/search/constrained.cc: New test.
1075 * testsuite/25_algorithms/search_n/constrained.cc: New test.
1076 * testsuite/25_algorithms/set_difference/constrained.cc: New test.
1077 * testsuite/25_algorithms/set_intersection/constrained.cc: New test.
1078 * testsuite/25_algorithms/set_symmetric_difference/constrained.cc: New
1079 test.
1080 * testsuite/25_algorithms/set_union/constrained.cc: New test.
1081 * testsuite/25_algorithms/shuffle/constrained.cc: New test.
1082 * testsuite/25_algorithms/sort/constrained.cc: New test.
1083 * testsuite/25_algorithms/stable_partition/constrained.cc: New test.
1084 * testsuite/25_algorithms/stable_sort/constrained.cc: New test.
1085 * testsuite/25_algorithms/swap_ranges/constrained.cc: New test.
1086 * testsuite/25_algorithms/transform/constrained.cc: New test.
1087 * testsuite/25_algorithms/unique/constrained.cc: New test.
1088 * testsuite/25_algorithms/unique_copy/constrained.cc: New test.
1089 * testsuite/25_algorithms/upper_bound/constrained.cc: New test.
1090
d1aa7705
JW
10912020-02-06 Jonathan Wakely <jwakely@redhat.com>
1092
bd630df0
JW
1093 * include/bits/stl_iterator.h (__detail::__common_iter_ptr): Fix PR
1094 number in comment. Fix indentation.
1095
d1aa7705
JW
1096 * include/bits/stl_algobase.h (__iter_swap, __iter_swap<true>): Remove
1097 redundant _GLIBCXX20_CONSTEXPR.
1098
26eae9ac
JW
1099 * include/std/ranges (viewable_range): Replace decay_t with
1100 remove_cvref_t (LWG 3375).
1101
269e8130
JW
11022020-02-05 Jonathan Wakely <jwakely@redhat.com>
1103
1104 * include/bits/iterator_concepts.h (iter_reference_t)
1105 (iter_rvalue_reference_t, iter_common_reference_t, indirect_result_t):
1106 Remove workarounds for PR c++/67704.
1107 * testsuite/24_iterators/aliases.cc: New test.
1108
7db12d15
PP
11092020-02-05 Patrick Palka <ppalka@redhat.com>
1110
1111 * include/bits/stl_iterator.h (move_iterator::move_iterator): Move __i
1112 when initializing _M_current.
1113 (move_iterator::base): Split into two overloads differing in
1114 ref-qualifiers as in P1207R4 for C++20.
1115
9962493c
JW
11162020-02-04 Jonathan Wakely <jwakely@redhat.com>
1117
9bc5bea1
JW
1118 * include/std/functional (_GLIBCXX_NOT_FN_CALL_OP): Un-define after
1119 use.
1120
9962493c
JW
1121 PR libstdc++/93562
1122 * include/bits/unique_ptr.h (__uniq_ptr_impl::swap): Define.
1123 (unique_ptr::swap, unique_ptr<T[], D>::swap): Call it.
1124 * testsuite/20_util/unique_ptr/modifiers/93562.cc: New test.
1125
20fa702b
AB
11262020-02-01 Andrew Burgess <andrew.burgess@embecosm.com>
1127
1128 * configure: Regenerate.
1129
6e5a1963
PP
11302020-01-31 Patrick Palka <ppalka@redhat.com>
1131
1132 * testsuite/24_iterators/range_operations/distance.cc: Do not assume
1133 test_range::end() returns the same type as test_range::begin().
1134 * testsuite/24_iterators/range_operations/next.cc: Likewise.
1135 * testsuite/24_iterators/range_operations/prev.cc: Likewise.
1136 * testsuite/util/testsuite_iterators.h (__gnu_test::test_range::end):
1137 Always return a sentinel<I>.
1138
5cd2e126
JW
11392020-01-29 Jonathan Wakely <jwakely@redhat.com>
1140
0a8f4feb
JW
1141 PR libstdc++/92895
1142 * include/std/stop_token (stop_token::stop_possible()): Call new
1143 _M_stop_possible() function.
1144 (stop_token::stop_requested()): Do not use stop_possible().
1145 (stop_token::binary_semaphore): New class, as temporary stand-in for
1146 std::binary_semaphore.
1147 (stop_token::_Stop_cb::_M_callback): Add noexcept to type.
1148 (stop_token::_Stop_cb::_M_destroyed, stop_token::_Stop_cb::_M_done):
1149 New data members for symchronization with stop_callback destruction.
1150 (stop_token::_Stop_cb::_Stop_cb): Make non-template.
1151 (stop_token::_Stop_cb::_M_linked, stop_token::_Stop_cb::_S_execute):
1152 Remove.
1153 (stop_token::_Stop_cb::_M_run): New member function.
1154 (stop_token::_Stop_state::_M_stopped, stop_token::_Stop_state::_M_mtx):
1155 Remove.
1156 (stop_token::_Stop_state::_M_owners): New data member to track
1157 reference count for ownership.
1158 (stop_token::_Stop_state::_M_value): New data member combining a
1159 spinlock, the stop requested flag, and the reference count for
1160 associated stop_source objects.
1161 (stop_token::_Stop_state::_M_requester): New data member for
1162 synchronization with stop_callback destruction.
1163 (stop_token::_Stop_state::_M_stop_possible()): New member function.
1164 (stop_token::_Stop_state::_M_stop_requested()): Inspect relevant bit
1165 of _M_value.
1166 (stop_token::_Stop_state::_M_add_owner)
1167 (stop_token::_Stop_state::_M_release_ownership)
1168 (stop_token::_Stop_state::_M_add_ssrc)
1169 (stop_token::_Stop_state::_M_sub_ssrc): New member functions for
1170 updating reference counts.
1171 (stop_token::_Stop_state::_M_lock, stop_token::_Stop_state::_M_unlock)
1172 (stop_token::_Stop_state::_M_lock, stop_token::_Stop_state::_M_unlock)
1173 (stop_token::_Stop_state::_M_try_lock)
1174 (stop_token::_Stop_state::_M_try_lock_and_stop)
1175 (stop_token::_Stop_state::_M_do_try_lock): New member functions for
1176 managing spinlock.
1177 (stop_token::_Stop_state::_M_request_stop): Use atomic operations to
1178 read and update state. Release lock while running callbacks. Use new
1179 data members to synchronize with callback destruction.
1180 (stop_token::_Stop_state::_M_remove_callback): Likewise.
1181 (stop_token::_Stop_state::_M_register_callback): Use atomic operations
1182 to read and update state.
1183 (stop_token::_Stop_state_ref): Handle type to manage _Stop_state,
1184 replacing shared_ptr.
1185 (stop_source::stop_source(const stop_source&)): Update reference count.
1186 (stop_source::operator=(const stop_source&)): Likewise.
1187 (stop_source::~stop_source()): Likewise.
1188 (stop_source::stop_source(stop_source&&)): Define as defaulted.
1189 (stop_source::operator=(stop_source&&)): Establish postcondition on
1190 parameter.
1191 (stop_callback): Enforce preconditions on template parameter. Replace
1192 base class with data member of new _Cb_impl type.
1193 (stop_callback::stop_callback(const stop_token&, Cb&&))
1194 (stop_callback::stop_callback(stop_token&&, Cb&&)): Fix TOCTTOU race.
1195 (stop_callback::_Cb_impl): New type wrapping _Callback member and
1196 defining the _S_execute member function.
1197 * testsuite/30_threads/stop_token/stop_callback/deadlock-mt.cc: New
1198 test.
1199 * testsuite/30_threads/stop_token/stop_callback/deadlock.cc: New test.
1200 * testsuite/30_threads/stop_token/stop_callback/destroy.cc: New test.
1201 * testsuite/30_threads/stop_token/stop_callback/destructible_neg.cc:
1202 New test.
1203 * testsuite/30_threads/stop_token/stop_callback/invocable_neg.cc: New
1204 test.
1205 * testsuite/30_threads/stop_token/stop_callback/invoke.cc: New test.
1206 * testsuite/30_threads/stop_token/stop_source/assign.cc: New test.
1207 * testsuite/30_threads/stop_token/stop_token/stop_possible.cc: New
1208 test.
1209
f214ffb3
JW
1210 * libsupc++/compare (__detail::__3way_builtin_ptr_cmp): Use
1211 three_way_comparable_with.
1212 (__detail::__3way_cmp_with): Remove workaround for fixed bug.
1213 (compare_three_way::operator()): Remove redundant constraint from
1214 requires-clause.
1215 (__detail::_Synth3way::operator()): Use three_way_comparable_with
1216 instead of workaround.
1217 * testsuite/18_support/comparisons/object/93479.cc: Prune extra
1218 output due to simplified constraints on compare_three_way::operator().
1219
83b02010
JW
1220 PR libstdc++/93479
1221 * libsupc++/compare (__3way_builtin_ptr_cmp): Require <=> to be valid.
1222 * testsuite/18_support/comparisons/object/93479.cc: New test.
1223
5cd2e126
JW
1224 * testsuite/std/ranges/access/end.cc: Do not assume test_range::end()
1225 returns the same type as test_range::begin(). Add comments.
1226 * testsuite/std/ranges/access/rbegin.cc: Likewise.
1227 * testsuite/std/ranges/access/rend.cc: Likewise.
1228 * testsuite/std/ranges/range.cc: Do not assume the sentinel for
1229 test_range is the same as its iterator type.
1230 * testsuite/util/testsuite_iterators.h (test_range::sentinel): Add
1231 operator- overloads to satisfy sized_sentinel_for when the iterator
1232 satisfies random_access_iterator.
1233
759812fd
JW
12342020-01-28 Jonathan Wakely <jwakely@redhat.com>
1235
72a9fd20
JW
1236 PR libstdc++/93470
1237 * include/bits/refwrap.h (reference_wrapper::operator()): Restrict
1238 static assertion to object types.
1239
759812fd
JW
1240 PR libstdc++/93325
1241 * acinclude.m4 (GLIBCXX_ENABLE_LIBSTDCXX_TIME): Use AC_SEARCH_LIBS for
1242 clock_gettime instead of explicit glibc version check.
1243 * configure: Regenerate.
1244
a5d81aaa
JW
12452020-01-28 Martin Liska <mliska@suse.cz>
1246
1247 PR libstdc++/93478
1248 * include/std/atomic: Fix typo.
1249 * include/std/optional: Likewise.
1250
12512020-01-27 Andrew Burgess <andrew.burgess@embecosm.com>
1252
1253 * configure: Regenerate.
1254
389cd88c
JW
12552020-01-27 Jonathan Wakely <jwakely@redhat.com>
1256
1257 PR libstdc++/93426
1258 * include/std/span (span): Fix deduction guide.
1259 * testsuite/23_containers/span/deduction.cc: New test.
1260
482eeff5
JW
12612020-01-24 Jonathan Wakely <jwakely@redhat.com>
1262
1263 * libsupc++/compare (__cmp_cat::_Eq): Remove enumeration type.
1264 (__cmp_cat::_Ord::equivalent): Add enumerator.
1265 (__cmp_cat::_Ord::_Less, __cmp_cat::_Ord::_Greater): Rename to less
1266 and greater.
1267 (partial_ordering, weak_ordering, strong_ordering): Remove
1268 constructors taking __cmp_cat::_Eq parameters. Use renamed
1269 enumerators.
1270
e8e66971
MR
12712020-01-24 Maciej W. Rozycki <macro@wdc.com>
1272
1273 * acinclude.m4: Handle `--with-toolexeclibdir='.
1274 * Makefile.in: Regenerate.
1275 * aclocal.m4: Regenerate.
1276 * configure: Regenerate.
1277 * doc/Makefile.in: Regenerate.
1278 * include/Makefile.in: Regenerate.
1279 * libsupc++/Makefile.in: Regenerate.
1280 * po/Makefile.in: Regenerate.
1281 * python/Makefile.in: Regenerate.
1282 * src/Makefile.in: Regenerate.
1283 * src/c++11/Makefile.in: Regenerate.
1284 * src/c++17/Makefile.in: Regenerate.
1285 * src/c++98/Makefile.in: Regenerate.
1286 * src/filesystem/Makefile.in: Regenerate.
1287 * testsuite/Makefile.in: Regenerate.
1288
7a900bce
AO
12892020-01-23 Alexandre Oliva <oliva@adacore.com>
1290
f9e84b31
AO
1291 * crossconfig.m4 (GLIBCXX_CHECK_MATH_DECL): Reject macros.
1292 * configure: Rebuild.
1293
7a900bce
AO
1294 * testsuite/27_io/fpos/mbstate_t/1.cc: Zero-init mbstate_t.
1295
04681fca
JW
12962020-01-23 Jonathan Wakely <jwakely@redhat.com>
1297
1298 PR libstdc++/91947
1299 * include/Makefile.am (${host_builddir}/largefile-config.h): Simplify
1300 rule.
1301 * include/Makefile.in: Regenerate.
1302
c784f162
JW
13032020-01-20 Jonathan Wakely <jwakely@redhat.com>
1304
1305 * doc/xml/faq.xml: Fix grammar.
1306 * doc/xml/manual/appendix_contributing.xml: Improve instructions.
1307 * doc/xml/manual/spine.xml: Update copyright years.
1308 * doc/html/*: Regenerate.
1309
f4d83eba
ER
13102020-01-19 Eric S. Raymond <esr@thyrsus.com>
1311
1312 * doc/xml/faq.xml: Update for SVN -> Git transition.
1313 * doc/xml/manual/appendix_contributing.xml: Likewise.
1314 * doc/xml/manual/status_cxx1998.xml: Likewise.
1315 * doc/xml/manual/status_cxx2011.xml: Likewise.
1316 * doc/xml/manual/status_cxx2014.xml: Likewise.
1317 * doc/xml/manual/status_cxx2017.xml: Likewise.
1318 * doc/xml/manual/status_cxx2020.xml: Likewise.
1319 * doc/xml/manual/status_cxxtr1.xml: Likewise.
1320 * doc/xml/manual/status_cxxtr24733.xml: Likewise.
1321
49789fd0
IS
13222020-01-18 Iain Sandoe <iain@sandoe.co.uk>
1323
1324 * include/Makefile.am: Add coroutine to the std set.
1325 * include/Makefile.in: Regenerated.
1326 * include/std/coroutine: New file.
1327
0ba6a850
JW
13282020-01-17 Jonathan Wakely <jwakely@redhat.com>
1329
1330 PR libstdc++/92376
1331 * include/bits/c++config: Only do PSTL config when the header is
1332 present, to fix freestanding.
1333 * libsupc++/new_opa.cc [!_GLIBCXX_HOSTED]: Declare allocation
1334 functions if they were detected by configure.
1335
98d56ea8
JW
13362020-01-16 Kai-Uwe Eckhardt <kuehro@gmx.de>
1337 Matthew Bauer <mjbauer95@gmail.com>
1338 Jonathan Wakely <jwakely@redhat.com>
1339
1340 PR bootstrap/64271 (partial)
1341 * config/os/bsd/netbsd/ctype_base.h (ctype_base::mask): Change type
1342 to unsigned short.
1343 (ctype_base::alpha, ctype_base::digit, ctype_base::xdigit)
1344 (ctype_base::print, ctype_base::graph, ctype_base::alnum): Sync
1345 definitions with NetBSD upstream.
1346 (ctype_base::blank): Use _CTYPE_BL.
1347 * config/os/bsd/netbsd/ctype_configure_char.cc (_C_ctype_): Remove
1348 Declaration.
1349 (ctype<char>::classic_table): Use _C_ctype_tab_ instead of _C_ctype_.
1350 (ctype<char>::do_toupper, ctype<char>::do_tolower): Cast char
1351 parameters to unsigned char.
1352 * config/os/bsd/netbsd/ctype_inline.h (ctype<char>::is): Likewise.
1353
d9165389
FD
13542020-01-16 François Dumont <fdumont@gcc.gnu.org>
1355
1356 PR libstdc++/91263
1357 * include/bits/hashtable.h (_Hashtable<>): Make _Equality<> friend.
1358 * include/bits/hashtable_policy.h: Include <bits/stl_algo.h>.
1359 (_Equality_base): Remove.
1360 (_Equality<>::_M_equal): Review implementation. Use
1361 std::is_permutation.
1362 * testsuite/23_containers/unordered_multiset/operators/1.cc
1363 (Hash, Equal, test02, test03): New.
1364 * testsuite/23_containers/unordered_set/operators/1.cc
1365 (Hash, Equal, test02, test03): New.
1366
2a0f6c61
JW
13672020-01-15 Jonathan Wakely <jwakely@redhat.com>
1368
1369 PR libstdc++/93267
1370 * include/bits/iterator_concepts.h (__max_diff_type, __max_size_type):
1371 Move here from <bits/range_access.h> and define using __int128 when
1372 available.
1373 (__is_integer_like, __is_signed_integer_like): Move here from
1374 <bits/range_access.h>.
1375 (weakly_incrementable): Use __is_signed_integer_like.
1376 * include/bits/range_access.h (__max_diff_type, __max_size_type)
1377 (__is_integer_like, __is_signed_integer_like): Move to
1378 <bits/iterator_concepts.h>.
1379 (__make_unsigned_like_t): Move here from <ranges>.
1380 * include/std/ranges (__make_unsigned_like_t): Move to
1381 <bits/range_access.h>.
1382 (iota_view): Replace using-directive with using-declarations.
1383 * testsuite/std/ranges/iota/93267.cc: New test.
1384 * testsuite/std/ranges/iota_view.cc: Move to new 'iota' sub-directory.
1385
e4379a93
JW
13862020-01-13 Jonathan Wakely <jwakely@redhat.com>
1387
fe7cc34f
JW
1388 PR libstdc++/93244
1389 * include/bits/fs_path.h (path::generic_string<C,A>)
1390 [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Convert root-dir to forward-slash.
1391 * testsuite/27_io/filesystem/path/generic/generic_string.cc: Check
1392 root-dir is converted to forward slash in generic pathname.
1393 * testsuite/27_io/filesystem/path/generic/utf.cc: New test.
1394 * testsuite/27_io/filesystem/path/generic/wchar_t.cc: New test.
1395
e4379a93
JW
1396 PR libstdc++/58605
1397 * include/bits/atomic_base.h (__cpp_lib_atomic_value_initialization):
1398 Define.
1399 (__atomic_flag_base, __atomic_base, __atomic_base<_PTp*>)
1400 (__atomic_float): Add default member initializer for C++20.
1401 * include/std/atomic (atomic): Likewise.
1402 (atomic::atomic()): Remove noexcept-specifier on default constructor.
1403 * include/std/version (__cpp_lib_atomic_value_initialization): Define.
1404 * testsuite/29_atomics/atomic/cons/assign_neg.cc: Adjust dg-error line
1405 number.
1406 * testsuite/29_atomics/atomic/cons/copy_neg.cc: Likewise.
1407 * testsuite/29_atomics/atomic/cons/value_init.cc: New test.
1408 * testsuite/29_atomics/atomic_flag/cons/value_init.cc: New test.
1409 * testsuite/29_atomics/atomic_flag/requirements/trivial.cc: Adjust
1410 expected result for is_trivially_default_constructible.
1411 * testsuite/29_atomics/atomic_float/requirements.cc: Likewise.
1412 * testsuite/29_atomics/atomic_float/value_init.cc: New test.
1413 * testsuite/29_atomics/atomic_integral/cons/assign_neg.cc: Likewise.
1414 * testsuite/29_atomics/atomic_integral/cons/copy_neg.cc: Likewise.
1415 * testsuite/29_atomics/atomic_integral/cons/value_init.cc
1416 * testsuite/29_atomics/atomic_integral/requirements/trivial.cc: Adjust
1417 expected results for is_trivially_default_constructible.
1418 * testsuite/util/testsuite_common_types.h (has_trivial_dtor): Add
1419 new test generator.
1420
7918cb93
JW
14212020-01-10 Jonathan Wakely <jwakely@redhat.com>
1422
68be73fc
JW
1423 * testsuite/util/testsuite_iterators.h: Improve comment.
1424
78f02e80
JW
1425 * testsuite/25_algorithms/equal/deque_iterators/1.cc: Don't use C++11
1426 initialization syntax.
1427
7918cb93
JW
1428 PR libstdc++/92285
1429 * include/bits/streambuf_iterator.h (istreambuf_iterator): Make type
1430 of base class independent of __cplusplus value.
1431 [__cplusplus < 201103L] (istreambuf_iterator::reference): Override the
1432 type defined in the base class
1433 * testsuite/24_iterators/istreambuf_iterator/92285.cc: New test.
1434 * testsuite/24_iterators/istreambuf_iterator/requirements/
1435 base_classes.cc: Adjust expected base class for C++98.
1436
acd43917
OH
14372020-01-09 Olivier Hainque <hainque@adacore.com>
1438
1439 * doc/xml/manual/appendix_contributing.xml: Document _C2
1440 as a reserved identifier, by VxWorks.
1441 * include/bits/stl_map.h: Rename _C2 template typenames as _Cmp2.
1442 * include/bits/stl_multimap.h: Likewise.
1443
caa39b2e
JW
14442020-01-09 Jonathan Wakely <jwakely@redhat.com>
1445
1a788638
JW
1446 * include/ext/extptr_allocator.h (_ExtPtr_allocator::operator==)
1447 (_ExtPtr_allocator::operator!=): Add missing const qualifiers.
1448 * include/ext/pointer.h (readable_traits<_Pointer_adapter<S>>): Add
1449 partial specialization to disambiguate the two constrained
1450 specializations.
1451
caa39b2e
JW
1452 * include/experimental/type_traits (experimental::is_pod_v): Disable
1453 -Wdeprecated-declarations warnings around reference to std::is_pod.
1454 * include/std/type_traits (is_pod_v): Likewise.
1455 * testsuite/18_support/max_align_t/requirements/2.cc: Also check
1456 is_standard_layout and is_trivial. Do not check is_pod for C++20.
1457 * testsuite/20_util/is_pod/requirements/explicit_instantiation.cc:
1458 Add -Wno-deprecated for C++20.
1459 * testsuite/20_util/is_pod/requirements/typedefs.cc: Likewise.
1460 * testsuite/20_util/is_pod/value.cc: Likewise.
1461 * testsuite/experimental/type_traits/value.cc: Likewise.
1462
1a6c5064
JTM
14632020-01-09 JeanHeyd "ThePhD" Meneide <phdofthehouse@gmail.com>
1464
1465 * include/bits/c++config (_GLIBCXX20_DEPRECATED): Add new macro.
1466 * include/std/type_traits (is_pod, is_pod_v): Deprecate for C++20.
1467 * testuite/20_util/is_pod/deprecated-2a.cc: New test.
1468
d574c8aa
JW
14692020-01-09 Jonathan Wakely <jwakely@redhat.com>
1470
160e95dc
JW
1471 PR libstdc++/93205
1472 * include/bits/random.h (operator>>): Check stream operation succeeds.
1473 * include/bits/random.tcc (operator<<): Remove redundant __ostream_type
1474 typedefs.
1475 (operator>>): Remove redundant __istream_type typedefs. Check stream
1476 operations succeed.
1477 (__extract_params): New function to fill a vector from a stream.
1478 * testsuite/26_numerics/random/pr60037-neg.cc: Adjust dg-error line.
1479
d574c8aa
JW
1480 PR libstdc++/93208
1481 * config/abi/pre/gnu.ver: Add new exports.
1482 * include/std/memory_resource (memory_resource::~memory_resource()):
1483 Do not define inline.
1484 (monotonic_buffer_resource::~monotonic_buffer_resource()): Likewise.
1485 * src/c++17/memory_resource.cc (memory_resource::~memory_resource()):
1486 Define.
1487 (monotonic_buffer_resource::~monotonic_buffer_resource()): Define.
1488 * testsuite/20_util/monotonic_buffer_resource/93208.cc: New test.
1489
b9c84e95
FD
14902020-01-09 François Dumont <fdumont@gcc.gnu.org>
1491
1492 PR libstdc++/92124
1493 * include/bits/hashtable.h (_Hashtable<>::__alloc_node_gen_t): New
1494 template alias.
1495 (_Hashtable<>::__fwd_value_for): New.
1496 (_Hashtable<>::_M_assign_elements<>): Remove _NodeGenerator template
1497 parameter.
1498 (_Hashtable<>::_M_assign<>): Add _Ht template parameter.
1499 (_Hashtable<>::operator=(const _Hashtable<>&)): Adapt.
1500 (_Hashtable<>::_M_move_assign): Adapt. Replace std::move_if_noexcept
1501 with std::move.
1502 (_Hashtable<>::_Hashtable(const _Hashtable&)): Adapt.
1503 (_Hashtable<>::_Hashtable(const _Hashtable&, const allocator_type&)):
1504 Adapt.
1505 (_Hashtable<>::_Hashtable(_Hashtable&&, const allocator_type&)):
1506 Adapt.
1507 * testsuite/23_containers/unordered_set/92124.cc: New.
1508
fff148b7
JW
15092020-01-08 Jonathan Wakely <jwakely@redhat.com>
1510
1511 PR libstdc++/93201
1512 * src/c++17/fs_ops.cc (do_remove_all): New function implementing more
1513 detailed error reporting for remove_all. Check result of recursive
1514 call before incrementing iterator.
1515 (remove_all(const path&), remove_all(const path&, error_code&)): Use
1516 do_remove_all.
1517 * src/filesystem/ops.cc (remove_all(const path&, error_code&)): Check
1518 result of recursive call before incrementing iterator.
1519 * testsuite/27_io/filesystem/operations/remove_all.cc: Check errors
1520 are reported correctly.
1521 * testsuite/experimental/filesystem/operations/remove_all.cc: Likewise.
1522
9e3c1eb7
TR
15232020-01-07 Thomas Rodgers <trodgers@redhat.com>
1524
1525 * include/std/condition_variable
1526 (condition_variable_any::wait_on): Rename to match current draft
1527 standard.
1528 (condition_variable_any::wait_on_until): Likewise.
1529 (condition_variable_any::wait_on_for): Likewise.
1530 * testsuite/30_threads/condition_variable_any/stop_token/wait_on.cc:
1531 Adjust tests to account for renamed methods.
1532
6af8819b
FD
15332020-01-07 François Dumont <fdumont@gcc.gnu.org>
1534
1535 PR libstdc++/92124
1536 * include/bits/stl_tree.h
1537 (_Rb_tree<>::_M_move_assign(_Rb_tree&, false_type)): Replace
1538 std::move_if_noexcept by std::move.
1539 * testsuite/23_containers/map/92124.cc: New.
1540 * testsuite/23_containers/set/92124.cc: New.
1541
f31a99f7
JW
15422020-01-06 Jonathan Wakely <jwakely@redhat.com>
1543
a4a1f965
JW
1544 * include/std/stop_token (stop_token): Remove operator!= (LWG 3254).
1545 (stop_source): Likewise (LWG 3362).
1546 * testsuite/30_threads/stop_token/stop_source.cc: Test equality
1547 comparisons.
1548
f31a99f7
JW
1549 * include/bits/stl_algobase.h (__is_byte_iter, __min_cmp)
1550 (lexicographical_compare_three_way): Do not depend on
1551 __cpp_lib_concepts.
1552 * include/std/version (__cpp_lib_three_way_comparison): Only define
1553 when __cpp_lib_concepts is defined.
1554 * libsupc++/compare (__cpp_lib_three_way_comparison): Likewise.
1555
b4e70137
JW
15562020-01-03 Jonathan Wakely <jwakely@redhat.com>
1557
1558 * include/bits/stl_algobase.h (lexicographical_compare_three_way):
1559 Only define four-argument overload when __cpp_lib_concepts is defined.
1560
a8497ec6
JDA
15612020-01-01 John David Anglin <danglin@gcc.gnu.org>
1562
1563 * config/abi/post/hppa-linux-gnu/baseline_symbols.txt: Update.
1564
8d9254fc 15652020-01-01 Jakub Jelinek <jakub@redhat.com>
5624e564
JJ
1566
1567 Update copyright years.
b4df5e92 1568\f
8d9254fc 1569Copyright (C) 2020 Free Software Foundation, Inc.
b4df5e92
JW
1570
1571Copying and distribution of this file, with or without modification,
1572are permitted in any medium without royalty provided the copyright
1573notice and this notice are preserved.