VOOZH about

URL: https://qiita.com/kaizen_nagoya/items/d47c8f1ff8da96ad1fc7

⇱ 27.8 Sorting and related operations [alg.sorting] C++N4910:2022 (662) p1223.cpp #小川メソッド - Qiita


👁 Image
0

Go to list of users who liked

1

Share on X(Twitter)

Share on Facebook

Add to Hatena Bookmark

More than 1 year has passed since last update.

@kaizen_nagoya(Dr. Kiyoshi Ogawa)

27.8 Sorting and related operations [alg.sorting] C++N4910:2022 (662) p1223.cpp

0
Last updated at Posted at 2022-08-15

はじめに(Introduction)

N4910 Working Draft, Standard for Programming Language C++
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2022/n4910.pdf

n4910は、ISO/IEC JTC1 SC22 WG21の作業原案(Working Draft)です。
公式のISO/IEC 14882原本ではありません。
ISO/IEC JTC1 SC22 WG21では、可能な限り作業文書を公開し、幅広い意見を求めています。
一連の記事はコード断片をコンパイルできる形にする方法を検討してコンパイル、リンク、実行して、規格案の原文と処理系(g++, Clang++)との違いを確認し、技術内容を検討し、ISO/IEC JTC1 SC22 WG21にフィードバックするために用います。
また、CERT C++, MISRA C++等のコーディング標準のコード断片をコンパイルする際の参考にさせていただこうと考えています。CERT C++, MISRA C++が標準化の動きとの時間的なずれがあれば確認できれば幸いです。また、boostライブラリとの関連、Linux OS, TOPPERSカーネル、g++(GCC), clang++(LLVM)との関係も調査中です。
何か、抜け漏れ、耳より情報がありましたらおしらせくださると幸いです。

<この項は書きかけです。順次追記します。>

背景(back ground)

C/C++でコンパイルエラーが出ると、途方にくれることがしばしばあります。
何回かに1回は、該当するエラーが検索できます。
ただ、条件が違っていて、そこでの修正方法では目的を達成しないこともしばしばです。いろいろな条件のコンパイルエラーとその対応方法について、広く記録することによって、いつか同じエラーに遭遇した時にやくに立つことを目指しています。

この半年の間で、三度、自分のネットでの記録に助けられたことがあります。
また過去に解決できなかった記録を10種類以上、最近になって解決できたことがあります。それは、主に次の3つの情報に基づいています。

cpprefjp - C++日本語リファレンス

コンパイラの実装状況

また
https://researchmap.jp/joub9b3my-1797580/#_1797580
に記載したサイトのお世話になっています。

作業方針(sequence)

Clang++では-std=c++03, C++2bの2種類
g++では-std=c++03, c++2bの2種類
でコンパイルし、

1)コンパイルエラーを収集する。
2)コンパイルエラーをなくす方法を検討する。
コンパイルエラーになる例を示すだけが目的のコードは、コンパイルエラーをなくすのではなく、コンパイルエラーの種類を収集するだけにする。
文法を示すのが目的のコード場合に、コンパイルエラーをなくすのに手間がかかる場合は、順次作業します。
3)リンクエラーをなくす方法を検討する。
文法を示すのが目的のコード場合に、リンクエラーをなくすのに手間がかかる場合は、順次作業します。
4)意味のある出力を作る。
コンパイル、リンクが通っても、意味のある出力を示そうとすると、コンパイル・リンクエラーが出て収拾できそうにない場合がある。順次作業します。

1)だけのものから4)まで進んだものと色々ある状態です。一歩でも前に進むご助言をお待ちしています。「検討事項」の欄に現状を記録するようにしています。

C++N4910:2022 Standard Working Draft on ISO/IEC 14882(0) sample code compile list

C++N4741, 2018 Standard Working Draft on ISO/IEC 14882 sample code compile list

C++N4606, 2016符号断片編纂一覧(example code compile list)

C++N4606, 2016 Working Draft 2016, ISO/IEC 14882, C++ standard(1) Example code compile list
https://qiita.com/kaizen_nagoya/items/df5d62c35bd6ed1c3d43/

C++N3242, 2011 sample code compile list on clang++ and g++

編纂器(Compiler)

clang++ --version

Debian clang version 14.0.5-++20220610033153+c12386ae247c-1~exp1~20220610153237.151
Target: x86_64-pc-linux-gnu, Thread model: posix, InstalledDir: /usr/bin

g++- --version

g++ (GCC) 12.1.0 Copyright (C) 2022 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

27.8 Sorting and related operations [alg.sorting] C++N4910:2022 (662) p1223.cpp

算譜(source code)

p1223.cpp
// C++N4910 Committee Draft, Standard for Programming Language C++
// http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2022/n4910.pdf
const char * n4910 = "27.8 Sorting and related operations [alg.sorting] C++N4910:2022 (662) p1223.cpp";
// Debian clang version 14.0.5-++20220610033153+c12386ae247c-
// g++ (GCC) 12.1.0 Copyright (C) 2022 Free Software Foundation, Inc.
// Edited by Dr. OGAWA Kiyoshi. Compile procedure and results record.
// C++N4910:2022 Standard Working Draft on ISO/IEC 14882(0) sample code compile list
// https://qiita.com/kaizen_nagoya/items/fc957ddddd402004bb91

#include "N4910.h"
using namespace std;

#define R int
// 27.8.1 General [alg.sorting.general]
// The operations in 27.8 defined directly in namespace std have two versions: one that takes a function object of type Compare and one that uses an operator<.
// Compare is a function object type (22.10) that meets the requirements for a template parameter named BinaryPredicate (27.2). The return value of the function call operation applied to an object of type Compare, when contextually converted to bool (7.3), yields true if the first argument of the call is less than the second, and false otherwise. Compare comp is used throughout for algorithms assuming an ordering relation.
// For all algorithms that take Compare, there is a version that uses operator< instead. That is, comp(*i, *j) != false defaults to *i < *j != false. For algorithms other than those described in 27.8.4, comp shall induce a strict weak ordering on the values.
// The term strict refers to the requirement of an irreflexive relation (!comp(x, x) for all x), and the term weak to requirements that are not as strong as those for a total ordering, but stronger than those for a partial ordering. If we define equiv(a, b) as !comp(a, b) && !comp(b, a), then the requirements are that comp and equiv both be transitive relations:
// — equiv(a, b) && equiv(b, c) implies equiv(a, c) [Note 1: Under these conditions, it can be shown that
//— comp(a, b) && comp(b, c) implies comp(a, c)
// — equiv is an equivalence relation,
// — comp induces a well-defined relation on the equivalence classes determined by equiv, and — the induced relation is a strict total ordering.
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: For the overloads in namespace std, RandomAccessIterator meets the Cpp17Value- Swappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Sorts the elements in the range [first, last) with respect to comp and proj. Returns: last for the overloads in namespace ranges.
Complexity: Let N be last - first. O(N log N) comparisons and projections.
// A sequence is sorted with respect to a comp and proj for a comparator and projection comp and proj if for every iterator i pointing to the sequence and every non-negative integer n such that i + n is a valid iterator pointing to an element of the sequence,
 bool(invoke(comp, invoke(proj, *(i + n)), invoke(proj, *i)))
is false.
// A sequence [start, finish) is partitioned with respect to an expression f(e) if there exists an integer n such
thatforall0 <= i < (finish - start),f(*(start + i))istrueifandonlyifi < n.
// In the descriptions of the functions that deal with ordering relationships we frequently use a notion of equivalence to describe concepts such as stability. The equivalence to which we refer is not necessarily an operator==, but an equivalence relation induced by the strict weak ordering. That is, two elements a and b are considered equivalent if and only if !(a < b) && !(b < a).
// 27.8.2.1 sort
template<class RandomAccessIterator>
constexpr void sort(RandomAccessIterator first, RandomAccessIterator last);
template<class ExecutionPolicy, class RandomAccessIterator>
void sort(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void sort(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
void sort(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
[alg.sort] [sort]
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
// 27.8.2.2 stable_sort [stable.sort]
template<class RandomAccessIterator>
void stable_sort(RandomAccessIterator first, RandomAccessIterator last);
template<class ExecutionPolicy, class RandomAccessIterator>
void stable_sort(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
void stable_sort(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
void stable_sort(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
borrowed_iterator_t<R>
ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: For the overloads in namespace std, RandomAccessIterator meets the Cpp17Value- Swappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Sorts the elements in the range [first, last) with respect to comp and proj.
// Returns: last for the overloads in namespace ranges.
// Complexity: Let N be last - first. If enough extra memory is available, N log(N) comparisons. Otherwise, at most N log2(N) comparisons. In either case, twice as many projections as the number of comparisons.
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: [first, middle) and [middle, last) are valid ranges. For the overloads in namespace std, RandomAccessIterator meets the Cpp17ValueSwappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Remarks: Stable (16.4.6.8).
// 7.8.2.3 partial_sort [partial.sort]
template<class RandomAccessIterator>
constexpr void partial_sort(RandomAccessIterator first,
 RandomAccessIterator middle,
 RandomAccessIterator last);
template<class ExecutionPolicy, class RandomAccessIterator>
void partial_sort(ExecutionPolicy&& exec,
 RandomAccessIterator first,
 RandomAccessIterator middle,
 RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void partial_sort(RandomAccessIterator first,
 RandomAccessIterator middle,
 RandomAccessIterator last,
 Compare comp);
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
void partial_sort(ExecutionPolicy&& exec,
 RandomAccessIterator first,
 RandomAccessIterator middle,
 RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
// Effects: Places the first middle - first elements from the range [first, last) as sorted with respect to comp and proj into the range [first, middle). The rest of the elements in the range [middle, last) are placed in an unspecified order.
// Returns: last for the overload in namespace ranges.
// Complexity: Approximately (last - first) * log(middle - first) comparisons, and twice as many projections.
class Proj1 = identity, class Proj2 = identity>
 requires indirectly_copyable<iterator_t<R1>, iterator_t<R2>> &&
 sortable<iterator_t<R2>, Comp, Proj2> &&
 indirect_strict_weak_order<Comp, projected<iterator_t<R1>, Proj1>,
 projected<iterator_t<R2>, Proj2>>
 constexpr ranges::partial_sort_copy_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>>
 ranges::partial_sort_copy(R1&& r, R2&& result_r, Comp comp = {},
Proj1 proj1 = {}, Proj2 proj2 = {});
// Let N be min(last - first, result_last - result_first). Let comp be less{}, and proj1 and proj2 be identity{} for the overloads with no parameters by those names.
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
// Effects: Equivalent to:
return ranges::partial_sort(ranges::begin(r), middle, ranges::end(r), comp, proj);
// 27.8.2.4 partial_sort_copy [partial.sort.copy]
template<class InputIterator, class RandomAccessIterator>
constexpr RandomAccessIterator
partial_sort_copy(InputIterator first, InputIterator last,
 RandomAccessIterator result_first,
 RandomAccessIterator result_last);
template<class ExecutionPolicy, class ForwardIterator, class RandomAccessIterator>
RandomAccessIterator
partial_sort_copy(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 RandomAccessIterator result_first,
 RandomAccessIterator result_last);
template<class InputIterator, class RandomAccessIterator,
 class Compare>
constexpr RandomAccessIterator
partial_sort_copy(InputIterator first, InputIterator last,
 RandomAccessIterator result_first,
 RandomAccessIterator result_last,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator, class RandomAccessIterator,
 class Compare>
RandomAccessIterator
partial_sort_copy(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 RandomAccessIterator result_first,
 RandomAccessIterator result_last,
 Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, random_access_iterator I2, sentinel_for<I2> S2,
 class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
requires indirectly_copyable<I1, I2> && sortable<I2, Comp, Proj2> &&
indirect_strict_weak_order<Comp, projected<I1, Proj1>, projected<I2, Proj2>>
 constexpr ranges::partial_sort_copy_result<I1, I2>
 ranges::partial_sort_copy(I1 first, S1 last, I2 result_first, S2 result_last,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, random_access_range R2, class Comp = ranges::less,
// Mandates: For the overloads in namespace std, the expression *first is writable (25.3.1) to result_- first.
// Preconditions: For the overloads in namespace std, RandomAccessIterator meets the Cpp17Value- Swappable requirements (16.4.4.3), the type of *result_first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// For iterators a1 and b1 in [first, last), and iterators x2 and y2 in [result_first, result_last), after evaluating the assignment *y2 = *b1, let E be the value of
 bool(invoke(comp, invoke(proj1, *a1), invoke(proj2, *y2))).
// Then, after evaluating the assignment *x2 = *a1, E is equal to bool(invoke(comp, invoke(proj2, *x2), invoke(proj2, *y2))).
// [Note 1: Writing a value from the input range into the output range does not affect how it is ordered by comp and proj1 or proj2. —end note]
// Effects: Places the first N elements as sorted with respect to comp and proj2 into the range [result_- first,result_first + N).
// Returns:
// — result_first + N for the overloads in namespace std.
// — {last, result_first + N} for the overloads in namespace ranges.
// Complexity: Approximately (last - first) * log N comparisons, and twice as many projections.
// 27.8.2.5 is_sorted template<class ForwardIterator>
 [is.sorted]
 constexpr bool is_sorted(ForwardIterator first, ForwardIterator last);
Effects:
Equivalent to:
return is_sorted_until(first, last) == last;
template<class ExecutionPolicy, class ForwardIterator>
bool is_sorted(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last);
// Effects: Equivalent to:
return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
template<class ForwardIterator, class Compare>
constexpr bool is_sorted(ForwardIterator first, ForwardIterator last,
 Compare comp);
// Effects: Equivalent to: return is_sorted_until(first, last, comp) == last;
template<class ExecutionPolicy, class ForwardIterator, class Compare>
bool is_sorted(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 Compare comp);
// Effects: Equivalent to:
return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
template<forward_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
// Effects: Equivalent to: return ranges::is_sorted_until(first, last, comp, proj) == last;
template<class ForwardIterator>
constexpr ForwardIterator
is_sorted_until(ForwardIterator first, ForwardIterator last);
template<class ExecutionPolicy, class ForwardIterator>
ForwardIterator
is_sorted_until(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last);
template<class ForwardIterator, class Compare>
constexpr ForwardIterator
is_sorted_until(ForwardIterator first, ForwardIterator last,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator, class Compare>
ForwardIterator
is_sorted_until(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 Compare comp);
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
template<forward_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
constexpr borrowed_iterator_t<R>
ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names. Returns: The last iterator i in [first, last] for which the range [first, i) is sorted with respect to comp and proj. Complexity: Linear.
requires sortable<I, Comp, Proj>
constexpr I
ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: [first,nth) and [nth,last) are valid ranges. For the overloads in namespace std, RandomAccessIterator meets the Cpp17ValueSwappable requirements (16.4.4.3), and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) require-
ments.
// Effects: After nth_element the element in the position pointed to by nth is the element that would be in that position if the whole range were sorted with respect to comp and proj, unless nth == last. Also for every iterator i in the range [first, nth) and every iterator j in the range [nth, last) it holds that: bool(invoke(comp, invoke(proj, *j), invoke(proj, *i))) is false.
// 27.8.3 Nth element [alg.nth.element]
template<class RandomAccessIterator>
constexpr void nth_element(RandomAccessIterator first, RandomAccessIterator nth,
 RandomAccessIterator last);
template<class ExecutionPolicy, class RandomAccessIterator>
void nth_element(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator nth,
 RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void nth_element(RandomAccessIterator first, RandomAccessIterator nth,
 RandomAccessIterator last, Compare comp);
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
void nth_element(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator nth,
 RandomAccessIterator last, Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
// Returns: last for the overload in namespace ranges.
ranges::less>
constexpr borrowed_iterator_t<R>
ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names. Preconditions: The elements e of [first, last) are partitioned with respect to the expression
bool(invoke(comp, invoke(proj, e), value)).
// Returns: The furthermost iterator i in the range [first,last] such that for every iterator j in the range [first, i), bool(invoke(comp, invoke(proj, *j), value)) is true. // Complexity: At most log2(last - first) + O(1) comparisons and projections.
// Complexity: For the overloads with no ExecutionPolicy, linear on average. For the overloads with an ExecutionPolicy, O(N) applications of the predicate, and O(N logN) swaps, where N = last - first.
// All of the algorithms in 27.8.4 are versions of binary search and assume that the sequence being searched is partitioned with respect to an expression formed by binding the search key to an argument of the comparison function. They work on non-random access iterators minimizing the number of comparisons, which will be logarithmic for all types of iterators. They are especially appropriate for random access iterators, because these algorithms do a logarithmic number of steps through the data structure. For non-random access iterators they execute a linear number of steps.
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
// Effects: Equivalent to:
return ranges::nth_element(ranges::begin(r), nth, ranges::end(r), comp, proj);
// 27.8.4 Binary search [alg.binary.search]
// 27.8.4.1 General [alg.binary.search.general]
// 27.8.4.2 lower_bound [lower.bound]
template<class ForwardIterator, class T>
constexpr ForwardIterator
lower_bound(ForwardIterator first, ForwardIterator last,
 const T& value);
template<class ForwardIterator, class T, class Compare>
constexpr ForwardIterator
lower_bound(ForwardIterator first, ForwardIterator last,
 const T& value, Compare comp);
template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::lower_bound(I first, S last, const T& value, Comp comp = {},
 Proj proj = {});
template<forward_range R, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
// 27.8.4.3 upper_bound [upper.bound]
 template<class ForwardIterator, class T>
 constexpr ForwardIterator
 upper_bound(ForwardIterator first, ForwardIterator last,
 const T& value);
template<class ForwardIterator, class T, class Compare>
constexpr ForwardIterator
upper_bound(ForwardIterator first, ForwardIterator last,
 const T& value, Compare comp);
ranges::less>
constexpr borrowed_subrange_t<R>
ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names.
// Preconditions: The elements e of [first,last) are partitioned with respect to the expressions bool(invoke(comp, invoke(proj, e), value)) and !bool(invoke(comp, value, invoke(proj, e))). Also, for all elements e of [first, last), bool(comp(e, value)) implies !bool(comp(value, e)) for the overloads in namespace std.
// Returns: — For the overloads in namespace std:
{ lower_bound(first, last, value, comp),
 upper_bound(first, last, value, comp)
}
// — For the overloads in namespace ranges: {ranges::lower_bound(first, last, value, comp, proj),
ranges::upper_bound(first, last, value, comp, proj)
}
// Complexity: At most 2 ∗ log2(last - first) + O(1) comparisons and projections.
template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
template<forward_range R, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 ranges::less>
constexpr borrowed_iterator_t<R>
ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names. Preconditions: The elements e of [first, last) are partitioned with respect to the expression
!bool(invoke(comp, value, invoke(proj, e))).
// Returns: The furthermost iterator i in the range [first,last] such that for every iterator j in the range [first, i), !bool(invoke(comp, value, invoke(proj, *j))) is true. Complexity: At most log2(last - first) + O(1) comparisons and projections.
// 27.8.4.4 equal_range [equal.range]
template<class ForwardIterator, class T>
constexpr pair<ForwardIterator, ForwardIterator>
equal_range(ForwardIterator first,
 ForwardIterator last, const T& value);
template<class ForwardIterator, class T, class Compare>
constexpr pair<ForwardIterator, ForwardIterator>
equal_range(ForwardIterator first,
 ForwardIterator last, const T& value,
 Compare comp);
template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
constexpr subrange<I>
ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
template<forward_range R, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
// 27.8.4.5 binary_search [binary.search]
 template<class ForwardIterator, class T>
 constexpr bool
 binary_search(ForwardIterator first, ForwardIterator last,
 const T& value);
template<class ForwardIterator, class T, class Compare>
constexpr bool
binary_search(ForwardIterator first, ForwardIterator last,
 const T& value, Compare comp);
template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<I, Proj>> Comp = ranges::less>
constexpr bool ranges::binary_search(I first, S last, const T& value, Comp comp = {},
 Proj proj = {});
template<forward_range R, class T, class Proj = identity,
 indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 ranges::less>
constexpr bool ranges::binary_search(R&& r, const T& value, Comp comp = {},
 Proj proj = {});
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names.
// Preconditions: The elements e of [first,last) are partitioned with respect to the expressions bool(invoke(comp, invoke(proj, e), value)) and !bool(invoke(comp, value, invoke(proj, e))). Also, for all elements e of [first, last), bool(comp(e, value)) implies !bool(comp(value, e)) for the overloads in namespace std.
// Returns: true if and only if for some iterator i in the range [first,last), !bool(invoke(comp, invoke(proj, *i), value)) && !bool(invoke(comp, value, invoke(proj, *i))) is true.
indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 constexpr bool ranges::is_partitioned(R&& r, Pred pred, Proj proj = {});
// Let proj be identity{} for the overloads with no parameter named proj.
// Returns: true if and only if the elements e of [first,last) are partitioned with respect to the expression bool(invoke(pred, invoke(proj, e))).
// Complexity: Linear. At most last - first applications of pred and proj.
// Complexity: At most log2(last - first) + O(1) comparisons and projections.
// 27.8.5 Partitions [alg.partitions]
template<class InputIterator, class Predicate>
constexpr bool is_partitioned(InputIterator first, InputIterator last, Predicate pred);
template<class ExecutionPolicy, class ForwardIterator, class Predicate>
bool is_partitioned(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last, Predicate pred);
template<input_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_unary_predicate<projected<I, Proj>> Pred>
constexpr bool ranges::is_partitioned(I first, S last, Pred pred, Proj proj = {});
template<input_range R, class Proj = identity,
 template<class ForwardIterator, class Predicate>
 constexpr ForwardIterator
 partition(ForwardIterator first, ForwardIterator last, Predicate pred);
template<class ExecutionPolicy, class ForwardIterator, class Predicate>
ForwardIterator
partition(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last, Predicate pred);
template<permutable I, sentinel_for<I> S, class Proj = identity,
 indirect_unary_predicate<projected<I, Proj>> Pred>
constexpr subrange<I>
ranges::partition(I first, S last, Pred pred, Proj proj = {});
template<forward_range R, class Proj = identity,
 indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
requires permutable<iterator_t<R>>
constexpr borrowed_subrange_t<R>
ranges::partition(R&& r, Pred pred, Proj proj = {});
// Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
// Preconditions: For the overloads in namespace std, ForwardIterator meets the Cpp17ValueSwappable requirements (16.4.4.3).
// Effects: Places all the elements e in [first,last) that satisfy E(e) before all the elements that do not. Returns: Let i be an iterator such that E(*j) is true for every iterator j in [first,i) and false for every iterator j in [i, last).
// Returns: — i for the overloads in namespace std.
// — {i, last} for the overloads in namespace ranges.
// Complexity: Let N = last - first:
// — For the overload with no ExecutionPolicy, exactly N applications of the predicate and projection. At most N/2 swaps if the type of first meets the Cpp17BidirectionalIterator requirements for the overloads in namespace std or models bidirectional_iterator for the overloads in namespace ranges, and at most N swaps otherwise.
// — For the overload with an ExecutionPolicy, O(N logN) swaps and O(N) applications of the predicate.
indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 requires permutable<iterator_t<R>>
 borrowed_subrange_t<R> ranges::stable_partition(R&& r, Pred pred, Proj proj = {});
Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
// Preconditions: For the overloads in namespace std, BidirectionalIterator meets the Cpp17Value- Swappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Places all the elements e in [first,last) that satisfy E(e) before all the elements that do not. The relative order of the elements in both groups is preserved.
// Returns: Let i be an iterator such that for every iterator j in [first,i), E(*j) is true, and for every iterator j in the range [i,last), E(*j) is false. Returns:
// — i for the overloads in namespace std.
// — {i, last} for the overloads in namespace ranges. Complexity: Let N = last - first:
// — For the overloads with no ExecutionPolicy, at most N log N swaps, but only O (N ) swaps if there is enough extra memory. Exactly N applications of the predicate and projection.
// — For the overload with an ExecutionPolicy, O(N logN) swaps and O(N) applications of the predicate.
 template<class BidirectionalIterator, class Predicate>
 BidirectionalIterator
 stable_partition(BidirectionalIterator first, BidirectionalIterator last, Predicate pred);
template<class ExecutionPolicy, class BidirectionalIterator, class Predicate>
BidirectionalIterator
stable_partition(ExecutionPolicy&& exec,
 BidirectionalIterator first, BidirectionalIterator last, Predicate pred);
template<bidirectional_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_unary_predicate<projected<I, Proj>> Pred>
requires permutable<I>
subrange<I> ranges::stable_partition(I first, S last, Pred pred, Proj proj = {});
template<bidirectional_range R, class Proj = identity,
 template<class InputIterator, class OutputIterator1, class OutputIterator2, class Predicate>
 constexpr pair<OutputIterator1, OutputIterator2>
 partition_copy(InputIterator first, InputIterator last,
 OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred);
template<class ExecutionPolicy, class ForwardIterator, class ForwardIterator1,
 class ForwardIterator2, class Predicate>
pair<ForwardIterator1, ForwardIterator2>
partition_copy(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 ForwardIterator1 out_true, ForwardIterator2 out_false, Predicate pred);
template<input_iterator I, sentinel_for<I> S, weakly_incrementable O1, weakly_incrementable O2,
 class Proj = identity, indirect_unary_predicate<projected<I, Proj>> Pred>
requires indirectly_copyable<I, O1> && indirectly_copyable<I, O2>
constexpr ranges::partition_copy_result<I, O1, O2>
ranges::partition_copy(I first, S last, O1 out_true, O2 out_false, Pred pred,
 Proj proj = {});
template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
 class Proj = identity,
 indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
requires indirectly_copyable<iterator_t<R>, O1> &&
indirectly_copyable<iterator_t<R>, O2>
constexpr ranges::partition_copy_result<borrowed_iterator_t<R>, O1, O2>
ranges::partition_copy(R&& r, O1 out_true, O2 out_false, Pred pred, Proj proj = {});
// Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
// Mandates: For the overloads in namespace std, the expression *first is writable (25.3.1) to out_true and out_false.
// Preconditions: The input range and output ranges do not overlap.
// [Note 1: For the overload with an ExecutionPolicy, there might be a performance cost if first’s value type does not meet the Cpp17CopyConstructible requirements.
// Effects: For each iterator i in [first, last), copies *i to the output range beginning with out_true if E(*i) is true, or to the output range beginning with out_false otherwise.
// Returns: Let o1 be the end of the output range beginning at out_true, and o2 the end of the output range beginning at out_false. Returns
// — {o1, o2} for the overloads in namespace std.
// — {last, o1, o2} for the overloads in namespace ranges.
// Complexity: Exactly last - first applications of pred and proj.
indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 constexpr borrowed_iterator_t<R>
 ranges::partition_point(R&& r, Pred pred, Proj proj = {});
// Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
// Preconditions: The elements e of [first,last) are partitioned with respect to E(e).
// Returns: An iterator mid such that E(*i) is true for all iterators i in [first,mid), and false for all iterators i in [mid, last).
// Complexity: O(log(last - first)) applications of pred and proj.
template<class ForwardIterator, class Predicate>
constexpr ForwardIterator
partition_point(ForwardIterator first, ForwardIterator last, Predicate pred);
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_unary_predicate<projected<I, Proj>> Pred>
constexpr I ranges::partition_point(I first, S last, Pred pred, Proj proj = {});
template<forward_range R, class Proj = identity,
// 27.8.6 Merge [alg.merge]
 template<class InputIterator1, class InputIterator2,
 class OutputIterator>
 constexpr OutputIterator
 merge(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator>
ForwardIterator
merge(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result);
template<class InputIterator1, class InputIterator2,
 class OutputIterator, class Compare>
constexpr OutputIterator
merge(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result, Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator, class Compare>
ForwardIterator
merge(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result, Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 weakly_incrementable O, class Comp = ranges::less, class Proj1 = identity,
 class Proj2 = identity>
requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
constexpr ranges::merge_result<I1, I2, O>
ranges::merge(I1 first1, S1 last1, I2 first2, S2 last2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 class Proj1 = identity, class Proj2 = identity>
requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
constexpr ranges::merge_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
ranges::merge(R1&& r1, R2&& r2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
// Let N be (last1 - first1) + (last2 - first2). Let comp be less{}, proj1 be identity{}, and proj2 be identity{}, for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively. The resulting range does not overlap with either of the original ranges.
// Effects: Copies all the elements of the two ranges [first1, last1) and [first2, last2) into the range [result,result_last), where result_last is result + N. If an element a precedes b in an input range, a is copied into the output range before b. If e1 is an element of [first1,last1) and e2 of [first2,last2), e2 is copied into the output range before e1 if and only if bool(invoke(comp, invoke(proj2, e2), invoke(proj1, e1))) is true.
// Returns: — result_last for the overloads in namespace std.
// — {last1, last2, result_last} for the overloads in namespace ranges.
// Complexity :— For the overloads with no ExecutionPolicy, at most N // − 1 comparisons and applications of each projection.
// — For the overloads with an ExecutionPolicy, O(N) comparisons.
// Remarks: Stable (16.4.6.8).
template<class BidirectionalIterator>
void inplace_merge(BidirectionalIterator first,
 BidirectionalIterator middle,
 BidirectionalIterator last);
template<class ExecutionPolicy, class BidirectionalIterator>
void inplace_merge(ExecutionPolicy&& exec,
 BidirectionalIterator first,
 BidirectionalIterator middle,
 BidirectionalIterator last);
template<class BidirectionalIterator, class Compare>
void inplace_merge(BidirectionalIterator first,
 BidirectionalIterator middle,
 BidirectionalIterator last, Compare comp);
template<class ExecutionPolicy, class BidirectionalIterator, class Compare>
void inplace_merge(ExecutionPolicy&& exec,
 BidirectionalIterator first,
 BidirectionalIterator middle,
 BidirectionalIterator last, Compare comp);
template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
I ranges::inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: [first,middle) and [middle,last) are valid ranges sorted with respect to comp and proj. For the overloads in namespace std, BidirectionalIterator meets the Cpp17ValueSwappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Merges two sorted consecutive ranges [first, middle) and [middle, last), putting the result of the merge into the range [first, last). The resulting range is sorted with respect to comp and proj. Returns: last for the overload in namespace ranges.
// Complexity: Let N = last - first:
// — For the overloads with no ExecutionPolicy, and if enough additional memory is available, exactly N − 1 comparisons.
// — Otherwise, O(N logN) comparisons.
// In either case, twice as many projections as comparisons. Remarks: Stable (16.4.6.8).
// Subclause 27.8.7 defines all the basic set operations on sorted structures. They also work with multisets (24.4.7) containing multiple copies of equivalent elements. The semantics of the set operations are generalized to multisets in a standard way by defining set_union to contain the maximum number of occurrences of every element, set_intersection to contain the minimum, and so on.
// 27.8.7.2 includes [includes]
template<class InputIterator1, class InputIterator2>
constexpr bool includes(InputIterator1 first1, InputIterator1 last1,
 template<bidirectional_range R, class Comp = ranges::less, class Proj = identity>
 requires sortable<iterator_t<R>, Comp, Proj>
 borrowed_iterator_t<R>
 ranges::inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
// Effects: Equivalent to:
 return ranges::inplace_merge(ranges::begin(r), middle, ranges::end(r), comp, proj);
// 27.8.7 Set operations on sorted structures [alg.set.operations]
// 27.8.7.1 General [alg.set.operations.general]
 InputIterator2 first2, InputIterator2 last2);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2>
bool includes(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2);
template<class InputIterator1, class InputIterator2, class Compare>
constexpr bool includes(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2, class Compare>
bool includes(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 class Proj1 = identity, class Proj2 = identity,
 indirect_strict_weak_order<projected<I1, Proj1>,
 projected<I2, Proj2>> Comp = ranges::less>
constexpr bool ranges::includes(I1 first1, S1 last1, I2 first2, S2 last2, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, class Proj1 = identity,
 class Proj2 = identity,
 indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
constexpr bool ranges::includes(R1&& r1, R2&& r2, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
// Let comp be less{}, proj1 be identity{}, and proj2 be identity{}, for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively.
// Returns: true if and only if [first2, last2) is a subsequence of [first1, last1).
// [Note 1: A sequence S is a subsequence of another sequence T if S can be obtained from T by removing some, all, or none of T’s elements and keeping the remaining elements in the same order.
// Complexity: At most 2 * ((last1 - first1) + (last2 - first2)) - 1 comparisons and applica-tions of each projection.
// 27.8.7.3 set_union [set.union]
template<class InputIterator1, class InputIterator2, class OutputIterator>
constexpr OutputIterator
set_union(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator>
ForwardIterator
set_union(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result);
template<class InputIterator1, class InputIterator2, class OutputIterator, class Compare>
constexpr OutputIterator
set_union(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result, Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator, class Compare>
ForwardIterator
set_union(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result, Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 weakly_incrementable O, class Comp = ranges::less,
 class Proj1 = identity, class Proj2 = identity>
requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
constexpr ranges::set_union_result<I1, I2, O>
ranges::set_union(I1 first1, S1 last1, I2 first2, S2 last2, O result, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, weakly_incrementable O,
 class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
constexpr ranges::set_union_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
ranges::set_union(R1&& r1, R2&& r2, O result, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
// Let comp be less{}, and proj1 and proj2 be identity{} for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively. The resulting range does not overlap with either of the original ranges.
// Effects: Constructs a sorted union of the elements from the two ranges; that is, the set of elements that are present in one or both of the ranges.
// Returns: Let result_last be the end of the constructed range. Returns
// — result_last for the overloads in namespace std.
// — {last1, last2, result_last} for the overloads in namespace ranges.
// Complexity: At most 2 * ((last1 - first1) + (last2 - first2)) - 1 comparisons and applica- tions of each projection.
// Remarks: Stable (16.4.6.8). If [first1, last1) contains m elements that are equivalent to each other and [first2, last2) contains n elements that are equivalent to them, then all m elements from the first range are copied to the output range, in order, and then the final max(n − m, 0) elements from the second range are copied to the output range, in order.
// 27.8.7.4 set_intersection [set.intersection]
template<class InputIterator1, class InputIterator2,
 class OutputIterator>
constexpr OutputIterator
set_intersection(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator>
ForwardIterator
set_intersection(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result);
template<class InputIterator1, class InputIterator2,
 class OutputIterator, class Compare>
constexpr OutputIterator
set_intersection(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result, Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator, class Compare>
ForwardIterator
set_intersection(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 constexpr ranges::set_intersection_result<borrowed_iterator_t<R1>, borrowed_iterator_t<R2>, O>
 ranges::set_intersection(R1&& r1, R2&& r2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
// Let comp be less{}, and proj1 and proj2 be identity{} for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively. The resulting range does not overlap with either of the original ranges.
// Effects: Constructs a sorted intersection of the elements from the two ranges; that is, the set of elements that are present in both of the ranges.
// Returns: Let result_last be the end of the constructed range. Returns
// — result_last for the overloads in namespace std.
// — {last1, last2, result_last} for the overloads in namespace ranges.
// Complexity: At most 2 * ((last1 - first1) + (last2 - first2)) - 1 comparisons and applica- tions of each projection.
// Remarks: Stable (16.4.6.8). If [first1, last1) contains m elements that are equivalent to each other and [first2, last2) contains n elements that are equivalent to them, the first min(m, n) elements are copied from the first range to the output range, in order.
 ForwardIterator result, Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 weakly_incrementable O, class Comp = ranges::less,
 class Proj1 = identity, class Proj2 = identity>
requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
constexpr ranges::set_intersection_result<I1, I2, O>
ranges::set_intersection(I1 first1, S1 last1, I2 first2, S2 last2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, weakly_incrementable O,
 class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
// 27.8.7.5 set_difference [set.difference]
template<class InputIterator1, class InputIterator2,
 class OutputIterator>
constexpr OutputIterator
set_difference(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator>
ForwardIterator
set_difference(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result);
template<class InputIterator1, class InputIterator2,
 class OutputIterator, class Compare>
constexpr OutputIterator
set_difference(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result, Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator, class Compare>
ForwardIterator
set_difference(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result, Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 weakly_incrementable O, class Comp = ranges::less,
 class Proj1 = identity, class Proj2 = identity>
requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
constexpr ranges::set_difference_result<I1, O>
ranges::set_difference(I1 first1, S1 last1, I2 first2, S2 last2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, weakly_incrementable O,
 class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
constexpr ranges::set_difference_result<borrowed_iterator_t<R1>, O>
ranges::set_difference(R1&& r1, R2&& r2, O result,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
// Let comp be less{}, and proj1 and proj2 be identity{} for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively. The resulting range does not overlap with either of the original ranges.
// Effects: Copies the elements of the range [first1, last1) which are not present in the range [first2, last2) to the range beginning at result. The elements in the constructed range are sorted.
// Returns: Let result_last be the end of the constructed range. Returns // — result_last for the overloads in namespace std.
// — {last1, result_last} for the overloads in namespace ranges.
// Complexity: At most 2 * ((last1 - first1) + (last2 - first2)) - 1 comparisons and applica- tions of each projection.
// Remarks: If [first1, last1) contains m elements that are equivalent to each other and [first2, last2) contains n elements that are equivalent to them, the last max(m − n, 0) elements from [first1, last1) is copied to the output range, in order.
// 27.8.7.6 set_symmetric_difference [set.symmetric.difference]
template<class InputIterator1, class InputIterator2,
 class OutputIterator>
constexpr OutputIterator
set_symmetric_difference(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator>
ForwardIterator
set_symmetric_difference(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result);
template<class InputIterator1, class InputIterator2,
 class OutputIterator, class Compare>
constexpr OutputIterator
set_symmetric_difference(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 OutputIterator result, Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class ForwardIterator, class Compare>
ForwardIterator
set_symmetric_difference(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 ForwardIterator result, Compare comp);
// — With N = b - a, for all i, 0 < i < N, bool(invoke(comp, invoke(proj, a[􏰅i−1􏰆]), invoke( proj, a[i]))) is false.
// — *a may be removed by pop_heap, or a new element added by push_heap, in O(logN) time.
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 weakly_incrementable O, class Comp = ranges::less,
 class Proj1 = identity, class Proj2 = identity>
requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
constexpr ranges::set_symmetric_difference_result<I1, I2, O>
ranges::set_symmetric_difference(I1 first1, S1 last1, I2 first2, S2 last2, O result,
 Comp comp = {}, Proj1 proj1 = {},
 Proj2 proj2 = {});
template<input_range R1, input_range R2, weakly_incrementable O,
 class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
constexpr ranges::set_symmetric_difference_result<borrowed_iterator_t<R1>,
 borrowed_iterator_t<R2>, O>
ranges::set_symmetric_difference(R1&& r1, R2&& r2, O result, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
// Let comp be less{}, and proj1 and proj2 be identity{} for the overloads with no parameters by those names.
// Preconditions: The ranges [first1, last1) and [first2, last2) are sorted with respect to comp and proj1 or proj2, respectively. The resulting range does not overlap with either of the original ranges.
// Effects: Copies the elements of the range [first1, last1) that are not present in the range [first2, last2), and the elements of the range [first2, last2) that are not present in the range [first1, last1) to the range beginning at result. The elements in the constructed range are sorted.
// Returns: Let result_last be the end of the constructed range. Returns
// — result_last for the overloads in namespace std.
// — {last1, last2, result_last} for the overloads in namespace ranges.
// Complexity: At most 2 * ((last1 - first1) + (last2 - first2)) - 1 comparisons and applica- tions of each projection.
// Remarks: Stable (16.4.6.8). If [first1, last1) contains m elements that are equivalent to each other and [first2, last2) contains n elements that are equivalent to them, then |m − n| of those elements shall be copied to the output range: the last m − n of these elements from [first1, last1) if m > n, and the last n − m of these elements from [first2, last2) if m < n. In either case, the elements are copied in order.
// A random access range [a, b) is a heap with respect to comp and proj for a comparator and projection comp and proj if its elements are organized such that:
// 27.8.8 Heap operations [alg.heap.operations]
// 27.8.8.1 General [alg.heap.operations.general]
// These properties make heaps useful as priority queues.
// make_heap converts a range into a heap and sort_heap turns a heap into a sorted sequence.
// 27.8.8.2 push_heap [push.heap]
template<class RandomAccessIterator>
constexpr void push_heap(RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void push_heap(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: The range [first, last - 1) is a valid heap with respect to comp and proj. For the overloads in namespace std, the type of *first meets the Cpp17MoveConstructible requirements
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: The range [first,last) is a valid non-empty heap with respect to comp and proj. For the overloads in namespace std, RandomAccessIterator meets the Cpp17ValueSwappable re- quirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Swaps the value in the location first with the value in the location last - 1 and makes
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// (Table 30) and the Cpp17MoveAssignable requirements (Table 32).
// Effects: Places the value in the location last - 1 into the resulting heap [first, last). Returns: last for the overloads in namespace ranges.
// Complexity: At most log(last - first) comparisons and twice as many projections.
// 27.8.8.3 pop_heap [pop.heap]
template<class RandomAccessIterator>
constexpr void pop_heap(RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void pop_heap(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
// [first, last - 1) into a heap with respect to comp and proj.
// Returns: last for the overloads in namespace ranges.
// Complexity: At most 2log(last - first) comparisons and twice as many projections.
// 27.8.8.4 make_heap [make.heap]
template<class RandomAccessIterator>
constexpr void make_heap(RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void make_heap(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
// Preconditions: For the overloads in namespace std, the type of *first meets the Cpp17Move- Constructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Constructs a heap with respect to comp and proj out of the range [first, last). Returns: last for the overloads in namespace ranges.
// Complexity: At most 3(last - first) comparisons and twice as many projections.
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
// Preconditions: The range [first, last) is a valid heap with respect to comp and proj. For the overloads in namespace std, RandomAccessIterator meets the Cpp17ValueSwappable requirements (16.4.4.3) and the type of *first meets the Cpp17MoveConstructible (Table 30) and Cpp17MoveAssignable (Table 32) requirements.
// Effects: Sorts elements in the heap [first, last) with respect to comp and proj.
// Returns: last for the overloads in namespace ranges.
// Complexity: At most 2N log N comparisons, where N = last - first, and twice as many projections.
// 27.8.8.5 sort_heap [sort.heap]
template<class RandomAccessIterator>
constexpr void sort_heap(RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr void sort_heap(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr I
ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr borrowed_iterator_t<R>
ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
// 27.8.8.6 is_heap [is.heap]
template<class RandomAccessIterator>
constexpr bool is_heap(RandomAccessIterator first, RandomAccessIterator last);
// Effects: Equivalent to: return is_heap_until(first, last) == last;
template<class ExecutionPolicy, class RandomAccessIterator>
bool is_heap(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last);
// Effects: Equivalent to:
return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
template<class RandomAccessIterator, class Compare>
constexpr bool is_heap(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
// Effects: Equivalent to: return is_heap_until(first, last, comp) == last;
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
bool is_heap(ExecutionPolicy&& exec, RandomAccessIterator first, RandomAccessIterator last, Compare comp);
// Effects: Equivalent to:
return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
// Effects: Equivalent to: return ranges::is_heap_until(first, last, comp, proj) == last;
indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 constexpr borrowed_iterator_t<R>
 ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names. Returns: The last iterator i in [first, last] for which the range [first, i) is a heap with respect to
constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
// Preconditions: For the first form, T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: The smaller value. Returns the first argument when the arguments are equivalent.
// Complexity: Exactly one comparison and two applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the overloads in namespace std.
template<class RandomAccessIterator>
constexpr RandomAccessIterator
is_heap_until(RandomAccessIterator first, RandomAccessIterator last);
template<class ExecutionPolicy, class RandomAccessIterator>
RandomAccessIterator
is_heap_until(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last);
template<class RandomAccessIterator, class Compare>
constexpr RandomAccessIterator
is_heap_until(RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<class ExecutionPolicy, class RandomAccessIterator, class Compare>
RandomAccessIterator
is_heap_until(ExecutionPolicy&& exec,
 RandomAccessIterator first, RandomAccessIterator last,
 Compare comp);
template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
template<random_access_range R, class Proj = identity,
// comp and proj. Complexity: Linear.
// 27.8.9 Minimum and maximum [alg.min.max]
 template<class T>
 constexpr const T& min(const T& a, const T& b);
template<class T, class Compare>
constexpr const T& min(const T& a, const T& b, Compare comp);
template<class T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
template<class T>
constexpr T min(initializer_list<T> r);
template<class T, class Compare>
constexpr T min(initializer_list<T> r, Compare comp);
template<copyable T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
template<input_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
constexpr range_value_t<R>
ranges::min(R&& r, Comp comp = {}, Proj proj = {});
// Preconditions: ranges::distance(r) > 0. For the overloads in namespace std, T meets the Cpp17- CopyConstructible requirements. For the first form, T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: The smallest value in the input range. Returns a copy of the leftmost element when several elements are equivalent to the smallest.
// Complexity: Exactly ranges::distance(r) - 1 comparisons and twice as many applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the overloads in namespace std.
indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
 constexpr range_value_t<R>
 ranges::max(R&& r, Comp comp = {}, Proj proj = {});
// Preconditions: ranges::distance(r) > 0. For the overloads in namespace std, T meets the Cpp17- CopyConstructible requirements. For the first form, T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: The largest value in the input range. Returns a copy of the leftmost element when several elements are equivalent to the largest.
// Complexity: Exactly ranges::distance(r) - 1 comparisons and twice as many applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the overloads in namespace std.
template<class T>
constexpr const T& max(const T& a, const T& b);
template<class T, class Compare>
constexpr const T& max(const T& a, const T& b, Compare comp);
template<class T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
// Preconditions: For the first form, T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: The larger value. Returns the first argument when the arguments are equivalent.
// Complexity: Exactly one comparison and two applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the overloads in namespace std.
template<class T>
constexpr T max(initializer_list<T> r);
template<class T, class Compare>
constexpr T max(initializer_list<T> r, Compare comp);
template<copyable T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
template<input_range R, class Proj = identity,
 template<class T>
 constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
template<class T, class Compare>
constexpr pair<const T&, const T&> minmax(const T& a, const T& b, Compare comp);
template<class T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
constexpr ranges::minmax_result<const T&>
ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
// Preconditions: For the first form, T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: {b, a} if b is smaller than a, and {a, b} otherwise.
// Complexity: Exactly one comparison and two applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the overloads in namespace std.
requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
constexpr ranges::minmax_result<range_value_t<R>>
 ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
// Preconditions: ranges::distance(r) > 0. For the overloads in namespace std, T meets the Cpp17- CopyConstructible requirements. For the first form, type T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: Let X be the return type. Returns X{x, y}, where x is a copy of the leftmost element with the smallest value and y a copy of the rightmost element with the largest value in the input range. Complexity: At most (3/2)ranges::distance(r) applications of the corresponding predicate and twice as many applications of the projection, if any.
// Remarks: An invocation may explicitly specify an argument for the template parameter T of the
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names.
template<class T>
constexpr pair<T, T> minmax(initializer_list<T> t);
template<class T, class Compare>
constexpr pair<T, T> minmax(initializer_list<T> t, Compare comp);
template<copyable T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
constexpr ranges::minmax_result<T>
ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
template<input_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
// overloads in namespace std.
template<class ForwardIterator>
constexpr ForwardIterator min_element(ForwardIterator first, ForwardIterator last);
template<class ExecutionPolicy, class ForwardIterator>
ForwardIterator min_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last);
template<class ForwardIterator, class Compare>
constexpr ForwardIterator min_element(ForwardIterator first, ForwardIterator last,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator, class Compare>
ForwardIterator min_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last, Compare comp);
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
template<forward_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
constexpr borrowed_iterator_t<R>
ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
// Returns: The first iterator i in the range [first,last) such that for every iterator j in the range [first, last),
bool(invoke(comp, invoke(proj, *j), invoke(proj, *i)))
// is false. Returns last if first == last.
// Complexity: Exactly max(last - first - 1,0) comparisons and twice as many projections.
indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 constexpr borrowed_iterator_t<R>
 ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for the overloads with no parameters by those names. Returns: The first iterator i in the range [first,last) such that for every iterator j in the range [first, last),
bool(invoke(comp, invoke(proj, *i), invoke(proj, *j)))
// is false. Returns last if first == last.
// Complexity: Exactly max(last - first - 1,0) comparisons and twice as many projections.
constexpr ranges::minmax_result<borrowed_iterator_t<R>>
 ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
// Returns: {first, first} if [first, last) is empty, otherwise {m, M}, where m is the first iterator in [first, last) such that no iterator in the range refers to a smaller element, and where M is the last
template<class ForwardIterator>
constexpr ForwardIterator max_element(ForwardIterator first, ForwardIterator last);
template<class ExecutionPolicy, class ForwardIterator>
ForwardIterator max_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last);
template<class ForwardIterator, class Compare>
constexpr ForwardIterator max_element(ForwardIterator first, ForwardIterator last,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator, class Compare>
ForwardIterator max_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last,
 Compare comp);
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
template<forward_range R, class Proj = identity,
 template<class ForwardIterator>
 constexpr pair<ForwardIterator, ForwardIterator>
 minmax_element(ForwardIterator first, ForwardIterator last);
template<class ExecutionPolicy, class ForwardIterator>
pair<ForwardIterator, ForwardIterator>
minmax_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last);
template<class ForwardIterator, class Compare>
constexpr pair<ForwardIterator, ForwardIterator>
minmax_element(ForwardIterator first, ForwardIterator last, Compare comp);
template<class ExecutionPolicy, class ForwardIterator, class Compare>
pair<ForwardIterator, ForwardIterator>
minmax_element(ExecutionPolicy&& exec,
 ForwardIterator first, ForwardIterator last, Compare comp);
template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 indirect_strict_weak_order<projected<I, Proj>> Comp = ranges::less>
constexpr ranges::minmax_result<I>
ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
template<forward_range R, class Proj = identity,
 indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
// iterator224 in [first, last) such that no iterator in the range refers to a larger element.
// Complexity: Let N be last - first. At most max(􏰅 3 (N − 1)􏰆, 0) comparisons and twice as many
constexpr const T&
ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
// Let comp be less{} for the overloads with no parameter comp, and let proj be identity{} for the overloads with no parameter proj.
// Preconditions: bool(invoke(comp, invoke(proj, hi), invoke(proj, lo))) is false. For the first form, type T meets the Cpp17LessThanComparable requirements (Table 28).
// Returns: lo if bool(invoke(comp, invoke(proj, v), invoke(proj, lo))) is true, hi if bool( invoke(comp, invoke(proj, hi), invoke(proj, v))) is true, otherwise v.
// [Note 1: If NaN is avoided, T can be a floating-point type.
// Complexity: At most two comparisons and three applications of the projection.
// applications of the projection, if any.
// 27.8.10 Bounded value [alg.clamp]
template<class T>
constexpr const T& clamp(const T& v, const T& lo, const T& hi);
template<class T, class Compare>
constexpr const T& clamp(const T& v, const T& lo, const T& hi, Compare comp);
template<class T, class Proj = identity,
 indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
// 27.8.11 Lexicographical comparison [alg.lex.comparison]
template<class InputIterator1, class InputIterator2>
constexpr bool
lexicographical_compare(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2>
bool
lexicographical_compare(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2);
template<class InputIterator1, class InputIterator2, class Compare>
constexpr bool
lexicographical_compare(InputIterator1 first1, InputIterator1 last1,
 InputIterator2 first2, InputIterator2 last2,
 Compare comp);
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2,
 class Compare>
bool
lexicographical_compare(ExecutionPolicy&& exec,
 ForwardIterator1 first1, ForwardIterator1 last1,
 ForwardIterator2 first2, ForwardIterator2 last2,
 Compare comp);
template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 class Proj1 = identity, class Proj2 = identity,
 indirect_strict_weak_order<projected<I1, Proj1>,
 projected<I2, Proj2>> Comp = ranges::less>
constexpr bool
ranges::lexicographical_compare(I1 first1, S1 last1, I2 first2, S2 last2,
 Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
template<input_range R1, input_range R2, class Proj1 = identity,
 class Proj2 = identity,
 indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
constexpr bool
ranges::lexicographical_compare(R1&& r1, R2&& r2, Comp comp = {},
 Proj1 proj1 = {}, Proj2 proj2 = {});
// Returns: true if and only if the sequence of elements defined by the range [first1, last1) is lexico- graphically less than the sequence of elements defined by the range [first2, last2).
// Complexity: At most 2min(last1 - first1, last2 - first2) applications of the corresponding comparison and each projection, if any.
// Remarks: If two sequences have the same number of elements and their corresponding elements (if any) are equivalent, then neither sequence is lexicographically less than the other. If one sequence is a proper prefix of the other, then the shorter sequence is lexicographically less than the longer sequence. Otherwise, the lexicographical comparison of the sequences yields the same result as the comparison of the first corresponding pair of elements that are not equivalent.
// [Example 1: ranges::lexicographical_compare(I1, S1, I2, S2, Comp, Proj1, Proj2) can be implemen- ted as:
for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 if (invoke(comp, invoke(proj1, *first1), invoke(proj2, *first2))) return true;
 if (invoke(comp, invoke(proj2, *first2), invoke(proj1, *first1))) return false;
}
return first1 == last1 && first2 != last2;
// [Note 1 : An empty sequence is lexicographically less than any non-empty sequence, but not less than any empty sequence.
// 27.8.12 Three-way comparison algorithms [alg.three.way]
template<class InputIterator1, class InputIterator2, class Cmp>
constexpr auto
lexicographical_compare_three_way(InputIterator1 b1, InputIterator1 e1,
 InputIterator2 b2, InputIterator2 e2,
 Cmp comp)
-> decltype(comp(*b1, *b2));
// Let N be min(e1 - b1, e2 - b2). Let E(n) be comp(*(b1 + n), *(b2 + n)).
// Mandates: decltype(comp(*b1, *b2)) is a comparison category type.
// Returns: E(i), where i is the smallest integer in [0,N) such that E(i) != 0 is true, or (e1 - b1) <=> (e2 - b2) if no such integer exists.
// Complexity: At most N applications of comp.
template<class InputIterator1, class InputIterator2>
constexpr auto
lexicographical_compare_three_way(InputIterator1 b1, InputIterator1 e1,
 InputIterator2 b2, InputIterator2 e2);
// Effects: Equivalent to:
return lexicographical_compare_three_way(b1, e1, b2, e2, compare_three_way());
// 27.8.13 Permutation generators [alg.permutation.generators]
template<class BidirectionalIterator>
constexpr bool next_permutation(BidirectionalIterator first,
 BidirectionalIterator last);
template<class BidirectionalIterator, class Compare>
constexpr bool next_permutation(BidirectionalIterator first,
 BidirectionalIterator last, Compare comp);
template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 class Proj = identity>
requires sortable<I, Comp, Proj>
constexpr ranges::next_permutation_result<I>
ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
template<bidirectional_range R, class Comp = ranges::less,
 class Proj = identity>
requires sortable<iterator_t<R>, Comp, Proj>
constexpr ranges::next_permutation_result<borrowed_iterator_t<R>>
ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names. Preconditions: For the overloads in namespace std, BidirectionalIterator meets the Cpp17Value- Swappable requirements (16.4.4.3).
// Effects: Takes a sequence defined by the range [first, last) and transforms it into the next permutation. The next permutation is found by assuming that the set of all permutations is lexicographically sorted with respect to comp and proj. If no such permutation exists, transforms the sequence into the first permutation; that is, the ascendingly-sorted one.
// Returns: Let B be true if a next permutation was found and otherwise false. Returns: — B for the overloads in namespace std.
// — { last, B } for the overloads in namespace ranges.
// Complexity: At most (last - first) / 2 swaps.
// Let comp be less{} and proj be identity{} for overloads with no parameters by those names. Preconditions: For the overloads in namespace std, BidirectionalIterator meets the Cpp17Value- Swappable requirements (16.4.4.3).
// Effects: Takes a sequence defined by the range [first,last) and transforms it into the previous permutation. The previous permutation is found by assuming that the set of all permutations is lexicographically sorted with respect to comp and proj. If no such permutation exists, transforms the sequence into the last permutation; that is, the descendingly-sorted one.
// Returns: Let B be true if a previous permutation was found and otherwise false. Returns: — B for the overloads in namespace std.
// — { last, B } for the overloads in namespace ranges.
// Complexity: At most (last - first) / 2 swaps.
int main() {
 cout << n4910 << endl;
 return EXIT_SUCCESS;
}

編纂・実行結果(compile and go)

bash
$ clang++ p1223.cpp -std=03 -o p1223l -I. -Wall
In file included from p1223.cpp:10:
In file included from ./N4910.h:11:
In file included from /usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/10/atomic:38:
/usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/10/bits/c++0x_warning.h:32:2: error: This file requires compiler and library support for the ISO C++ 2011 standard. This support must be enabled with the -std=c++11 or -std=gnu++11 compiler options.
#error This file requires compiler and library support \
 ^
p1223.cpp:17:3: error: unknown type name 'constexpr'
 constexpr void sort(RandomAccessIterator first, RandomAccessIterator last);
 ^
p1223.cpp:19:28: warning: rvalue references are a C++11 extension [-Wc++11-extensions]
 void sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:22:3: error: unknown type name 'constexpr'
 constexpr void sort(RandomAccessIterator first, RandomAccessIterator last,
 ^
p1223.cpp:25:28: warning: rvalue references are a C++11 extension [-Wc++11-extensions]
 void sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:28:10: error: unknown type name 'random_access_iterator'; did you mean 'random_access_iterator_tag'?
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 ^~~~~~~~~~~~~~~~~~~~~~
 random_access_iterator_tag
/usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/10/bits/stl_iterator_base_types.h:107:10: note: 'random_access_iterator_tag' declared here
 struct random_access_iterator_tag : public bidirectional_iterator_tag { };
 ^
p1223.cpp:28:33: error: a non-type template parameter cannot have type 'std::random_access_iterator_tag' before C++20
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 ^
p1223.cpp:28:68: error: use of undeclared identifier 'ranges'
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 ^
p1223.cpp:29:23: error: unknown type name 'identity'
 class Proj = identity>
 ^
p1223.cpp:30:3: error: unknown type name 'requires'
 requires sortable<I, Comp, Proj>
 ^
p1223.cpp:33:10: error: unknown type name 'random_access_range'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:33:46: error: use of undeclared identifier 'ranges'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:33:73: error: unknown type name 'identity'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:34:2: error: use of undeclared identifier 'alg'
[alg.sort] [sort]
 ^
p1223.cpp:35:9: error: brackets are not allowed here; to declare an array, place the brackets after the name
requires sortable<iterator_t<R>, Comp, Proj>
 ^
 [alg.sort] [sort]
p1223.cpp:35:1: error: C++ requires a type specifier for all declarations
requires sortable<iterator_t<R>, Comp, Proj>
^
p1223.cpp:34:13: error: reference to overloaded function could not be resolved; did you mean to call it?
[alg.sort] [sort]
 ^~~~
p1223.cpp:25:8: note: possible target for call
 void sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:19:8: note: possible target for call
 void sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:35:1: warning: variable templates are a C++14 extension [-Wc++14-extensions]
requires sortable<iterator_t<R>, Comp, Proj>
^
p1223.cpp:35:9: error: expected ';' at end of declaration
requires sortable<iterator_t<R>, Comp, Proj>
 ^
 ;
p1223.cpp:35:19: error: use of undeclared identifier 'iterator_t'
requires sortable<iterator_t<R>, Comp, Proj>
 ^
p1223.cpp:36:10: error: expected ';' after top level declarator
constexpr borrowed_iterator_t<R>
 ^
 ;
p1223.cpp:42:35: warning: rvalue references are a C++11 extension [-Wc++11-extensions]
 void stable_sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:48:35: warning: rvalue references are a C++11 extension [-Wc++11-extensions]
 void stable_sort(ExecutionPolicy&& exec,
 ^
p1223.cpp:51:10: error: unknown type name 'random_access_iterator'; did you mean 'random_access_iterator_tag'?
template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 ^~~~~~~~~~~~~~~~~~~~~~
 random_access_iterator_tag
/usr/bin/../lib/gcc/x86_64-linux-gnu/10/../../../../include/c++/10/bits/stl_iterator_base_types.h:107:10: note: 'random_access_iterator_tag' declared here
 struct random_access_iterator_tag : public bidirectional_iterator_tag { };
 ^
fatal error: too many errors emitted, stopping now [-ferror-limit=]
5 warnings and 20 errors generated.
$ clang++ p1223.cpp -std=2b -o p1223l -I. -Wall
p1223.cpp:32:13: error: out-of-line declaration of 'sort' does not match any declaration in namespace 'std::ranges'
 ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
 ^~~~
p1223.cpp:33:10: error: unknown type name 'random_access_range'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:34:2: error: use of undeclared identifier 'alg'
[alg.sort] [sort]
 ^
p1223.cpp:35:1: error: expected unqualified-id
requires sortable<iterator_t<R>, Comp, Proj>
^
p1223.cpp:54:13: error: out-of-line declaration of 'stable_sort' does not match any declaration in namespace 'std::ranges'
 I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
 ^~~~~~~~~~~
p1223.cpp:55:10: error: unknown type name 'random_access_range'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:56:21: error: use of undeclared identifier 'iterator_t'
 requires sortable<iterator_t<R>, Comp, Proj>
 ^
p1223.cpp:92:11: error: out-of-line declaration of 'partial_sort' does not match any declaration in namespace 'std::ranges'
 ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 ^~~~~~~~~~~~
p1223.cpp:96:20: error: expected unqualified-id
 class Proj1 = identity, class Proj2 = identity>
 ^
p1223.cpp:105:10: error: unknown type name 'random_access_range'
template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 ^
p1223.cpp:106:21: error: use of undeclared identifier 'iterator_t'
 requires sortable<iterator_t<R>, Comp, Proj>
 ^
p1223.cpp:110:1: error: expected unqualified-id
return ranges::partial_sort(ranges::begin(r), middle, ranges::end(r), comp, proj);
^
p1223.cpp:142:13: error: no template named 'partial_sort_copy_result' in namespace 'std::ranges'; did you mean 'partial_sort_copy'?
 constexpr ranges::partial_sort_copy_result<I1, I2>
 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 partial_sort_copy
p1223.cpp:133:5: note: 'partial_sort_copy' declared here
 partial_sort_copy(ExecutionPolicy&& exec,
 ^
p1223.cpp:142:21: error: C++ requires a type specifier for all declarations
 constexpr ranges::partial_sort_copy_result<I1, I2>
 ~~~~~~~~~ ^
p1223.cpp:142:21: error: no variable template matches specialization; did you mean to use 'partial_sort_copy' as function template instead?
p1223.cpp:142:53: error: expected ';' at end of declaration
 constexpr ranges::partial_sort_copy_result<I1, I2>
 ^
 ;
p1223.cpp:143:31: error: unknown type name 'I1'
 ranges::partial_sort_copy(I1 first, S1 last, I2 result_first, S2 result_last,
 ^
p1223.cpp:143:41: error: unknown type name 'S1'
 ranges::partial_sort_copy(I1 first, S1 last, I2 result_first, S2 result_last,
 ^
p1223.cpp:143:50: error: unknown type name 'I2'
 ranges::partial_sort_copy(I1 first, S1 last, I2 result_first, S2 result_last,
 ^
fatal error: too many errors emitted, stopping now [-ferror-limit=]
20 errors generated.

$ g++ p1223.cpp -std=03 -o p1223g -I. -Wall
In file included from /usr/local/include/c++/12.1.0/atomic:38,
 from N4910.h:11,
 from p1223.cpp:10:
/usr/local/include/c++/12.1.0/bits/c++0x_warning.h:32:2: error: #error This file requires compiler and library support for the ISO C++ 2011 standard. This support must be enabled with the -std=c++11 or -std=gnu++11 compiler options.
 32 | #error This file requires compiler and library support \
 | ^~~~~
p1223.cpp:17:3: warning: identifier 'constexpr' is a keyword in C++11 [-Wc++11-compat]
 17 | constexpr void sort(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:1109:6: warning: identifier 'decltype' is a keyword in C++11 [-Wc++11-compat]
 1109 | -> decltype(comp(*b1, *b2));
 | ^~~~~~~~
p1223.cpp:17:3: error: 'constexpr' does not name a type
 17 | constexpr void sort(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:17:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:19:28: error: expected ',' or '...' before '&&' token
 19 | void sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:22:3: error: 'constexpr' does not name a type
 22 | constexpr void sort(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:22:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:25:28: error: expected ',' or '...' before '&&' token
 25 | void sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:28:10: error: 'random_access_iterator' has not been declared
 28 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:28:36: error: 'sentinel_for' has not been declared
 28 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:28:48: error: expected '>' before '<' token
 28 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:30:3: error: 'requires' does not name a type
 30 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:30:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:32:49: error: expected unqualified-id before ',' token
 32 | ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:32:56: error: expected constructor, destructor, or type conversion before 'proj'
 32 | ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:32:65: error: expected unqualified-id before ')' token
 32 | ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:33:10: error: 'random_access_range' has not been declared
 33 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:33:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:33:46: error: 'ranges' does not name a type
 33 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:33:52: error: expected '>' before '::' token
 33 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:34:1: error: expected unqualified-id before '[' token
 34 | [alg.sort] [sort]
 | ^
p1223.cpp:37:37: error: expected unqualified-id before ',' token
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:37:44: error: expected constructor, destructor, or type conversion before 'proj'
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:37:53: error: expected unqualified-id before ')' token
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:42:35: error: expected ',' or '...' before '&&' token
 42 | void stable_sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:48:35: error: expected ',' or '...' before '&&' token
 48 | void stable_sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:51:10: error: 'random_access_iterator' has not been declared
 51 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:51:36: error: 'sentinel_for' has not been declared
 51 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:51:48: error: expected '>' before '<' token
 51 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:53:3: error: 'requires' does not name a type
 53 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:53:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:54:56: error: expected unqualified-id before ',' token
 54 | I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:54:63: error: expected constructor, destructor, or type conversion before 'proj'
 54 | I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:54:72: error: expected unqualified-id before ')' token
 54 | I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:55:10: error: 'random_access_range' has not been declared
 55 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:55:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:55:46: error: 'ranges' does not name a type
 55 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:55:52: error: expected '>' before '::' token
 55 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:56:3: error: 'requires' does not name a type
 56 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:56:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:58:46: error: expected unqualified-id before ',' token
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:58:53: error: expected constructor, destructor, or type conversion before 'proj'
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:58:62: error: expected unqualified-id before ')' token
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:69:3: error: 'constexpr' does not name a type
 69 | constexpr void partial_sort(RandomAccessIterator first,
 | ^~~~~~~~~
p1223.cpp:69:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:73:36: error: expected ',' or '...' before '&&' token
 73 | void partial_sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:78:3: error: 'constexpr' does not name a type
 78 | constexpr void partial_sort(RandomAccessIterator first,
 | ^~~~~~~~~
p1223.cpp:78:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:83:36: error: expected ',' or '...' before '&&' token
 83 | void partial_sort(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:88:10: error: 'random_access_iterator' has not been declared
 88 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:88:36: error: 'sentinel_for' has not been declared
 88 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:88:48: error: expected '>' before '<' token
 88 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:90:1: error: 'requires' does not name a type
 90 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:90:1: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:92:65: error: expected unqualified-id before ',' token
 92 | ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:92:72: error: expected constructor, destructor, or type conversion before 'proj'
 92 | ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:92:81: error: expected unqualified-id before ')' token
 92 | ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:96:20: error: expected unqualified-id before '=' token
 96 | class Proj1 = identity, class Proj2 = identity>
 | ^
p1223.cpp:102:66: error: expected unqualified-id before ',' token
 102 | ranges::partial_sort_copy(R1&& r, R2&& result_r, Comp comp = {},
 | ^
p1223.cpp:103:35: error: expected constructor, destructor, or type conversion before 'proj1'
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:103:45: error: expected unqualified-id before ',' token
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:103:53: error: expected constructor, destructor, or type conversion before 'proj2'
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:103:63: error: expected unqualified-id before ')' token
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:105:10: error: 'random_access_range' has not been declared
 105 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:105:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:105:46: error: 'ranges' does not name a type
 105 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:105:52: error: expected '>' before '::' token
 105 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:106:3: error: 'requires' does not name a type
 106 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:106:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:108:65: error: expected unqualified-id before ',' token
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:108:72: error: expected constructor, destructor, or type conversion before 'proj'
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:108:81: error: expected unqualified-id before ')' token
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:110:1: error: expected unqualified-id before 'return'
 110 | return ranges::partial_sort(ranges::begin(r), middle, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:113:3: error: 'constexpr' does not name a type
 113 | constexpr RandomAccessIterator
 | ^~~~~~~~~
p1223.cpp:113:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:119:38: error: expected ',' or '...' before '&&' token
 119 | partial_sort_copy(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:125:3: error: 'constexpr' does not name a type
 125 | constexpr RandomAccessIterator
 | ^~~~~~~~~
p1223.cpp:125:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:133:38: error: expected ',' or '...' before '&&' token
 133 | partial_sort_copy(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:138:10: error: 'input_iterator' has not been declared
 138 | template<input_iterator I1, sentinel_for<I1> S1, random_access_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:138:29: error: 'sentinel_for' has not been declared
 138 | template<input_iterator I1, sentinel_for<I1> S1, random_access_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:138:41: error: expected '>' before '<' token
 138 | template<input_iterator I1, sentinel_for<I1> S1, random_access_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:140:3: error: 'requires' does not name a type
 140 | requires indirectly_copyable<I1, I2> && sortable<I2, Comp, Proj2> &&
 | ^~~~~~~~
p1223.cpp:140:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:144:45: error: expected unqualified-id before ',' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:144:53: error: expected constructor, destructor, or type conversion before 'proj1'
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:144:63: error: expected unqualified-id before ',' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:144:71: error: expected constructor, destructor, or type conversion before 'proj2'
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:144:81: error: expected unqualified-id before ')' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:145:10: error: 'input_range' has not been declared
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:145:26: error: 'random_access_range' has not been declared
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:145:63: error: 'ranges' does not name a type
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~~~~~
p1223.cpp:145:69: error: expected '>' before '::' token
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~
p1223.cpp:159:70: error: expected unqualified-id before ';' token
 159 | constexpr bool is_sorted(ForwardIterator first, ForwardIterator last);
 | ^
p1223.cpp:160:8: error: found ':' in nested-name-specifier, expected '::'
 160 | Effects: Equivalent to: return is_sorted_until(first, last) == last;
 | ^
 | ::
p1223.cpp:160:1: error: 'Effects' does not name a type
 160 | Effects: Equivalent to: return is_sorted_until(first, last) == last;
 | ^~~~~~~
p1223.cpp:162:33: error: expected ',' or '...' before '&&' token
 162 | bool is_sorted(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:165:1: error: expected unqualified-id before 'return'
 165 | return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
 | ^~~~~~
p1223.cpp:167:3: error: 'constexpr' does not name a type
 167 | constexpr bool is_sorted(ForwardIterator first, ForwardIterator last,
 | ^~~~~~~~~
p1223.cpp:167:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:171:33: error: expected ',' or '...' before '&&' token
 171 | bool is_sorted(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:175:1: error: expected unqualified-id before 'return'
 175 | return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
 | ^~~~~~
p1223.cpp:176:10: error: 'forward_iterator' has not been declared
 176 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:176:30: error: 'sentinel_for' has not been declared
 176 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:176:42: error: expected '>' before '<' token
 176 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:178:65: error: expected unqualified-id before '{' token
 178 | constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:178:67: error: expected unqualified-id before ',' token
 178 | constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:178:74: error: expected constructor, destructor, or type conversion before 'proj'
 178 | constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:178:83: error: expected unqualified-id before ')' token
 178 | constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:179:10: error: 'forward_range' has not been declared
 179 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:179:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:179:40: error: 'identity' does not name a type
 179 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:180:8: error: 'indirect_strict_weak_order' has not been declared
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:180:34: error: expected '>' before '<' token
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:181:53: error: expected unqualified-id before '{' token
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:181:55: error: expected unqualified-id before ',' token
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:181:62: error: expected constructor, destructor, or type conversion before 'proj'
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:181:71: error: expected unqualified-id before ')' token
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:184:3: error: 'constexpr' does not name a type
 184 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:184:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:188:36: error: expected ',' or '...' before '&&' token
 188 | is_sorted_until(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:191:3: error: 'constexpr' does not name a type
 191 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:191:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:196:36: error: expected ',' or '...' before '&&' token
 196 | is_sorted_until(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:199:10: error: 'forward_iterator' has not been declared
 199 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:199:30: error: 'sentinel_for' has not been declared
 199 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:199:42: error: expected '>' before '<' token
 199 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:201:68: error: expected unqualified-id before '{' token
 201 | constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:201:70: error: expected unqualified-id before ',' token
 201 | constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:201:77: error: expected constructor, destructor, or type conversion before 'proj'
 201 | constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:201:86: error: expected unqualified-id before ')' token
 201 | constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:202:10: error: 'forward_range' has not been declared
 202 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:202:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:202:40: error: 'identity' does not name a type
 202 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:203:10: error: 'indirect_strict_weak_order' has not been declared
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:203:36: error: expected '>' before '<' token
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:205:48: error: expected unqualified-id before '{' token
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:205:50: error: expected unqualified-id before ',' token
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:205:57: error: expected constructor, destructor, or type conversion before 'proj'
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:205:66: error: expected unqualified-id before ')' token
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:207:1: error: 'requires' does not name a type
 207 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:207:1: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:209:61: error: expected unqualified-id before ',' token
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:209:68: error: expected constructor, destructor, or type conversion before 'proj'
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:209:77: error: expected unqualified-id before ')' token
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:212:1: error: 'ments' does not name a type
 212 | ments.
 | ^~~~~
p1223.cpp:219:35: error: expected ',' or '...' before '&&' token
 219 | void nth_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:223:3: error: 'constexpr' does not name a type
 223 | constexpr void nth_element(RandomAccessIterator first, RandomAccessIterator nth,
 | ^~~~~~~~~
p1223.cpp:223:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:226:35: error: expected ',' or '...' before '&&' token
 226 | void nth_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:229:10: error: 'random_access_iterator' has not been declared
 229 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:229:36: error: 'sentinel_for' has not been declared
 229 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:229:48: error: expected '>' before '<' token
 229 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:232:10: error: 'ranges' does not name a type
 232 | ranges::less>
 | ^~~~~~
p1223.cpp:234:60: error: expected unqualified-id before ',' token
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:234:67: error: expected constructor, destructor, or type conversion before 'proj'
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:234:76: error: expected unqualified-id before ')' token
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:236:12: error: expected ')' before '(' token
 236 | bool(invoke(comp, invoke(proj, e), value)).
 | ~ ^
 | )
p1223.cpp:243:61: error: expected unqualified-id before ',' token
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:243:68: error: expected constructor, destructor, or type conversion before 'proj'
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:243:77: error: expected unqualified-id before ')' token
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:245:1: error: expected unqualified-id before 'return'
 245 | return ranges::nth_element(ranges::begin(r), nth, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:250:3: error: 'constexpr' does not name a type
 250 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:250:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:254:3: error: 'constexpr' does not name a type
 254 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:254:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:257:10: error: 'forward_iterator' has not been declared
 257 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:257:30: error: 'sentinel_for' has not been declared
 257 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:257:42: error: expected '>' before '<' token
 257 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^
p1223.cpp:259:80: error: expected unqualified-id before '{' token
 259 | constexpr I ranges::lower_bound(I first, S last, const T& value, Comp comp = {},
 | ^
p1223.cpp:259:82: error: expected unqualified-id before ',' token
 259 | constexpr I ranges::lower_bound(I first, S last, const T& value, Comp comp = {},
 | ^
p1223.cpp:260:40: error: expected constructor, destructor, or type conversion before 'proj'
 260 | Proj proj = {});
 | ^~~~
p1223.cpp:260:49: error: expected unqualified-id before ')' token
 260 | Proj proj = {});
 | ^
p1223.cpp:261:10: error: 'forward_range' has not been declared
 261 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:261:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:261:49: error: 'identity' does not name a type
 261 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:262:10: error: 'indirect_strict_weak_order' has not been declared
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:262:36: error: expected '>' before '<' token
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
p1223.cpp:267:32: error: expected unqualified-id before ';' token
 267 | const T& value);
 | ^
p1223.cpp:269:3: error: 'constexpr' does not name a type
 269 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:269:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:272:10: error: 'ranges' does not name a type
 272 | ranges::less>
 | ^~~~~~
p1223.cpp:274:60: error: expected unqualified-id before ',' token
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:274:67: error: expected constructor, destructor, or type conversion before 'proj'
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:274:76: error: expected unqualified-id before ')' token
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:278:11: error: expected unqualified-id before '{' token
 278 | {lower_bound(first, last, value, comp),
 | ^
p1223.cpp:281:12: error: 'ranges' does not name a type
 281 | ranges::upper_bound(first, last, value, comp, proj)}
 | ^~~~~~
p1223.cpp:281:63: error: expected declaration before '}' token
 281 | ranges::upper_bound(first, last, value, comp, proj)}
 | ^
p1223.cpp:283:10: error: 'forward_iterator' has not been declared
 283 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:283:30: error: 'sentinel_for' has not been declared
 283 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:283:42: error: expected '>' before '<' token
 283 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^
p1223.cpp:285:80: error: expected unqualified-id before '{' token
 285 | constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:285:82: error: expected unqualified-id before ',' token
 285 | constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:285:89: error: expected constructor, destructor, or type conversion before 'proj'
 285 | constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:285:98: error: expected unqualified-id before ')' token
 285 | constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:286:10: error: 'forward_range' has not been declared
 286 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:286:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:286:49: error: 'identity' does not name a type
 286 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:287:10: error: 'indirect_strict_weak_order' has not been declared
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:287:36: error: expected '>' before '<' token
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
p1223.cpp:290:60: error: expected unqualified-id before '{' token
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:290:62: error: expected unqualified-id before ',' token
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:290:69: error: expected constructor, destructor, or type conversion before 'proj'
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:290:78: error: expected unqualified-id before ')' token
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:292:1: error: expected unqualified-id before '!' token
 292 | !bool(invoke(comp, value, invoke(proj, e))).
 | ^
p1223.cpp:300:3: error: 'constexpr' does not name a type
 300 | constexpr pair<ForwardIterator, ForwardIterator>
 | ^~~~~~~~~
p1223.cpp:300:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:304:10: error: 'forward_iterator' has not been declared
 304 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:304:30: error: 'sentinel_for' has not been declared
 304 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:304:42: error: expected '>' before '<' token
 304 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^
p1223.cpp:307:70: error: expected unqualified-id before '{' token
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:307:72: error: expected unqualified-id before ',' token
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:307:79: error: expected constructor, destructor, or type conversion before 'proj'
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:307:88: error: expected unqualified-id before ')' token
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:308:10: error: 'forward_range' has not been declared
 308 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:308:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:308:49: error: 'identity' does not name a type
 308 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:309:10: error: 'indirect_strict_weak_order' has not been declared
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:309:36: error: expected '>' before '<' token
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
p1223.cpp:314:34: error: expected unqualified-id before ';' token
 314 | const T& value);
 | ^
p1223.cpp:316:3: error: 'constexpr' does not name a type
 316 | constexpr bool
 | ^~~~~~~~~
p1223.cpp:316:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:319:10: error: 'forward_iterator' has not been declared
 319 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:319:30: error: 'sentinel_for' has not been declared
 319 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:319:42: error: expected '>' before '<' token
 319 | template<forward_iterator I, sentinel_for<I> S, class T, class Proj = identity,
 | ^
p1223.cpp:321:85: error: expected unqualified-id before '{' token
 321 | constexpr bool ranges::binary_search(I first, S last, const T& value, Comp comp = {},
 | ^
p1223.cpp:321:87: error: expected unqualified-id before ',' token
 321 | constexpr bool ranges::binary_search(I first, S last, const T& value, Comp comp = {},
 | ^
p1223.cpp:322:45: error: expected constructor, destructor, or type conversion before 'proj'
 322 | Proj proj = {});
 | ^~~~
p1223.cpp:322:54: error: expected unqualified-id before ')' token
 322 | Proj proj = {});
 | ^
p1223.cpp:323:10: error: 'forward_range' has not been declared
 323 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:323:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:323:49: error: 'identity' does not name a type
 323 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:324:10: error: 'indirect_strict_weak_order' has not been declared
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:324:36: error: expected '>' before '<' token
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
p1223.cpp:326:75: error: expected unqualified-id before '{' token
 326 | constexpr bool ranges::binary_search(R&& r, const T& value, Comp comp = {},
 | ^
p1223.cpp:326:77: error: expected unqualified-id before ',' token
 326 | constexpr bool ranges::binary_search(R&& r, const T& value, Comp comp = {},
 | ^
p1223.cpp:327:45: error: expected constructor, destructor, or type conversion before 'proj'
 327 | Proj proj = {});
 | ^~~~
p1223.cpp:327:54: error: expected unqualified-id before ')' token
 327 | Proj proj = {});
 | ^
p1223.cpp:331:8: error: 'indirect_unary_predicate' does not name a type
 331 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:332:71: error: expected unqualified-id before ')' token
 332 | constexpr bool ranges::is_partitioned(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:339:3: error: 'constexpr' does not name a type
 339 | constexpr bool is_partitioned(InputIterator first, InputIterator last, Predicate pred);
 | ^~~~~~~~~
p1223.cpp:339:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:341:38: error: expected ',' or '...' before '&&' token
 341 | bool is_partitioned(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:343:10: error: 'input_iterator' has not been declared
 343 | template<input_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~
p1223.cpp:343:28: error: 'sentinel_for' has not been declared
 343 | template<input_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:343:40: error: expected '>' before '<' token
 343 | template<input_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:345:81: error: expected unqualified-id before '{' token
 345 | constexpr bool ranges::is_partitioned(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:345:83: error: expected unqualified-id before ')' token
 345 | constexpr bool ranges::is_partitioned(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:346:10: error: 'input_range' has not been declared
 346 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:346:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:346:38: error: 'identity' does not name a type
 346 | template<input_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:348:3: error: expected 'class' or 'typename' before 'constexpr'
 348 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:348:13: error: expected '>' before 'ForwardIterator'
 348 | constexpr ForwardIterator
 | ^~~~~~~~~~~~~~~
p1223.cpp:349:75: error: expected unqualified-id before ';' token
 349 | partition(ForwardIterator first, ForwardIterator last, Predicate pred);
 | ^
p1223.cpp:352:30: error: expected ',' or '...' before '&&' token
 352 | partition(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:354:10: error: 'permutable' has not been declared
 354 | template<permutable I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~
p1223.cpp:354:24: error: 'sentinel_for' has not been declared
 354 | template<permutable I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:354:36: error: expected '>' before '<' token
 354 | template<permutable I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:357:63: error: expected unqualified-id before '{' token
 357 | ranges::partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:357:65: error: expected unqualified-id before ')' token
 357 | ranges::partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:358:10: error: 'forward_range' has not been declared
 358 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:358:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:358:40: error: 'identity' does not name a type
 358 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:359:10: error: 'indirect_unary_predicate' has not been declared
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:359:34: error: expected '>' before '<' token
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
p1223.cpp:362:49: error: expected unqualified-id before '{' token
 362 | ranges::partition(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:362:51: error: expected unqualified-id before ')' token
 362 | ranges::partition(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:371:8: error: 'indirect_unary_predicate' does not name a type
 371 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:373:81: error: expected unqualified-id before ')' token
 373 | borrowed_subrange_t<R> ranges::stable_partition(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:374:1: error: 'Let' does not name a type
 374 | Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
 | ^~~
p1223.cpp:374:24: error: expected unqualified-id before 'for'
 374 | Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
 | ^~~
p1223.cpp:387:37: error: expected ',' or '...' before '&&' token
 387 | stable_partition(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:389:10: error: 'bidirectional_iterator' has not been declared
 389 | template<bidirectional_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:389:36: error: 'sentinel_for' has not been declared
 389 | template<bidirectional_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:389:48: error: expected '>' before '<' token
 389 | template<bidirectional_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:392:80: error: expected unqualified-id before '{' token
 392 | subrange<I> ranges::stable_partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:392:82: error: expected unqualified-id before ')' token
 392 | subrange<I> ranges::stable_partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:393:10: error: 'bidirectional_range' has not been declared
 393 | template<bidirectional_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:393:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:393:46: error: 'identity' does not name a type
 393 | template<bidirectional_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:395:3: error: expected 'class' or 'typename' before 'constexpr'
 395 | constexpr pair<OutputIterator1, OutputIterator2>
 | ^~~~~~~~~
p1223.cpp:395:13: error: expected '>' before 'pair'
 395 | constexpr pair<OutputIterator1, OutputIterator2>
 | ^~~~
p1223.cpp:397:88: error: expected unqualified-id before ';' token
 397 | OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred);
 | ^
p1223.cpp:401:35: error: expected ',' or '...' before '&&' token
 401 | partition_copy(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:404:10: error: 'input_iterator' has not been declared
 404 | template<input_iterator I, sentinel_for<I> S, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~~~~
p1223.cpp:404:28: error: 'sentinel_for' has not been declared
 404 | template<input_iterator I, sentinel_for<I> S, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~~
p1223.cpp:404:40: error: expected '>' before '<' token
 404 | template<input_iterator I, sentinel_for<I> S, weakly_incrementable O1, weakly_incrementable O2,
 | ^
p1223.cpp:409:40: error: expected unqualified-id before '{' token
 409 | Proj proj = {});
 | ^
p1223.cpp:409:42: error: expected unqualified-id before ')' token
 409 | Proj proj = {});
 | ^
p1223.cpp:410:10: error: 'input_range' has not been declared
 410 | template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~
p1223.cpp:410:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:410:25: error: 'weakly_incrementable' has not been declared
 410 | template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:410:50: error: 'weakly_incrementable' has not been declared
 410 | template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:411:23: error: 'identity' does not name a type
 411 | class Proj = identity,
 | ^~~~~~~~
p1223.cpp:412:10: error: 'indirect_unary_predicate' has not been declared
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:412:34: error: expected '>' before '<' token
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
p1223.cpp:416:85: error: expected unqualified-id before '{' token
 416 | ranges::partition_copy(R&& r, O1 out_true, O2 out_false, Pred pred, Proj proj = {});
 | ^
p1223.cpp:416:87: error: expected unqualified-id before ')' token
 416 | ranges::partition_copy(R&& r, O1 out_true, O2 out_false, Pred pred, Proj proj = {});
 | ^
p1223.cpp:426:8: error: 'indirect_unary_predicate' does not name a type
 426 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:428:59: error: expected unqualified-id before ')' token
 428 | ranges::partition_point(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:434:3: error: 'constexpr' does not name a type
 434 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:434:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:436:10: error: 'forward_iterator' has not been declared
 436 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:436:30: error: 'sentinel_for' has not been declared
 436 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:436:42: error: expected '>' before '<' token
 436 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:438:79: error: expected unqualified-id before '{' token
 438 | constexpr I ranges::partition_point(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:438:81: error: expected unqualified-id before ')' token
 438 | constexpr I ranges::partition_point(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:439:10: error: 'forward_range' has not been declared
 439 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:439:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:439:40: error: 'identity' does not name a type
 439 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:443:3: error: expected 'class' or 'typename' before 'constexpr'
 443 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:443:13: error: expected '>' before 'OutputIterator'
 443 | constexpr OutputIterator
 | ^~~~~~~~~~~~~~
p1223.cpp:446:33: error: expected unqualified-id before ';' token
 446 | OutputIterator result);
 | ^
p1223.cpp:450:26: error: expected ',' or '...' before '&&' token
 450 | merge(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:456:3: error: 'constexpr' does not name a type
 456 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:456:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:463:26: error: expected ',' or '...' before '&&' token
 463 | merge(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:467:10: error: 'input_iterator' has not been declared
 467 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:467:29: error: 'sentinel_for' has not been declared
 467 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:467:41: error: expected '>' before '<' token
 467 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:470:3: error: 'requires' does not name a type
 470 | requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:470:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:473:33: error: expected unqualified-id before ',' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:473:41: error: expected constructor, destructor, or type conversion before 'proj1'
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:473:51: error: expected unqualified-id before ',' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:473:59: error: expected constructor, destructor, or type conversion before 'proj2'
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:473:69: error: expected unqualified-id before ')' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:474:10: error: 'input_range' has not been declared
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:474:26: error: 'input_range' has not been declared
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:474:42: error: 'weakly_incrementable' has not been declared
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:474:79: error: 'ranges' does not name a type
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~
p1223.cpp:474:85: error: expected '>' before '::' token
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~
p1223.cpp:476:3: error: 'requires' does not name a type
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:476:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:479:33: error: expected unqualified-id before ',' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:479:41: error: expected constructor, destructor, or type conversion before 'proj1'
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:479:51: error: expected unqualified-id before ',' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:479:59: error: expected constructor, destructor, or type conversion before 'proj2'
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:479:69: error: expected unqualified-id before ')' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:493:37: error: expected ',' or '...' before '&&' token
 493 | void inplace_merge(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:502:37: error: expected ',' or '...' before '&&' token
 502 | void inplace_merge(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:506:10: error: 'bidirectional_iterator' has not been declared
 506 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:506:36: error: 'sentinel_for' has not been declared
 506 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:506:48: error: expected '>' before '<' token
 506 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:508:3: error: 'requires' does not name a type
 508 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:508:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:509:68: error: expected unqualified-id before ',' token
 509 | I ranges::inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:509:75: error: expected constructor, destructor, or type conversion before 'proj'
 509 | I ranges::inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:509:84: error: expected unqualified-id before ')' token
 509 | I ranges::inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:520:9: error: 'constexpr' does not name a type
 520 | constexpr bool includes(InputIterator1 first1, InputIterator1 last1,
 | ^~~~~~~~~
p1223.cpp:520:9: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:524:66: error: expected unqualified-id before ',' token
 524 | ranges::inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:524:73: error: expected constructor, destructor, or type conversion before 'proj'
 524 | ranges::inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:524:82: error: expected unqualified-id before ')' token
 524 | ranges::inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:526:1: error: expected unqualified-id before 'return'
 526 | return ranges::inplace_merge(ranges::begin(r), middle, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:529:1: error: 'InputIterator2' does not name a type
 529 | InputIterator2 first2, InputIterator2 last2);
 | ^~~~~~~~~~~~~~
p1223.cpp:531:32: error: expected ',' or '...' before '&&' token
 531 | bool includes(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:535:3: error: 'constexpr' does not name a type
 535 | constexpr bool includes(InputIterator1 first1, InputIterator1 last1,
 | ^~~~~~~~~
p1223.cpp:535:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:539:32: error: expected ',' or '...' before '&&' token
 539 | bool includes(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:543:10: error: 'input_iterator' has not been declared
 543 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:543:29: error: 'sentinel_for' has not been declared
 543 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:543:41: error: expected '>' before '<' token
 543 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:547:89: error: expected unqualified-id before '{' token
 547 | constexpr bool ranges::includes(I1 first1, S1 last1, I2 first2, S2 last2, Comp comp = {},
 | ^
p1223.cpp:547:91: error: expected unqualified-id before ',' token
 547 | constexpr bool ranges::includes(I1 first1, S1 last1, I2 first2, S2 last2, Comp comp = {},
 | ^
p1223.cpp:548:41: error: expected constructor, destructor, or type conversion before 'proj1'
 548 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:548:51: error: expected unqualified-id before ',' token
 548 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:548:59: error: expected constructor, destructor, or type conversion before 'proj2'
 548 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:548:69: error: expected unqualified-id before ')' token
 548 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:549:10: error: 'input_range' has not been declared
 549 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:549:26: error: 'input_range' has not been declared
 549 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:549:56: error: 'identity' does not name a type
 549 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~
p1223.cpp:550:24: error: 'identity' does not name a type
 550 | class Proj2 = identity,
 | ^~~~~~~~
p1223.cpp:551:10: error: 'indirect_strict_weak_order' has not been declared
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:551:36: error: expected '>' before '<' token
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^
p1223.cpp:553:65: error: expected unqualified-id before '{' token
 553 | constexpr bool ranges::includes(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:553:67: error: expected unqualified-id before ',' token
 553 | constexpr bool ranges::includes(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:554:41: error: expected constructor, destructor, or type conversion before 'proj1'
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:554:51: error: expected unqualified-id before ',' token
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:554:59: error: expected constructor, destructor, or type conversion before 'proj2'
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:554:69: error: expected unqualified-id before ')' token
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:562:3: error: 'constexpr' does not name a type
 562 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:562:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:569:30: error: expected ',' or '...' before '&&' token
 569 | set_union(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:574:3: error: 'constexpr' does not name a type
 574 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:574:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:581:30: error: expected ',' or '...' before '&&' token
 581 | set_union(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:585:10: error: 'input_iterator' has not been declared
 585 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:585:29: error: 'sentinel_for' has not been declared
 585 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:585:41: error: expected '>' before '<' token
 585 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:588:3: error: 'requires' does not name a type
 588 | requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:588:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:590:89: error: expected unqualified-id before ',' token
 590 | ranges::set_union(I1 first1, S1 last1, I2 first2, S2 last2, O result, Comp comp = {},
 | ^
p1223.cpp:591:29: error: expected constructor, destructor, or type conversion before 'proj1'
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:591:39: error: expected unqualified-id before ',' token
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:591:47: error: expected constructor, destructor, or type conversion before 'proj2'
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:591:57: error: expected unqualified-id before ')' token
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:592:10: error: 'input_range' has not been declared
 592 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:592:26: error: 'input_range' has not been declared
 592 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:592:42: error: 'weakly_incrementable' has not been declared
 592 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:593:23: error: 'ranges' does not name a type
 593 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~~~~~
p1223.cpp:593:29: error: expected '>' before '::' token
 593 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~
p1223.cpp:594:3: error: 'requires' does not name a type
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:594:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:596:65: error: expected unqualified-id before ',' token
 596 | ranges::set_union(R1&& r1, R2&& r2, O result, Comp comp = {},
 | ^
p1223.cpp:597:29: error: expected constructor, destructor, or type conversion before 'proj1'
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:597:39: error: expected unqualified-id before ',' token
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:597:47: error: expected constructor, destructor, or type conversion before 'proj2'
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:597:57: error: expected unqualified-id before ')' token
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:609:3: error: 'constexpr' does not name a type
 609 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:609:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:616:37: error: expected ',' or '...' before '&&' token
 616 | set_intersection(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:622:3: error: 'constexpr' does not name a type
 622 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:622:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:629:37: error: expected ',' or '...' before '&&' token
 629 | set_intersection(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:635:79: error: expected ')' before ';' token
 635 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
 | )
p1223.cpp:629:21: note: to match this '('
 629 | set_intersection(ExecutionPolicy&& exec,
 | ^
p1223.cpp:644:1: error: 'ForwardIterator' does not name a type
 644 | ForwardIterator result, Compare comp);
 | ^~~~~~~~~~~~~~~
p1223.cpp:645:10: error: 'input_iterator' has not been declared
 645 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:645:29: error: 'sentinel_for' has not been declared
 645 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:645:41: error: expected '>' before '<' token
 645 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:648:3: error: 'requires' does not name a type
 648 | requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:648:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:651:44: error: expected unqualified-id before ',' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:651:52: error: expected constructor, destructor, or type conversion before 'proj1'
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:651:62: error: expected unqualified-id before ',' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:651:70: error: expected constructor, destructor, or type conversion before 'proj2'
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:651:80: error: expected unqualified-id before ')' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:652:10: error: 'input_range' has not been declared
 652 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:652:26: error: 'input_range' has not been declared
 652 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:652:42: error: 'weakly_incrementable' has not been declared
 652 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:653:23: error: 'ranges' does not name a type
 653 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~~~~~
p1223.cpp:653:29: error: expected '>' before '::' token
 653 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~
p1223.cpp:657:3: error: 'constexpr' does not name a type
 657 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:657:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:664:35: error: expected ',' or '...' before '&&' token
 664 | set_difference(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:670:3: error: 'constexpr' does not name a type
 670 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:670:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:677:35: error: expected ',' or '...' before '&&' token
 677 | set_difference(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:681:10: error: 'input_iterator' has not been declared
 681 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:681:29: error: 'sentinel_for' has not been declared
 681 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:681:41: error: expected '>' before '<' token
 681 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:684:3: error: 'requires' does not name a type
 684 | requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:684:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:687:42: error: expected unqualified-id before ',' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:687:50: error: expected constructor, destructor, or type conversion before 'proj1'
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:687:60: error: expected unqualified-id before ',' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:687:68: error: expected constructor, destructor, or type conversion before 'proj2'
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:687:78: error: expected unqualified-id before ')' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:688:10: error: 'input_range' has not been declared
 688 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:688:26: error: 'input_range' has not been declared
 688 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:688:42: error: 'weakly_incrementable' has not been declared
 688 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:689:23: error: 'ranges' does not name a type
 689 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~~~~~
p1223.cpp:689:29: error: expected '>' before '::' token
 689 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~
p1223.cpp:690:3: error: 'requires' does not name a type
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:690:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:693:42: error: expected unqualified-id before ',' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:693:50: error: expected constructor, destructor, or type conversion before 'proj1'
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:693:60: error: expected unqualified-id before ',' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:693:68: error: expected constructor, destructor, or type conversion before 'proj2'
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:693:78: error: expected unqualified-id before ')' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:704:3: error: 'constexpr' does not name a type
 704 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:704:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:711:45: error: expected ',' or '...' before '&&' token
 711 | set_symmetric_difference(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:717:3: error: 'constexpr' does not name a type
 717 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:717:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:724:45: error: expected ',' or '...' before '&&' token
 724 | set_symmetric_difference(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:730:10: error: 'input_iterator' has not been declared
 730 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:730:29: error: 'sentinel_for' has not been declared
 730 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:730:41: error: expected '>' before '<' token
 730 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:733:3: error: 'requires' does not name a type
 733 | requires mergeable<I1, I2, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:733:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:736:52: error: expected unqualified-id before ',' token
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^
p1223.cpp:736:60: error: expected constructor, destructor, or type conversion before 'proj1'
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^~~~~
p1223.cpp:736:70: error: expected unqualified-id before ',' token
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^
p1223.cpp:737:44: error: expected constructor, destructor, or type conversion before 'proj2'
 737 | Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:737:54: error: expected unqualified-id before ')' token
 737 | Proj2 proj2 = {});
 | ^
p1223.cpp:738:10: error: 'input_range' has not been declared
 738 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:738:26: error: 'input_range' has not been declared
 738 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:738:42: error: 'weakly_incrementable' has not been declared
 738 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~~~~~~~~~~
p1223.cpp:739:23: error: 'ranges' does not name a type
 739 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~~~~~
p1223.cpp:739:29: error: expected '>' before '::' token
 739 | class Comp = ranges::less, class Proj1 = identity, class Proj2 = identity>
 | ^~
p1223.cpp:740:3: error: 'requires' does not name a type
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:740:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:743:80: error: expected unqualified-id before ',' token
 743 | ranges::set_symmetric_difference(R1&& r1, R2&& r2, O result, Comp comp = {},
 | ^
p1223.cpp:744:44: error: expected constructor, destructor, or type conversion before 'proj1'
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:744:54: error: expected unqualified-id before ',' token
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:744:62: error: expected constructor, destructor, or type conversion before 'proj2'
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:744:72: error: expected unqualified-id before ')' token
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:760:6: error: 'constexpr' does not name a type
 760 | constexpr void push_heap(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:760:6: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:762:6: error: 'constexpr' does not name a type
 762 | constexpr void push_heap(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:762:6: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:764:13: error: 'random_access_iterator' has not been declared
 764 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:764:39: error: 'sentinel_for' has not been declared
 764 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:764:51: error: expected '>' before '<' token
 764 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:766:6: error: 'requires' does not name a type
 766 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:766:6: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:768:57: error: expected unqualified-id before ',' token
 768 | ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:768:64: error: expected constructor, destructor, or type conversion before 'proj'
 768 | ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:768:73: error: expected unqualified-id before ')' token
 768 | ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:769:10: error: 'random_access_range' has not been declared
 769 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:769:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:769:46: error: 'ranges' does not name a type
 769 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:769:52: error: expected '>' before '::' token
 769 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:770:3: error: 'requires' does not name a type
 770 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:770:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:772:44: error: expected unqualified-id before ',' token
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:772:51: error: expected constructor, destructor, or type conversion before 'proj'
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:772:60: error: expected unqualified-id before ')' token
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:784:3: error: 'constexpr' does not name a type
 784 | constexpr void pop_heap(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:784:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:786:3: error: 'constexpr' does not name a type
 786 | constexpr void pop_heap(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:786:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:788:10: error: 'random_access_iterator' has not been declared
 788 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:788:36: error: 'sentinel_for' has not been declared
 788 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:788:48: error: expected '>' before '<' token
 788 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:790:3: error: 'requires' does not name a type
 790 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:790:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:792:53: error: expected unqualified-id before ',' token
 792 | ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:792:60: error: expected constructor, destructor, or type conversion before 'proj'
 792 | ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:792:69: error: expected unqualified-id before ')' token
 792 | ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:793:10: error: 'random_access_range' has not been declared
 793 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:793:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:793:46: error: 'ranges' does not name a type
 793 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:793:52: error: expected '>' before '::' token
 793 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:794:1: error: 'requires' does not name a type
 794 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:794:1: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:796:41: error: expected unqualified-id before ',' token
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:796:48: error: expected constructor, destructor, or type conversion before 'proj'
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:796:57: error: expected unqualified-id before ')' token
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:802:3: error: 'constexpr' does not name a type
 802 | constexpr void make_heap(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:802:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:804:3: error: 'constexpr' does not name a type
 804 | constexpr void make_heap(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:804:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:806:10: error: 'random_access_iterator' has not been declared
 806 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:806:36: error: 'sentinel_for' has not been declared
 806 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:806:48: error: expected '>' before '<' token
 806 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:808:3: error: 'requires' does not name a type
 808 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:808:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:810:54: error: expected unqualified-id before ',' token
 810 | ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:810:61: error: expected constructor, destructor, or type conversion before 'proj'
 810 | ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:810:70: error: expected unqualified-id before ')' token
 810 | ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:811:10: error: 'random_access_range' has not been declared
 811 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:811:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:811:46: error: 'ranges' does not name a type
 811 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:811:52: error: expected '>' before '::' token
 811 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:812:3: error: 'requires' does not name a type
 812 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:812:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:814:44: error: expected unqualified-id before ',' token
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:814:51: error: expected constructor, destructor, or type conversion before 'proj'
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:814:60: error: expected unqualified-id before ')' token
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:825:3: error: 'constexpr' does not name a type
 825 | constexpr void sort_heap(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:825:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:827:3: error: 'constexpr' does not name a type
 827 | constexpr void sort_heap(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:827:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:829:10: error: 'random_access_iterator' has not been declared
 829 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:829:36: error: 'sentinel_for' has not been declared
 829 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:829:48: error: expected '>' before '<' token
 829 | template<random_access_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:831:3: error: 'requires' does not name a type
 831 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:831:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:833:54: error: expected unqualified-id before ',' token
 833 | ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:833:61: error: expected constructor, destructor, or type conversion before 'proj'
 833 | ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:833:70: error: expected unqualified-id before ')' token
 833 | ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:834:10: error: 'random_access_range' has not been declared
 834 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:834:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:834:46: error: 'ranges' does not name a type
 834 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~
p1223.cpp:834:52: error: expected '>' before '::' token
 834 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~
p1223.cpp:835:1: error: 'requires' does not name a type
 835 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:835:1: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:837:42: error: expected unqualified-id before ',' token
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:837:49: error: expected constructor, destructor, or type conversion before 'proj'
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:837:58: error: expected unqualified-id before ')' token
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:840:1: error: 'constexpr' does not name a type
 840 | constexpr bool is_heap(RandomAccessIterator first, RandomAccessIterator last);
 | ^~~~~~~~~
p1223.cpp:840:1: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:843:31: error: expected ',' or '...' before '&&' token
 843 | bool is_heap(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:846:1: error: expected unqualified-id before 'return'
 846 | return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
 | ^~~~~~
p1223.cpp:848:3: error: 'constexpr' does not name a type
 848 | constexpr bool is_heap(RandomAccessIterator first, RandomAccessIterator last,
 | ^~~~~~~~~
p1223.cpp:848:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:852:31: error: expected ',' or '...' before '&&' token
 852 | bool is_heap(ExecutionPolicy&& exec, RandomAccessIterator first, RandomAccessIterator last, Compare comp);
 | ^~
p1223.cpp:854:1: error: expected unqualified-id before 'return'
 854 | return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
 | ^~~~~~
p1223.cpp:855:10: error: 'random_access_iterator' has not been declared
 855 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:855:36: error: 'sentinel_for' has not been declared
 855 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:855:48: error: expected '>' before '<' token
 855 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:857:63: error: expected unqualified-id before '{' token
 857 | constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:857:65: error: expected unqualified-id before ',' token
 857 | constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:857:72: error: expected constructor, destructor, or type conversion before 'proj'
 857 | constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:857:81: error: expected unqualified-id before ')' token
 857 | constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:858:10: error: 'random_access_range' has not been declared
 858 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:858:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:858:46: error: 'identity' does not name a type
 858 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:859:10: error: 'indirect_strict_weak_order' has not been declared
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:859:36: error: expected '>' before '<' token
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:860:53: error: expected unqualified-id before '{' token
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:860:55: error: expected unqualified-id before ',' token
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:860:62: error: expected constructor, destructor, or type conversion before 'proj'
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:860:71: error: expected unqualified-id before ')' token
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:862:8: error: 'indirect_strict_weak_order' does not name a type
 862 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:864:46: error: expected unqualified-id before ',' token
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:864:53: error: expected constructor, destructor, or type conversion before 'proj'
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:864:62: error: expected unqualified-id before ')' token
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:866:1: error: 'constexpr' does not name a type
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~~~~~~
p1223.cpp:866:1: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:866:70: error: expected unqualified-id before ',' token
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:866:77: error: expected constructor, destructor, or type conversion before 'proj'
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:866:86: error: expected unqualified-id before ')' token
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:872:3: error: 'constexpr' does not name a type
 872 | constexpr RandomAccessIterator
 | ^~~~~~~~~
p1223.cpp:872:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:876:34: error: expected ',' or '...' before '&&' token
 876 | is_heap_until(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:879:3: error: 'constexpr' does not name a type
 879 | constexpr RandomAccessIterator
 | ^~~~~~~~~
p1223.cpp:879:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:884:34: error: expected ',' or '...' before '&&' token
 884 | is_heap_until(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:887:10: error: 'random_access_iterator' has not been declared
 887 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:887:36: error: 'sentinel_for' has not been declared
 887 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:887:48: error: expected '>' before '<' token
 887 | template<random_access_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:889:66: error: expected unqualified-id before '{' token
 889 | constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:889:68: error: expected unqualified-id before ',' token
 889 | constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:889:75: error: expected constructor, destructor, or type conversion before 'proj'
 889 | constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:889:84: error: expected unqualified-id before ')' token
 889 | constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:890:10: error: 'random_access_range' has not been declared
 890 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:890:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:890:46: error: 'identity' does not name a type
 890 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:894:3: error: expected 'class' or 'typename' before 'constexpr'
 894 | constexpr const T& min(const T& a, const T& b);
 | ^~~~~~~~~
p1223.cpp:894:13: error: expected '>' before 'const'
 894 | constexpr const T& min(const T& a, const T& b);
 | ^~~~~
p1223.cpp:894:49: error: expected unqualified-id before ';' token
 894 | constexpr const T& min(const T& a, const T& b);
 | ^
p1223.cpp:896:3: error: 'constexpr' does not name a type
 896 | constexpr const T& min(const T& a, const T& b, Compare comp);
 | ^~~~~~~~~
p1223.cpp:896:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:897:32: error: 'identity' does not name a type
 897 | template<class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:898:10: error: 'indirect_strict_weak_order' has not been declared
 898 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:898:36: error: expected '>' before '<' token
 898 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:900:41: error: expected unqualified-id before ';' token
 900 | constexpr T min(initializer_list<T> r);
 | ^
p1223.cpp:902:3: error: 'constexpr' does not name a type
 902 | constexpr T min(initializer_list<T> r, Compare comp);
 | ^~~~~~~~~
p1223.cpp:902:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:903:10: error: 'copyable' has not been declared
 903 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:903:35: error: 'identity' does not name a type
 903 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:904:10: error: 'indirect_strict_weak_order' has not been declared
 904 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:904:36: error: expected '>' before '<' token
 904 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:905:62: error: expected unqualified-id before '{' token
 905 | constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:905:64: error: expected unqualified-id before ',' token
 905 | constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:905:71: error: expected constructor, destructor, or type conversion before 'proj'
 905 | constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:905:80: error: expected unqualified-id before ')' token
 905 | constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:906:10: error: 'input_range' has not been declared
 906 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:906:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:906:38: error: 'identity' does not name a type
 906 | template<input_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:907:10: error: 'indirect_strict_weak_order' has not been declared
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:907:36: error: expected '>' before '<' token
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:910:36: error: expected unqualified-id before '{' token
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:910:38: error: expected unqualified-id before ',' token
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:910:45: error: expected constructor, destructor, or type conversion before 'proj'
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:910:54: error: expected unqualified-id before ')' token
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:915:8: error: 'indirect_strict_weak_order' does not name a type
 915 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:918:36: error: expected unqualified-id before ',' token
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:918:43: error: expected constructor, destructor, or type conversion before 'proj'
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:918:52: error: expected unqualified-id before ')' token
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:924:3: error: 'constexpr' does not name a type
 924 | constexpr const T& max(const T& a, const T& b);
 | ^~~~~~~~~
p1223.cpp:924:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:926:3: error: 'constexpr' does not name a type
 926 | constexpr const T& max(const T& a, const T& b, Compare comp);
 | ^~~~~~~~~
p1223.cpp:926:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:927:32: error: 'identity' does not name a type
 927 | template<class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:928:10: error: 'indirect_strict_weak_order' has not been declared
 928 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:928:36: error: expected '>' before '<' token
 928 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:929:68: error: expected unqualified-id before '{' token
 929 | constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:929:70: error: expected unqualified-id before ',' token
 929 | constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:929:77: error: expected constructor, destructor, or type conversion before 'proj'
 929 | constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:929:86: error: expected unqualified-id before ')' token
 929 | constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:935:3: error: 'constexpr' does not name a type
 935 | constexpr T max(initializer_list<T> r);
 | ^~~~~~~~~
p1223.cpp:935:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:937:3: error: 'constexpr' does not name a type
 937 | constexpr T max(initializer_list<T> r, Compare comp);
 | ^~~~~~~~~
p1223.cpp:937:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:938:10: error: 'copyable' has not been declared
 938 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:938:35: error: 'identity' does not name a type
 938 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:939:10: error: 'indirect_strict_weak_order' has not been declared
 939 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:939:36: error: expected '>' before '<' token
 939 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:940:62: error: expected unqualified-id before '{' token
 940 | constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:940:64: error: expected unqualified-id before ',' token
 940 | constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:940:71: error: expected constructor, destructor, or type conversion before 'proj'
 940 | constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:940:80: error: expected unqualified-id before ')' token
 940 | constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:941:10: error: 'input_range' has not been declared
 941 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:941:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:941:38: error: 'identity' does not name a type
 941 | template<input_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:943:3: error: expected 'class' or 'typename' before 'constexpr'
 943 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
 | ^~~~~~~~~
p1223.cpp:943:13: error: expected '>' before 'pair'
 943 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
 | ^~~~
p1223.cpp:943:68: error: expected unqualified-id before ';' token
 943 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
 | ^
p1223.cpp:945:3: error: 'constexpr' does not name a type
 945 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b, Compare comp);
 | ^~~~~~~~~
p1223.cpp:945:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:946:32: error: 'identity' does not name a type
 946 | template<class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:947:10: error: 'indirect_strict_weak_order' has not been declared
 947 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:947:36: error: expected '>' before '<' token
 947 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:949:56: error: expected unqualified-id before '{' token
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:949:58: error: expected unqualified-id before ',' token
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:949:65: error: expected constructor, destructor, or type conversion before 'proj'
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:949:74: error: expected unqualified-id before ')' token
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:954:1: error: 'requires' does not name a type
 954 | requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
 | ^~~~~~~~
p1223.cpp:954:1: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:956:39: error: expected unqualified-id before ',' token
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:956:46: error: expected constructor, destructor, or type conversion before 'proj'
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:956:55: error: expected unqualified-id before ')' token
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:962:3: error: 'constexpr' does not name a type
 962 | constexpr pair<T, T> minmax(initializer_list<T> t);
 | ^~~~~~~~~
p1223.cpp:962:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:964:3: error: 'constexpr' does not name a type
 964 | constexpr pair<T, T> minmax(initializer_list<T> t, Compare comp);
 | ^~~~~~~~~
p1223.cpp:964:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:965:10: error: 'copyable' has not been declared
 965 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:965:35: error: 'identity' does not name a type
 965 | template<copyable T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:966:10: error: 'indirect_strict_weak_order' has not been declared
 966 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:966:36: error: expected '>' before '<' token
 966 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:968:55: error: expected unqualified-id before '{' token
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:968:57: error: expected unqualified-id before ',' token
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:968:64: error: expected constructor, destructor, or type conversion before 'proj'
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:968:73: error: expected unqualified-id before ')' token
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:969:10: error: 'input_range' has not been declared
 969 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:969:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:969:38: error: 'identity' does not name a type
 969 | template<input_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:970:10: error: 'indirect_strict_weak_order' has not been declared
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:970:36: error: expected '>' before '<' token
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:973:85: error: expected unqualified-id before ';' token
 973 | constexpr ForwardIterator min_element(ForwardIterator first, ForwardIterator last);
 | ^
p1223.cpp:975:46: error: expected ',' or '...' before '&&' token
 975 | ForwardIterator min_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:978:3: error: 'constexpr' does not name a type
 978 | constexpr ForwardIterator min_element(ForwardIterator first, ForwardIterator last,
 | ^~~~~~~~~
p1223.cpp:978:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:981:46: error: expected ',' or '...' before '&&' token
 981 | ForwardIterator min_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:983:10: error: 'forward_iterator' has not been declared
 983 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:983:30: error: 'sentinel_for' has not been declared
 983 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:983:42: error: expected '>' before '<' token
 983 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:985:64: error: expected unqualified-id before '{' token
 985 | constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:985:66: error: expected unqualified-id before ',' token
 985 | constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:985:73: error: expected constructor, destructor, or type conversion before 'proj'
 985 | constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:985:82: error: expected unqualified-id before ')' token
 985 | constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:986:10: error: 'forward_range' has not been declared
 986 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:986:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:986:40: error: 'identity' does not name a type
 986 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:987:10: error: 'indirect_strict_weak_order' has not been declared
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:987:36: error: expected '>' before '<' token
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:989:44: error: expected unqualified-id before '{' token
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:989:46: error: expected unqualified-id before ',' token
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:989:53: error: expected constructor, destructor, or type conversion before 'proj'
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:989:62: error: expected unqualified-id before ')' token
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:991:14: error: expected ')' before '(' token
 991 | bool(invoke(comp, invoke(proj, *j), invoke(proj, *i)))
 | ~ ^
 | )
p1223.cpp:996:44: error: expected unqualified-id before ',' token
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:996:51: error: expected constructor, destructor, or type conversion before 'proj'
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:996:60: error: expected unqualified-id before ')' token
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:998:12: error: expected ')' before '(' token
 998 | bool(invoke(comp, invoke(proj, *i), invoke(proj, *j)))
 | ~ ^
 | )
p1223.cpp:1002:47: error: expected unqualified-id before ',' token
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1002:54: error: expected constructor, destructor, or type conversion before 'proj'
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1002:63: error: expected unqualified-id before ')' token
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1005:3: error: 'constexpr' does not name a type
 1005 | constexpr ForwardIterator max_element(ForwardIterator first, ForwardIterator last);
 | ^~~~~~~~~
p1223.cpp:1005:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1007:46: error: expected ',' or '...' before '&&' token
 1007 | ForwardIterator max_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1010:3: error: 'constexpr' does not name a type
 1010 | constexpr ForwardIterator max_element(ForwardIterator first, ForwardIterator last,
 | ^~~~~~~~~
p1223.cpp:1010:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1013:46: error: expected ',' or '...' before '&&' token
 1013 | ForwardIterator max_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1016:10: error: 'forward_iterator' has not been declared
 1016 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:1016:30: error: 'sentinel_for' has not been declared
 1016 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:1016:42: error: expected '>' before '<' token
 1016 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:1018:64: error: expected unqualified-id before '{' token
 1018 | constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1018:66: error: expected unqualified-id before ',' token
 1018 | constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1018:73: error: expected constructor, destructor, or type conversion before 'proj'
 1018 | constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1018:82: error: expected unqualified-id before ')' token
 1018 | constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1019:10: error: 'forward_range' has not been declared
 1019 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:1019:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1019:40: error: 'identity' does not name a type
 1019 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:1021:3: error: expected 'class' or 'typename' before 'constexpr'
 1021 | constexpr pair<ForwardIterator, ForwardIterator>
 | ^~~~~~~~~
p1223.cpp:1021:13: error: expected '>' before 'pair'
 1021 | constexpr pair<ForwardIterator, ForwardIterator>
 | ^~~~
p1223.cpp:1022:64: error: expected unqualified-id before ';' token
 1022 | minmax_element(ForwardIterator first, ForwardIterator last);
 | ^
p1223.cpp:1025:35: error: expected ',' or '...' before '&&' token
 1025 | minmax_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1028:3: error: 'constexpr' does not name a type
 1028 | constexpr pair<ForwardIterator, ForwardIterator>
 | ^~~~~~~~~
p1223.cpp:1028:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1032:35: error: expected ',' or '...' before '&&' token
 1032 | minmax_element(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1034:10: error: 'forward_iterator' has not been declared
 1034 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~~~~~
p1223.cpp:1034:30: error: 'sentinel_for' has not been declared
 1034 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^~~~~~~~~~~~
p1223.cpp:1034:42: error: expected '>' before '<' token
 1034 | template<forward_iterator I, sentinel_for<I> S, class Proj = identity,
 | ^
p1223.cpp:1037:57: error: expected unqualified-id before '{' token
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1037:59: error: expected unqualified-id before ',' token
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1037:66: error: expected constructor, destructor, or type conversion before 'proj'
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1037:75: error: expected unqualified-id before ')' token
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1038:10: error: 'forward_range' has not been declared
 1038 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:1038:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1038:40: error: 'identity' does not name a type
 1038 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:1039:10: error: 'indirect_strict_weak_order' has not been declared
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1039:36: error: expected '>' before '<' token
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:1043:67: error: expected unqualified-id before '{' token
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1043:69: error: expected unqualified-id before ',' token
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1043:76: error: expected constructor, destructor, or type conversion before 'proj'
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1043:85: error: expected unqualified-id before ')' token
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1052:3: error: 'constexpr' does not name a type
 1052 | constexpr const T& clamp(const T& v, const T& lo, const T& hi);
 | ^~~~~~~~~
p1223.cpp:1052:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1054:3: error: 'constexpr' does not name a type
 1054 | constexpr const T& clamp(const T& v, const T& lo, const T& hi, Compare comp);
 | ^~~~~~~~~
p1223.cpp:1054:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1055:32: error: 'identity' does not name a type
 1055 | template<class T, class Proj = identity,
 | ^~~~~~~~
p1223.cpp:1056:10: error: 'indirect_strict_weak_order' has not been declared
 1056 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1056:36: error: expected '>' before '<' token
 1056 | indirect_strict_weak_order<projected<const T*, Proj>> Comp = ranges::less>
 | ^
p1223.cpp:1061:73: error: expected unqualified-id before ';' token
 1061 | InputIterator2 first2, InputIterator2 last2);
 | ^
p1223.cpp:1064:44: error: expected ',' or '...' before '&&' token
 1064 | lexicographical_compare(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1068:3: error: 'constexpr' does not name a type
 1068 | constexpr bool
 | ^~~~~~~~~
p1223.cpp:1068:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1075:44: error: expected ',' or '...' before '&&' token
 1075 | lexicographical_compare(ExecutionPolicy&& exec,
 | ^~
p1223.cpp:1079:10: error: 'input_iterator' has not been declared
 1079 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~~~
p1223.cpp:1079:29: error: 'sentinel_for' has not been declared
 1079 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^~~~~~~~~~~~
p1223.cpp:1079:41: error: expected '>' before '<' token
 1079 | template<input_iterator I1, sentinel_for<I1> S1, input_iterator I2, sentinel_for<I2> S2,
 | ^
p1223.cpp:1085:49: error: expected unqualified-id before '{' token
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1085:51: error: expected unqualified-id before ',' token
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1085:59: error: expected constructor, destructor, or type conversion before 'proj1'
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1085:69: error: expected unqualified-id before ',' token
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1085:77: error: expected constructor, destructor, or type conversion before 'proj2'
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1085:87: error: expected unqualified-id before ')' token
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1086:10: error: 'input_range' has not been declared
 1086 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:1086:26: error: 'input_range' has not been declared
 1086 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:1086:56: error: 'identity' does not name a type
 1086 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~
p1223.cpp:1087:24: error: 'identity' does not name a type
 1087 | class Proj2 = identity,
 | ^~~~~~~~
p1223.cpp:1088:10: error: 'indirect_strict_weak_order' has not been declared
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1088:36: error: expected '>' before '<' token
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^
p1223.cpp:1091:67: error: expected unqualified-id before '{' token
 1091 | ranges::lexicographical_compare(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:1091:69: error: expected unqualified-id before ',' token
 1091 | ranges::lexicographical_compare(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:1092:43: error: expected constructor, destructor, or type conversion before 'proj1'
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1092:53: error: expected unqualified-id before ',' token
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1092:61: error: expected constructor, destructor, or type conversion before 'proj2'
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1092:71: error: expected unqualified-id before ')' token
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1097:8: error: expected unqualified-id before 'for'
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~~
p1223.cpp:1097:16: error: 'first1' does not name a type
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~~~~~
p1223.cpp:1097:53: error: expected unqualified-id before '++' token
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~
p1223.cpp:1101:8: error: expected unqualified-id before 'return'
 1101 | return first1 == last1 && first2 != last2;
 | ^~~~~~
p1223.cpp:1105:3: error: 'constexpr' does not name a type
 1105 | constexpr auto
 | ^~~~~~~~~
p1223.cpp:1105:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1115:3: error: 'constexpr' does not name a type
 1115 | constexpr auto
 | ^~~~~~~~~
p1223.cpp:1115:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1119:1: error: expected unqualified-id before 'return'
 1119 | return lexicographical_compare_three_way(b1, e1, b2, e2, compare_three_way());
 | ^~~~~~
p1223.cpp:1122:3: error: 'constexpr' does not name a type
 1122 | constexpr bool next_permutation(BidirectionalIterator first,
 | ^~~~~~~~~
p1223.cpp:1122:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1125:3: error: 'constexpr' does not name a type
 1125 | constexpr bool next_permutation(BidirectionalIterator first,
 | ^~~~~~~~~
p1223.cpp:1125:3: note: C++11 'constexpr' only available with '-std=c++11' or '-std=gnu++11'
p1223.cpp:1127:10: error: 'bidirectional_iterator' has not been declared
 1127 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1127:36: error: 'sentinel_for' has not been declared
 1127 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^~~~~~~~~~~~
p1223.cpp:1127:48: error: expected '>' before '<' token
 1127 | template<bidirectional_iterator I, sentinel_for<I> S, class Comp = ranges::less,
 | ^
p1223.cpp:1129:3: error: 'requires' does not name a type
 1129 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:1129:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:1131:61: error: expected unqualified-id before ',' token
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1131:68: error: expected constructor, destructor, or type conversion before 'proj'
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1131:77: error: expected unqualified-id before ')' token
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1132:10: error: 'bidirectional_range' has not been declared
 1132 | template<bidirectional_range R, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:1132:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1132:46: error: 'ranges' does not name a type
 1132 | template<bidirectional_range R, class Comp = ranges::less,
 | ^~~~~~
p1223.cpp:1132:52: error: expected '>' before '::' token
 1132 | template<bidirectional_range R, class Comp = ranges::less,
 | ^~
p1223.cpp:1134:3: error: 'requires' does not name a type
 1134 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:1134:3: note: 'requires' only available with '-std=c++20' or '-fconcepts'
p1223.cpp:1136:51: error: expected unqualified-id before ',' token
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1136:58: error: expected constructor, destructor, or type conversion before 'proj'
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1136:67: error: expected unqualified-id before ')' token
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^

$ g++ p1223.cpp -std=2b -o p1223g -I. -Wall
p1223.cpp:32:65: error: 'I std::ranges::sort(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 32 | ranges::sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:33:10: error: 'random_access_range' has not been declared
 33 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:33:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:34:1: error: expected unqualified-id before '[' token
 34 | [alg.sort] [sort]
 | ^
p1223.cpp:37:37: error: expected unqualified-id before ',' token
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:37:44: error: expected constructor, destructor, or type conversion before 'proj'
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:37:53: error: expected unqualified-id before ')' token
 37 | ranges::sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:54:72: error: 'I std::ranges::stable_sort(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 54 | I ranges::stable_sort(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:55:10: error: 'random_access_range' has not been declared
 55 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:55:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:56:21: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 56 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
In file included from /usr/local/include/c++/12.1.0/string_view:50,
 from /usr/local/include/c++/12.1.0/bits/basic_string.h:48,
 from /usr/local/include/c++/12.1.0/string:53,
 from /usr/local/include/c++/12.1.0/bits/locale_classes.h:40,
 from /usr/local/include/c++/12.1.0/bits/ios_base.h:41,
 from /usr/local/include/c++/12.1.0/ios:42,
 from /usr/local/include/c++/12.1.0/ostream:38,
 from /usr/local/include/c++/12.1.0/iostream:39,
 from N4910.h:2,
 from p1223.cpp:10:
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:56:12: error: parse error in template argument list
 56 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:56:12: error: template argument 1 is invalid
p1223.cpp:56:34: error: expected unqualified-id before ',' token
 56 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:58:46: error: expected unqualified-id before ',' token
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:58:53: error: expected constructor, destructor, or type conversion before 'proj'
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:58:62: error: expected unqualified-id before ')' token
 58 | ranges::stable_sort(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:92:81: error: 'I std::ranges::partial_sort(I, I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 92 | ranges::partial_sort(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:96:20: error: expected unqualified-id before '=' token
 96 | class Proj1 = identity, class Proj2 = identity>
 | ^
p1223.cpp:102:66: error: expected unqualified-id before ',' token
 102 | ranges::partial_sort_copy(R1&& r, R2&& result_r, Comp comp = {},
 | ^
p1223.cpp:103:35: error: expected constructor, destructor, or type conversion before 'proj1'
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:103:45: error: expected unqualified-id before ',' token
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:103:53: error: expected constructor, destructor, or type conversion before 'proj2'
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:103:63: error: expected unqualified-id before ')' token
 103 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:105:10: error: 'random_access_range' has not been declared
 105 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:105:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:106:21: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 106 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:106:12: error: parse error in template argument list
 106 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:106:12: error: template argument 1 is invalid
p1223.cpp:106:34: error: expected unqualified-id before ',' token
 106 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:108:65: error: expected unqualified-id before ',' token
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:108:72: error: expected constructor, destructor, or type conversion before 'proj'
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:108:81: error: expected unqualified-id before ')' token
 108 | ranges::partial_sort(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:110:1: error: expected unqualified-id before 'return'
 110 | return ranges::partial_sort(ranges::begin(r), middle, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:142:21: error: 'partial_sort_copy_result' in namespace 'std::ranges' does not name a template type
 142 | constexpr ranges::partial_sort_copy_result<I1, I2>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:144:45: error: expected unqualified-id before ',' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:144:53: error: expected constructor, destructor, or type conversion before 'proj1'
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:144:63: error: expected unqualified-id before ',' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:144:71: error: expected constructor, destructor, or type conversion before 'proj2'
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:144:81: error: expected unqualified-id before ')' token
 144 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:145:10: error: 'input_range' has not been declared
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:145:26: error: 'random_access_range' has not been declared
 145 | template<input_range R1, random_access_range R2, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:149:14: error: expected ')' before '(' token
 149 | bool(invoke(comp, invoke(proj1, *a1), invoke(proj2, *y2))).
 | ~ ^
 | )
p1223.cpp:149:14: error: expected '>' before '(' token
p1223.cpp:149:60: error: expected unqualified-id before ')' token
 149 | bool(invoke(comp, invoke(proj1, *a1), invoke(proj2, *y2))).
 | ^
p1223.cpp:160:8: error: found ':' in nested-name-specifier, expected '::'
 160 | Effects: Equivalent to: return is_sorted_until(first, last) == last;
 | ^
 | ::
p1223.cpp:160:1: error: 'Effects' does not name a type
 160 | Effects: Equivalent to: return is_sorted_until(first, last) == last;
 | ^~~~~~~
p1223.cpp:165:1: error: expected unqualified-id before 'return'
 165 | return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
 | ^~~~~~
p1223.cpp:175:1: error: expected unqualified-id before 'return'
 175 | return is_sorted_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
 | ^~~~~~
p1223.cpp:178:83: error: 'bool std::ranges::is_sorted(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 178 | constexpr bool ranges::is_sorted(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:179:10: error: 'forward_range' has not been declared
 179 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:179:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:180:45: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:180:57: error: wrong number of template arguments (1, should be 2)
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
In file included from /usr/local/include/c++/12.1.0/bits/stl_iterator_base_types.h:71,
 from /usr/local/include/c++/12.1.0/bits/stl_construct.h:61,
 from /usr/local/include/c++/12.1.0/bits/char_traits.h:46,
 from /usr/local/include/c++/12.1.0/ios:40:
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:180:8: error: template argument 2 is invalid
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:180:67: error: 'Comp' does not name a type
 180 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:181:55: error: expected unqualified-id before ',' token
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:181:62: error: expected constructor, destructor, or type conversion before 'proj'
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:181:71: error: expected unqualified-id before ')' token
 181 | constexpr bool ranges::is_sorted(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:201:86: error: 'I std::ranges::is_sorted_until(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 201 | constexpr I ranges::is_sorted_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:202:10: error: 'forward_range' has not been declared
 202 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:202:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:203:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:203:59: error: wrong number of template arguments (1, should be 2)
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:203:10: error: template argument 2 is invalid
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:203:69: error: 'Comp' does not name a type
 203 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:205:50: error: expected unqualified-id before ',' token
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:205:57: error: expected constructor, destructor, or type conversion before 'proj'
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:205:66: error: expected unqualified-id before ')' token
 205 | ranges::is_sorted_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:207:1: error: expected unqualified-id before 'requires'
 207 | requires sortable<I, Comp, Proj>
 | ^~~~~~~~
p1223.cpp:209:61: error: expected unqualified-id before ',' token
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:209:68: error: expected constructor, destructor, or type conversion before 'proj'
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:209:77: error: expected unqualified-id before ')' token
 209 | ranges::nth_element(I first, I nth, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:212:1: error: 'ments' does not name a type
 212 | ments.
 | ^~~~~
p1223.cpp:232:22: error: expected unqualified-id before '>' token
 232 | ranges::less>
 | ^
p1223.cpp:234:60: error: expected unqualified-id before ',' token
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:234:67: error: expected constructor, destructor, or type conversion before 'proj'
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:234:76: error: expected unqualified-id before ')' token
 234 | ranges::lower_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:236:12: error: expected ')' before '(' token
 236 | bool(invoke(comp, invoke(proj, e), value)).
 | ~ ^
 | )
p1223.cpp:243:61: error: expected unqualified-id before ',' token
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:243:68: error: expected constructor, destructor, or type conversion before 'proj'
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:243:77: error: expected unqualified-id before ')' token
 243 | ranges::nth_element(R&& r, iterator_t<R> nth, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:245:1: error: expected unqualified-id before 'return'
 245 | return ranges::nth_element(ranges::begin(r), nth, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:260:49: error: 'I std::ranges::lower_bound(I, S, const T&, Comp, Proj)' should have been declared inside 'std::ranges'
 260 | Proj proj = {});
 | ^
p1223.cpp:261:10: error: 'forward_range' has not been declared
 261 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:261:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:262:57: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:262:69: error: wrong number of template arguments (1, should be 2)
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:262:10: error: wrong number of template arguments (4, should be at least 2)
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:739:13: note: provided for 'template<class _Fn, class _I1, class _I2> concept std::indirect_strict_weak_order'
 739 | concept indirect_strict_weak_order
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:262:79: error: 'Comp' does not name a type
 262 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~
p1223.cpp:272:22: error: expected unqualified-id before '>' token
 272 | ranges::less>
 | ^
p1223.cpp:274:60: error: expected unqualified-id before ',' token
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:274:67: error: expected constructor, destructor, or type conversion before 'proj'
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:274:76: error: expected unqualified-id before ')' token
 274 | ranges::equal_range(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:278:11: error: expected unqualified-id before '{' token
 278 | {lower_bound(first, last, value, comp),
 | ^
p1223.cpp:281:31: error: expected constructor, destructor, or type conversion before '(' token
 281 | ranges::upper_bound(first, last, value, comp, proj)}
 | ^
p1223.cpp:281:63: error: expected declaration before '}' token
 281 | ranges::upper_bound(first, last, value, comp, proj)}
 | ^
p1223.cpp:285:98: error: 'I std::ranges::upper_bound(I, S, const T&, Comp, Proj)' should have been declared inside 'std::ranges'
 285 | constexpr I ranges::upper_bound(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:286:10: error: 'forward_range' has not been declared
 286 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:286:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:287:57: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:287:69: error: wrong number of template arguments (1, should be 2)
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:287:10: error: wrong number of template arguments (4, should be at least 2)
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:739:13: note: provided for 'template<class _Fn, class _I1, class _I2> concept std::indirect_strict_weak_order'
 739 | concept indirect_strict_weak_order
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:287:79: error: 'Comp' does not name a type
 287 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~
p1223.cpp:290:62: error: expected unqualified-id before ',' token
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:290:69: error: expected constructor, destructor, or type conversion before 'proj'
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:290:78: error: expected unqualified-id before ')' token
 290 | ranges::upper_bound(R&& r, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:292:1: error: expected unqualified-id before '!' token
 292 | !bool(invoke(comp, value, invoke(proj, e))).
 | ^
p1223.cpp:306:13: error: 'subrange' does not name a type
 306 | constexpr subrange<I>
 | ^~~~~~~~
p1223.cpp:307:72: error: expected unqualified-id before ',' token
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:307:79: error: expected constructor, destructor, or type conversion before 'proj'
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:307:88: error: expected unqualified-id before ')' token
 307 | ranges::equal_range(I first, S last, const T& value, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:308:10: error: 'forward_range' has not been declared
 308 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:308:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:309:57: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:309:69: error: wrong number of template arguments (1, should be 2)
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:309:10: error: wrong number of template arguments (4, should be at least 2)
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:739:13: note: provided for 'template<class _Fn, class _I1, class _I2> concept std::indirect_strict_weak_order'
 739 | concept indirect_strict_weak_order
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:309:79: error: 'Comp' does not name a type
 309 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~
p1223.cpp:322:54: error: 'bool std::ranges::binary_search(I, S, const T&, Comp, Proj)' should have been declared inside 'std::ranges'
 322 | Proj proj = {});
 | ^
p1223.cpp:323:10: error: 'forward_range' has not been declared
 323 | template<forward_range R, class T, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:323:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:324:57: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:324:69: error: wrong number of template arguments (1, should be 2)
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:324:10: error: wrong number of template arguments (4, should be at least 2)
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:739:13: note: provided for 'template<class _Fn, class _I1, class _I2> concept std::indirect_strict_weak_order'
 739 | concept indirect_strict_weak_order
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:324:79: error: 'Comp' does not name a type
 324 | indirect_strict_weak_order<const T*, projected<iterator_t<R>, Proj>> Comp =
 | ^~~~
p1223.cpp:326:77: error: expected unqualified-id before ',' token
 326 | constexpr bool ranges::binary_search(R&& r, const T& value, Comp comp = {},
 | ^
p1223.cpp:327:45: error: expected constructor, destructor, or type conversion before 'proj'
 327 | Proj proj = {});
 | ^~~~
p1223.cpp:327:54: error: expected unqualified-id before ')' token
 327 | Proj proj = {});
 | ^
p1223.cpp:331:43: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 331 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:331:55: error: wrong number of template arguments (1, should be 2)
 331 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:331:58: error: 'Proj' was not declared in this scope; did you mean 'Proj1'?
 331 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~
 | Proj1
p1223.cpp:331:8: error: template argument 1 is invalid
 331 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:331:8: error: template argument 2 is invalid
p1223.cpp:331:8: error: '<expression error>' does not name a type
p1223.cpp:332:71: error: expected unqualified-id before ')' token
 332 | constexpr bool ranges::is_partitioned(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:345:83: error: 'bool std::ranges::is_partitioned(I, S, Pred, Proj)' should have been declared inside 'std::ranges'
 345 | constexpr bool ranges::is_partitioned(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:346:10: error: 'input_range' has not been declared
 346 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:346:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:348:3: error: expected 'class' or 'typename' before 'constexpr'
 348 | constexpr ForwardIterator
 | ^~~~~~~~~
p1223.cpp:348:3: error: expected identifier before 'constexpr'
p1223.cpp:348:3: error: expected '>' before 'constexpr'
p1223.cpp:349:75: error: expected unqualified-id before ';' token
 349 | partition(ForwardIterator first, ForwardIterator last, Predicate pred);
 | ^
p1223.cpp:356:13: error: 'subrange' does not name a type
 356 | constexpr subrange<I>
 | ^~~~~~~~
p1223.cpp:357:65: error: expected unqualified-id before ')' token
 357 | ranges::partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:358:10: error: 'forward_range' has not been declared
 358 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:358:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:359:45: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:359:57: error: wrong number of template arguments (1, should be 2)
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:359:10: error: wrong number of template arguments (3, should be 2)
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:710:13: note: provided for 'template<class _Fn, class _Iter> concept std::indirect_unary_predicate'
 710 | concept indirect_unary_predicate = indirectly_readable<_Iter>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:359:67: error: 'Pred' does not name a type
 359 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~
p1223.cpp:362:51: error: expected unqualified-id before ')' token
 362 | ranges::partition(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:371:43: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 371 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:371:55: error: wrong number of template arguments (1, should be 2)
 371 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:371:58: error: 'Proj' was not declared in this scope; did you mean 'Proj1'?
 371 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~
 | Proj1
p1223.cpp:371:8: error: template argument 1 is invalid
 371 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:371:8: error: template argument 2 is invalid
p1223.cpp:371:8: error: '<expression error>' does not name a type
p1223.cpp:373:81: error: expected unqualified-id before ')' token
 373 | borrowed_subrange_t<R> ranges::stable_partition(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:374:1: error: 'Let' does not name a type
 374 | Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
 | ^~~
p1223.cpp:374:24: error: expected unqualified-id before 'for'
 374 | Let proj be identity{} for the overloads with no parameter named proj and let E(x) be bool(invoke( pred, invoke(proj, x))).
 | ^~~
p1223.cpp:392:3: error: 'subrange' does not name a type
 392 | subrange<I> ranges::stable_partition(I first, S last, Pred pred, Proj proj = {});
 | ^~~~~~~~
p1223.cpp:392:82: error: expected unqualified-id before ')' token
 392 | subrange<I> ranges::stable_partition(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:393:10: error: 'bidirectional_range' has not been declared
 393 | template<bidirectional_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:393:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:395:3: error: expected 'class' or 'typename' before 'constexpr'
 395 | constexpr pair<OutputIterator1, OutputIterator2>
 | ^~~~~~~~~
p1223.cpp:395:3: error: expected identifier before 'constexpr'
p1223.cpp:395:3: error: expected '>' before 'constexpr'
p1223.cpp:397:88: error: expected unqualified-id before ';' token
 397 | OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred);
 | ^
p1223.cpp:407:21: error: 'partition_copy_result' in namespace 'std::ranges' does not name a template type
 407 | constexpr ranges::partition_copy_result<I, O1, O2>
 | ^~~~~~~~~~~~~~~~~~~~~
p1223.cpp:409:42: error: expected unqualified-id before ')' token
 409 | Proj proj = {});
 | ^
p1223.cpp:410:10: error: 'input_range' has not been declared
 410 | template<input_range R, weakly_incrementable O1, weakly_incrementable O2,
 | ^~~~~~~~~~~
p1223.cpp:410:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:412:45: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:412:57: error: wrong number of template arguments (1, should be 2)
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:412:10: error: wrong number of template arguments (3, should be 2)
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:710:13: note: provided for 'template<class _Fn, class _Iter> concept std::indirect_unary_predicate'
 710 | concept indirect_unary_predicate = indirectly_readable<_Iter>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:412:67: error: 'Pred' does not name a type
 412 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~
p1223.cpp:416:87: error: expected unqualified-id before ')' token
 416 | ranges::partition_copy(R&& r, O1 out_true, O2 out_false, Pred pred, Proj proj = {});
 | ^
p1223.cpp:426:43: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 426 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:426:55: error: wrong number of template arguments (1, should be 2)
 426 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:426:58: error: 'Proj' was not declared in this scope; did you mean 'Proj1'?
 426 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~
 | Proj1
p1223.cpp:426:8: error: template argument 1 is invalid
 426 | indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:426:8: error: template argument 2 is invalid
p1223.cpp:426:8: error: '<expression error>' does not name a type
p1223.cpp:428:59: error: expected unqualified-id before ')' token
 428 | ranges::partition_point(R&& r, Pred pred, Proj proj = {});
 | ^
p1223.cpp:438:81: error: 'I std::ranges::partition_point(I, S, Pred, Proj)' should have been declared inside 'std::ranges'
 438 | constexpr I ranges::partition_point(I first, S last, Pred pred, Proj proj = {});
 | ^
p1223.cpp:439:10: error: 'forward_range' has not been declared
 439 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:439:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:443:3: error: expected 'class' or 'typename' before 'constexpr'
 443 | constexpr OutputIterator
 | ^~~~~~~~~
p1223.cpp:443:3: error: expected identifier before 'constexpr'
p1223.cpp:443:3: error: expected '>' before 'constexpr'
p1223.cpp:446:33: error: expected unqualified-id before ';' token
 446 | OutputIterator result);
 | ^
p1223.cpp:471:21: error: 'merge_result' in namespace 'std::ranges' does not name a template type; did you mean 'move_result'?
 471 | constexpr ranges::merge_result<I1, I2, O>
 | ^~~~~~~~~~~~
 | move_result
p1223.cpp:473:33: error: expected unqualified-id before ',' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:473:41: error: expected constructor, destructor, or type conversion before 'proj1'
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:473:51: error: expected unqualified-id before ',' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:473:59: error: expected constructor, destructor, or type conversion before 'proj2'
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:473:69: error: expected unqualified-id before ')' token
 473 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:474:10: error: 'input_range' has not been declared
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:474:26: error: 'input_range' has not been declared
 474 | template<input_range R1, input_range R2, weakly_incrementable O, class Comp = ranges::less,
 | ^~~~~~~~~~~
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:22: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:476:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:476:12: error: wrong number of template arguments (1, should be at least 3)
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:905:13: note: provided for 'template<class _I1, class _I2, class _Out, class _Rel, class _P1, class _P2> concept std::mergeable'
 905 | concept mergeable = input_iterator<_I1> && input_iterator<_I2>
 | ^~~~~~~~~
p1223.cpp:476:36: error: expected unqualified-id before ',' token
 476 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^
p1223.cpp:479:33: error: expected unqualified-id before ',' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:479:41: error: expected constructor, destructor, or type conversion before 'proj1'
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:479:51: error: expected unqualified-id before ',' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:479:59: error: expected constructor, destructor, or type conversion before 'proj2'
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:479:69: error: expected unqualified-id before ')' token
 479 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:509:84: error: 'I std::ranges::inplace_merge(I, I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 509 | I ranges::inplace_merge(I first, I middle, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:521:1: error: expected identifier before 'template'
 521 | template<bidirectional_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~
p1223.cpp:521:1: error: expected ',' or '...' before 'template'
p1223.cpp:524:83: error: expected ')' before ';' token
 524 | ranges::inplace_merge(R&& r, iterator_t<R> middle, Comp comp = {}, Proj proj = {});
 | ^
 | )
p1223.cpp:520:32: note: to match this '('
 520 | constexpr bool includes(InputIterator1 first1, InputIterator1 last1,
 | ^
p1223.cpp:526:1: error: expected unqualified-id before 'return'
 526 | return ranges::inplace_merge(ranges::begin(r), middle, ranges::end(r), comp, proj);
 | ^~~~~~
p1223.cpp:529:1: error: 'InputIterator2' does not name a type
 529 | InputIterator2 first2, InputIterator2 last2);
 | ^~~~~~~~~~~~~~
p1223.cpp:548:69: error: 'bool std::ranges::includes(I1, S1, I2, S2, Comp, Proj1, Proj2)' should have been declared inside 'std::ranges'
 548 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:549:10: error: 'input_range' has not been declared
 549 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:549:26: error: 'input_range' has not been declared
 549 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:551:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:551:60: error: wrong number of template arguments (1, should be 2)
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:551:10: error: template argument 2 is invalid
 551 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:552:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:552:60: error: wrong number of template arguments (1, should be 2)
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:552:68: error: expected '>' before '>>' token
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
p1223.cpp:552:71: error: 'Comp' does not name a type
 552 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~~~
p1223.cpp:553:67: error: expected unqualified-id before ',' token
 553 | constexpr bool ranges::includes(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:554:41: error: expected constructor, destructor, or type conversion before 'proj1'
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:554:51: error: expected unqualified-id before ',' token
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:554:59: error: expected constructor, destructor, or type conversion before 'proj2'
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:554:69: error: expected unqualified-id before ')' token
 554 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:589:21: error: 'set_union_result' in namespace 'std::ranges' does not name a template type
 589 | constexpr ranges::set_union_result<I1, I2, O>
 | ^~~~~~~~~~~~~~~~
p1223.cpp:590:89: error: expected unqualified-id before ',' token
 590 | ranges::set_union(I1 first1, S1 last1, I2 first2, S2 last2, O result, Comp comp = {},
 | ^
p1223.cpp:591:29: error: expected constructor, destructor, or type conversion before 'proj1'
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:591:39: error: expected unqualified-id before ',' token
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:591:47: error: expected constructor, destructor, or type conversion before 'proj2'
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:591:57: error: expected unqualified-id before ')' token
 591 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:592:10: error: 'input_range' has not been declared
 592 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:592:26: error: 'input_range' has not been declared
 592 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:22: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:594:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:594:12: error: wrong number of template arguments (1, should be at least 3)
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:905:13: note: provided for 'template<class _I1, class _I2, class _Out, class _Rel, class _P1, class _P2> concept std::mergeable'
 905 | concept mergeable = input_iterator<_I1> && input_iterator<_I2>
 | ^~~~~~~~~
p1223.cpp:594:36: error: expected unqualified-id before ',' token
 594 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^
p1223.cpp:596:65: error: expected unqualified-id before ',' token
 596 | ranges::set_union(R1&& r1, R2&& r2, O result, Comp comp = {},
 | ^
p1223.cpp:597:29: error: expected constructor, destructor, or type conversion before 'proj1'
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:597:39: error: expected unqualified-id before ',' token
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:597:47: error: expected constructor, destructor, or type conversion before 'proj2'
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:597:57: error: expected unqualified-id before ')' token
 597 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:632:1: error: expected identifier before 'requires'
 632 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~
p1223.cpp:632:1: error: expected ',' or '...' before 'requires'
p1223.cpp:635:79: error: expected ')' before ';' token
 635 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
 | )
p1223.cpp:629:21: note: to match this '('
 629 | set_intersection(ExecutionPolicy&& exec,
 | ^
p1223.cpp:644:1: error: 'ForwardIterator' does not name a type
 644 | ForwardIterator result, Compare comp);
 | ^~~~~~~~~~~~~~~
p1223.cpp:649:21: error: 'set_intersection_result' in namespace 'std::ranges' does not name a template type
 649 | constexpr ranges::set_intersection_result<I1, I2, O>
 | ^~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:651:44: error: expected unqualified-id before ',' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:651:52: error: expected constructor, destructor, or type conversion before 'proj1'
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:651:62: error: expected unqualified-id before ',' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:651:70: error: expected constructor, destructor, or type conversion before 'proj2'
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:651:80: error: expected unqualified-id before ')' token
 651 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:652:10: error: 'input_range' has not been declared
 652 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:652:26: error: 'input_range' has not been declared
 652 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:658:5: error: too many template-parameter-lists
 658 | set_difference(InputIterator1 first1, InputIterator1 last1,
 | ^~~~~~~~~~~~~~
p1223.cpp:685:21: error: 'set_difference_result' in namespace 'std::ranges' does not name a template type
 685 | constexpr ranges::set_difference_result<I1, O>
 | ^~~~~~~~~~~~~~~~~~~~~
p1223.cpp:687:42: error: expected unqualified-id before ',' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:687:50: error: expected constructor, destructor, or type conversion before 'proj1'
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:687:60: error: expected unqualified-id before ',' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:687:68: error: expected constructor, destructor, or type conversion before 'proj2'
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:687:78: error: expected unqualified-id before ')' token
 687 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:688:10: error: 'input_range' has not been declared
 688 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:688:26: error: 'input_range' has not been declared
 688 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:22: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:690:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:690:12: error: wrong number of template arguments (1, should be at least 3)
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:905:13: note: provided for 'template<class _I1, class _I2, class _Out, class _Rel, class _P1, class _P2> concept std::mergeable'
 905 | concept mergeable = input_iterator<_I1> && input_iterator<_I2>
 | ^~~~~~~~~
p1223.cpp:690:36: error: expected unqualified-id before ',' token
 690 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^
p1223.cpp:693:42: error: expected unqualified-id before ',' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:693:50: error: expected constructor, destructor, or type conversion before 'proj1'
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:693:60: error: expected unqualified-id before ',' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:693:68: error: expected constructor, destructor, or type conversion before 'proj2'
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:693:78: error: expected unqualified-id before ')' token
 693 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:734:21: error: 'set_symmetric_difference_result' in namespace 'std::ranges' does not name a template type
 734 | constexpr ranges::set_symmetric_difference_result<I1, I2, O>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:736:52: error: expected unqualified-id before ',' token
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^
p1223.cpp:736:60: error: expected constructor, destructor, or type conversion before 'proj1'
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^~~~~
p1223.cpp:736:70: error: expected unqualified-id before ',' token
 736 | Comp comp = {}, Proj1 proj1 = {},
 | ^
p1223.cpp:737:44: error: expected constructor, destructor, or type conversion before 'proj2'
 737 | Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:737:54: error: expected unqualified-id before ')' token
 737 | Proj2 proj2 = {});
 | ^
p1223.cpp:738:10: error: 'input_range' has not been declared
 738 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:738:26: error: 'input_range' has not been declared
 738 | template<input_range R1, input_range R2, weakly_incrementable O,
 | ^~~~~~~~~~~
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:22: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:740:33: error: 'R1' was not declared in this scope; did you mean 'y1'?
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~
 | y1
p1223.cpp:740:12: error: wrong number of template arguments (1, should be at least 3)
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^~~~~~~~~~~~~~~~~~~~~~~~
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:905:13: note: provided for 'template<class _I1, class _I2, class _Out, class _Rel, class _P1, class _P2> concept std::mergeable'
 905 | concept mergeable = input_iterator<_I1> && input_iterator<_I2>
 | ^~~~~~~~~
p1223.cpp:740:36: error: expected unqualified-id before ',' token
 740 | requires mergeable<iterator_t<R1>, iterator_t<R2>, O, Comp, Proj1, Proj2>
 | ^
p1223.cpp:743:80: error: expected unqualified-id before ',' token
 743 | ranges::set_symmetric_difference(R1&& r1, R2&& r2, O result, Comp comp = {},
 | ^
p1223.cpp:744:44: error: expected constructor, destructor, or type conversion before 'proj1'
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:744:54: error: expected unqualified-id before ',' token
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:744:62: error: expected constructor, destructor, or type conversion before 'proj2'
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:744:72: error: expected unqualified-id before ')' token
 744 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:768:73: error: 'I std::ranges::push_heap(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 768 | ranges::push_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:769:10: error: 'random_access_range' has not been declared
 769 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:769:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:770:21: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 770 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:770:12: error: parse error in template argument list
 770 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:770:12: error: template argument 1 is invalid
p1223.cpp:770:34: error: expected unqualified-id before ',' token
 770 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:772:44: error: expected unqualified-id before ',' token
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:772:51: error: expected constructor, destructor, or type conversion before 'proj'
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:772:60: error: expected unqualified-id before ')' token
 772 | ranges::push_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:792:69: error: 'I std::ranges::pop_heap(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 792 | ranges::pop_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:793:10: error: 'random_access_range' has not been declared
 793 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:793:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:794:19: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 794 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:794:10: error: parse error in template argument list
 794 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:794:10: error: template argument 1 is invalid
p1223.cpp:794:32: error: expected unqualified-id before ',' token
 794 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:796:41: error: expected unqualified-id before ',' token
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:796:48: error: expected constructor, destructor, or type conversion before 'proj'
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:796:57: error: expected unqualified-id before ')' token
 796 | ranges::pop_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:810:70: error: 'I std::ranges::make_heap(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 810 | ranges::make_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:811:10: error: 'random_access_range' has not been declared
 811 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:811:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:812:21: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 812 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:812:12: error: parse error in template argument list
 812 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:812:12: error: template argument 1 is invalid
p1223.cpp:812:34: error: expected unqualified-id before ',' token
 812 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:814:44: error: expected unqualified-id before ',' token
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:814:51: error: expected constructor, destructor, or type conversion before 'proj'
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:814:60: error: expected unqualified-id before ')' token
 814 | ranges::make_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:833:70: error: 'I std::ranges::sort_heap(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 833 | ranges::sort_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:834:10: error: 'random_access_range' has not been declared
 834 | template<random_access_range R, class Comp = ranges::less, class Proj = identity>
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:834:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:835:19: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 835 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:835:10: error: parse error in template argument list
 835 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:835:10: error: template argument 1 is invalid
p1223.cpp:835:32: error: expected unqualified-id before ',' token
 835 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:837:42: error: expected unqualified-id before ',' token
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:837:49: error: expected constructor, destructor, or type conversion before 'proj'
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:837:58: error: expected unqualified-id before ')' token
 837 | ranges::sort_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:846:1: error: expected unqualified-id before 'return'
 846 | return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last) == last;
 | ^~~~~~
p1223.cpp:854:1: error: expected unqualified-id before 'return'
 854 | return is_heap_until(std::forward<ExecutionPolicy>(exec), first, last, comp) == last;
 | ^~~~~~
p1223.cpp:857:81: error: 'bool std::ranges::is_heap(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 857 | constexpr bool ranges::is_heap(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:858:10: error: 'random_access_range' has not been declared
 858 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:858:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:859:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:859:59: error: wrong number of template arguments (1, should be 2)
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:859:10: error: template argument 2 is invalid
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:859:69: error: 'Comp' does not name a type
 859 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:860:55: error: expected unqualified-id before ',' token
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:860:62: error: expected constructor, destructor, or type conversion before 'proj'
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:860:71: error: expected unqualified-id before ')' token
 860 | constexpr bool ranges::is_heap(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:862:45: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 862 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:862:57: error: wrong number of template arguments (1, should be 2)
 862 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:862:60: error: 'Proj' was not declared in this scope; did you mean 'Proj1'?
 862 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
 | Proj1
p1223.cpp:862:8: error: template argument 1 is invalid
 862 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:862:8: error: template argument 2 is invalid
p1223.cpp:862:8: error: template argument 3 is invalid
p1223.cpp:862:8: error: '<expression error>' does not name a type
p1223.cpp:864:46: error: expected unqualified-id before ',' token
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:864:53: error: expected constructor, destructor, or type conversion before 'proj'
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:864:62: error: expected unqualified-id before ')' token
 864 | ranges::is_heap_until(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:866:17: error: 'T' does not name a type
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:866:70: error: expected unqualified-id before ',' token
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:866:77: error: expected constructor, destructor, or type conversion before 'proj'
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:866:86: error: expected unqualified-id before ')' token
 866 | constexpr const T& ranges::min(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:889:84: error: 'I std::ranges::is_heap_until(I, S, Comp, Proj)' should have been declared inside std::ranges'
 889 | constexpr I ranges::is_heap_until(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:890:10: error: 'random_access_range' has not been declared
 890 | template<random_access_range R, class Proj = identity,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:890:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:894:3: error: expected 'class' or 'typename' before 'constexpr'
 894 | constexpr const T& min(const T& a, const T& b);
 | ^~~~~~~~~
p1223.cpp:894:3: error: expected identifier before 'constexpr'
p1223.cpp:894:3: error: expected '>' before 'constexpr'
p1223.cpp:894:49: error: expected unqualified-id before ';' token
 894 | constexpr const T& min(const T& a, const T& b);
 | ^
p1223.cpp:899:10: error: declaration of template parameter 'T' shadows template parameter
 899 | template<class T>
 | ^~~~~
p1223.cpp:897:10: note: template parameter 'T' declared here
 897 | template<class T, class Proj = identity,
 | ^~~~~
p1223.cpp:900:15: error: too many template-parameter-lists
 900 | constexpr T min(initializer_list<T> r);
 | ^~~
p1223.cpp:905:80: error: 'T std::ranges::min(std::initializer_list<_Tp>, Comp, Proj)' should have been declared inside 'std::ranges'
 905 | constexpr T ranges::min(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:906:10: error: 'input_range' has not been declared
 906 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:906:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:907:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:907:59: error: wrong number of template arguments (1, should be 2)
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:907:10: error: template argument 2 is invalid
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:907:69: error: 'Comp' does not name a type
 907 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:910:38: error: expected unqualified-id before ',' token
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:910:45: error: expected constructor, destructor, or type conversion before 'proj'
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:910:54: error: expected unqualified-id before ')' token
 910 | ranges::min(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:915:45: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 915 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:915:57: error: wrong number of template arguments (1, should be 2)
 915 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:915:60: error: 'Proj' was not declared in this scope; did you mean 'Proj1'?
 915 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
 | Proj1
p1223.cpp:915:8: error: template argument 1 is invalid
 915 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:915:8: error: template argument 2 is invalid
p1223.cpp:915:8: error: template argument 3 is invalid
p1223.cpp:915:8: error: '<expression error>' does not name a type
p1223.cpp:918:36: error: expected unqualified-id before ',' token
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:918:43: error: expected constructor, destructor, or type conversion before 'proj'
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:918:52: error: expected unqualified-id before ')' token
 918 | ranges::max(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:929:86: error: 'const T& std::ranges::max(const T&, const T&, Comp, Proj)' should have been declared inside 'std::ranges'
 929 | constexpr const T& ranges::max(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:940:80: error: 'T std::ranges::max(std::initializer_list<_Tp>, Comp, Proj)' should have been declared inside 'std::ranges'
 940 | constexpr T ranges::max(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:941:10: error: 'input_range' has not been declared
 941 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:941:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:943:3: error: expected 'class' or 'typename' before 'constexpr'
 943 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
 | ^~~~~~~~~
p1223.cpp:943:3: error: expected identifier before 'constexpr'
p1223.cpp:943:3: error: expected '>' before 'constexpr'
p1223.cpp:943:68: error: expected unqualified-id before ';' token
 943 | constexpr pair<const T&, const T&> minmax(const T& a, const T& b);
 | ^
p1223.cpp:948:21: error: 'minmax_result' in namespace 'std::ranges' does not name a template type; did you mean 'move_result'?
 948 | constexpr ranges::minmax_result<const T&>
 | ^~~~~~~~~~~~~
 | move_result
p1223.cpp:949:58: error: expected unqualified-id before ',' token
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:949:65: error: expected constructor, destructor, or type conversion before 'proj'
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:949:74: error: expected unqualified-id before ')' token
 949 | ranges::minmax(const T& a, const T& b, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:954:1: error: expected unqualified-id before 'requires'
 954 | requires indirectly_copyable_storable<iterator_t<R>, range_value_t<R>*>
 | ^~~~~~~~
p1223.cpp:956:39: error: expected unqualified-id before ',' token
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:956:46: error: expected constructor, destructor, or type conversion before 'proj'
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:956:55: error: expected unqualified-id before ')' token
 956 | ranges::minmax(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:967:21: error: 'minmax_result' in namespace 'std::ranges' does not name a template type; did you mean 'move_result'?
 967 | constexpr ranges::minmax_result<T>
 | ^~~~~~~~~~~~~
 | move_result
p1223.cpp:968:57: error: expected unqualified-id before ',' token
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:968:64: error: expected constructor, destructor, or type conversion before 'proj'
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:968:73: error: expected unqualified-id before ')' token
 968 | ranges::minmax(initializer_list<T> r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:969:10: error: 'input_range' has not been declared
 969 | template<input_range R, class Proj = identity,
 | ^~~~~~~~~~~
p1223.cpp:969:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:970:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:970:59: error: wrong number of template arguments (1, should be 2)
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:970:10: error: template argument 2 is invalid
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:970:69: error: 'Comp' does not name a type
 970 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:985:82: error: 'I std::ranges::min_element(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 985 | constexpr I ranges::min_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:986:10: error: 'forward_range' has not been declared
 986 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:986:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:987:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_t'?
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:987:59: error: wrong number of template arguments (1, should be 2)
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:987:10: error: template argument 2 is invalid
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:987:69: error: 'Comp' does not name a type
 987 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:989:46: error: expected unqualified-id before ',' token
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:989:53: error: expected constructor, destructor, or type conversion before 'proj'
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:989:62: error: expected unqualified-id before ')' token
 989 | ranges::min_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:991:14: error: expected ')' before '(' token
 991 | bool(invoke(comp, invoke(proj, *j), invoke(proj, *i)))
 | ~ ^
 | )
p1223.cpp:996:44: error: expected unqualified-id before ',' token
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:996:51: error: expected constructor, destructor, or type conversion before 'proj'
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:996:60: error: expected unqualified-id before ')' token
 996 | ranges::max_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:998:12: error: expected ')' before '(' token
 998 | bool(invoke(comp, invoke(proj, *i), invoke(proj, *j)))
 | ~ ^
 | )
p1223.cpp:1002:47: error: expected unqualified-id before ',' token
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1002:54: error: expected constructor, destructor, or type conversion before 'proj'
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1002:63: error: expected unqualified-id before ')' token
 1002 | ranges::minmax_element(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1018:82: error: 'I std::ranges::max_element(I, S, Comp, Proj)' should have been declared inside 'std::ranges'
 1018 | constexpr I ranges::max_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1019:10: error: 'forward_range' has not been declared
 1019 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:1019:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1021:3: error: expected 'class' or 'typename' before 'constexpr'
 1021 | constexpr pair<ForwardIterator, ForwardIterator>
 | ^~~~~~~~~
p1223.cpp:1021:3: error: expected identifier before 'constexpr'
p1223.cpp:1021:3: error: expected '>' before 'constexpr'
p1223.cpp:1022:64: error: expected unqualified-id before ';' token
 1022 | minmax_element(ForwardIterator first, ForwardIterator last);
 | ^
p1223.cpp:1036:21: error: 'minmax_result' in namespace 'std::ranges' does not name a template type; did you mean 'move_result'?
 1036 | constexpr ranges::minmax_result<I>
 | ^~~~~~~~~~~~~
 | move_result
p1223.cpp:1037:59: error: expected unqualified-id before ',' token
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1037:66: error: expected constructor, destructor, or type conversion before 'proj'
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1037:75: error: expected unqualified-id before ')' token
 1037 | ranges::minmax_element(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1038:10: error: 'forward_range' has not been declared
 1038 | template<forward_range R, class Proj = identity,
 | ^~~~~~~~~~~~~
p1223.cpp:1038:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1039:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_'?
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:1039:59: error: wrong number of template arguments (1, should be 2)
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:1039:10: error: template argument 2 is invalid
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1039:69: error: 'Comp' does not name a type
 1039 | indirect_strict_weak_order<projected<iterator_t<R>, Proj>> Comp = ranges::less>
 | ^~~~
p1223.cpp:1043:69: error: expected unqualified-id before ',' token
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1043:76: error: expected constructor, destructor, or type conversion before 'proj'
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1043:85: error: expected unqualified-id before ')' token
 1043 | ranges::clamp(const T& v, const T& lo, const T& hi, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1060:5: error: too many template-parameter-lists
 1060 | lexicographical_compare(InputIterator1 first1, InputIterator1 last1,
 | ^~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1085:87: error: 'bool std::ranges::lexicographical_compare(I1, S1, I2, S2, Comp, Proj1, Proj2)' should have been declared inside 'std::ranges'
 1085 | Comp comp = {}, Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1086:10: error: 'input_range' has not been declared
 1086 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:1086:26: error: 'input_range' has not been declared
 1086 | template<input_range R1, input_range R2, class Proj1 = identity,
 | ^~~~~~~~~~~
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:1088:58: error: 'R1' was not declared in this scope; did you mean 'y1'?
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~
 | y1
p1223.cpp:1088:60: error: wrong number of template arguments (1, should be 2)
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:1088:10: error: template argument 2 is invalid
 1088 | indirect_strict_weak_order<projected<iterator_t<R1>, Proj1>,
 | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:47: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:1089:58: error: 'R2' was not declared in this scope; did you mean 'R'?
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
 | R
p1223.cpp:1089:60: error: wrong number of template arguments (1, should be 2)
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^
/usr/local/include/c++/12.1.0/bits/iterator_concepts.h:757:12: note: provided for 'template<class _Iter, class _Proj> requires (indirectly_readable<_Iter>) && (indirectly_regular_unary_invocable<_Proj, _Iter>) struct std::projected'
 757 | struct projected
 | ^~~~~~~~~
p1223.cpp:1089:68: error: expected '>' before '>>' token
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~
p1223.cpp:1089:71: error: 'Comp' does not name a type
 1089 | projected<iterator_t<R2>, Proj2>> Comp = ranges::less>
 | ^~~~
p1223.cpp:1091:69: error: expected unqualified-id before ',' token
 1091 | ranges::lexicographical_compare(R1&& r1, R2&& r2, Comp comp = {},
 | ^
p1223.cpp:1092:43: error: expected constructor, destructor, or type conversion before 'proj1'
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1092:53: error: expected unqualified-id before ',' token
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1092:61: error: expected constructor, destructor, or type conversion before 'proj2'
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^~~~~
p1223.cpp:1092:71: error: expected unqualified-id before ')' token
 1092 | Proj1 proj1 = {}, Proj2 proj2 = {});
 | ^
p1223.cpp:1097:8: error: expected unqualified-id before 'for'
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~~
p1223.cpp:1097:16: error: 'first1' does not name a type
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~~~~~
p1223.cpp:1097:53: error: expected unqualified-id before '++' token
 1097 | for ( ; first1 != last1 && first2 != last2 ; ++first1, (void) ++first2) {
 | ^~
p1223.cpp:1101:8: error: expected unqualified-id before 'return'
 1101 | return first1 == last1 && first2 != last2;
 | ^~~~~~
p1223.cpp:1119:1: error: expected unqualified-id before 'return'
 1119 | return lexicographical_compare_three_way(b1, e1, b2, e2, compare_three_way());
 | ^~~~~~
p1223.cpp:1130:21: error: 'next_permutation_result' in namespace 'std::ranges' does not name a template type
 1130 | constexpr ranges::next_permutation_result<I>
 | ^~~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1131:61: error: expected unqualified-id before ',' token
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1131:68: error: expected constructor, destructor, or type conversion before 'proj'
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1131:77: error: expected unqualified-id before ')' token
 1131 | ranges::next_permutation(I first, S last, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1132:10: error: 'bidirectional_range' has not been declared
 1132 | template<bidirectional_range R, class Comp = ranges::less,
 | ^~~~~~~~~~~~~~~~~~~
p1223.cpp:1132:10: error: two or more data types in declaration of 'parameter'
p1223.cpp:1134:21: error: 'iterator_t' was not declared in this scope; did you mean 'std::ranges::iterator_'?
 1134 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~
 | std::ranges::iterator_t
/usr/local/include/c++/12.1.0/bits/ranges_base.h:595:11: note: 'std::ranges::iterator_t' declared here
 595 | using iterator_t = std::__detail::__range_iter_t<_Tp>;
 | ^~~~~~~~~~
p1223.cpp:1134:12: error: parse error in template argument list
 1134 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^~~~~~~~~~~~~~~~~~~~~~
p1223.cpp:1134:12: error: template argument 1 is invalid
p1223.cpp:1134:34: error: expected unqualified-id before ',' token
 1134 | requires sortable<iterator_t<R>, Comp, Proj>
 | ^
p1223.cpp:1136:51: error: expected unqualified-id before ',' token
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^
p1223.cpp:1136:58: error: expected constructor, destructor, or type conversion before 'proj'
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^~~~
p1223.cpp:1136:67: error: expected unqualified-id before ')' token
 1136 | ranges::next_permutation(R&& r, Comp comp = {}, Proj proj = {});
 | ^

検討事項(agenda)

コンパイルエラーを取るか、コンパイルエラーの理由を解説する。

参考資料(reference)

関連する自己参照以外は、こちらの先頭に移転。

C言語(C++)に対する誤解、曲解、無理解、爽快。

#include "N4910.h"

C++N4910資料の改善点

dockerにclang

docker gnu(gcc/g++) and llvm(clang/clang++)

コンパイル用shell script C版(clangとgcc)とC++版(clang++とg++)

C++N4910:2022 tag follower 300人超えました。ありがとうございます。

astyle 使ってみた

DoCAP(ドゥーキャップ)って何ですか?

小川メソッド 覚え(書きかけ)

<この記事は個人の過去の経験に基づく個人の感想です。現在所属する組織、業務とは関係がありません。>

文書履歴(document history)

ver. 0.01 初稿  20220815

0

Go to list of users who liked

1
0

Go to list of comments

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0

Go to list of users who liked

1