| `[deque.syn] <https://wg21.link/deque.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),| `deque <https://reviews.llvm.org/D144821>`_,[expos.only.func],Hristo Hristov,|Complete|
| `[forward.list.syn] <https://wg21.link/forward.list.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),| `forward_list <https://reviews.llvm.org/D145172>`_,[expos.only.func],Hristo Hristov,|Complete|
| `[list.syn] <https://wg21.link/list.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),| `list <https://reviews.llvm.org/D132312>`_,[expos.only.func],Adrian Vogelsgesang,|Complete|
-| `[vector.syn] <https://wg21.link/vector.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),| `vector <https://reviews.llvm.org/D132268>`_,[expos.only.func],Adrian Vogelsgesang,|In Progress|
+| `[vector.syn] <https://wg21.link/vector.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),| `vector <https://reviews.llvm.org/D132268>`_,[expos.only.func],"| Adrian Vogelsgesang
+| Hristo Hristov",|Complete|
| `[associative.map.syn] <https://wg21.link/associative.map.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),"| `map <https://reviews.llvm.org/D145976>`_
| `multimap <https://reviews.llvm.org/D145976>`_",[expos.only.func],Hristo Hristov,|Complete|
| `[associative.set.syn] <https://wg21.link/associative.set.syn>`_ (`general <https://wg21.link/container.opt.reqmts>`_),"| multiset
template <class Allocator> struct hash<std::vector<bool, Allocator>>;
-template <class T, class Allocator> bool operator==(const vector<T,Allocator>& x, const vector<T,Allocator>& y);
-template <class T, class Allocator> bool operator< (const vector<T,Allocator>& x, const vector<T,Allocator>& y);
-template <class T, class Allocator> bool operator!=(const vector<T,Allocator>& x, const vector<T,Allocator>& y);
-template <class T, class Allocator> bool operator> (const vector<T,Allocator>& x, const vector<T,Allocator>& y);
-template <class T, class Allocator> bool operator>=(const vector<T,Allocator>& x, const vector<T,Allocator>& y);
-template <class T, class Allocator> bool operator<=(const vector<T,Allocator>& x, const vector<T,Allocator>& y);
+template <class T, class Allocator> bool operator==(const vector<T,Allocator>& x, const vector<T,Allocator>& y); // constexpr since C++20
+template <class T, class Allocator> bool operator!=(const vector<T,Allocator>& x, const vector<T,Allocator>& y); // removed in C++20
+template <class T, class Allocator> bool operator< (const vector<T,Allocator>& x, const vector<T,Allocator>& y); // removed in C++20
+template <class T, class Allocator> bool operator> (const vector<T,Allocator>& x, const vector<T,Allocator>& y); // removed in C++20
+template <class T, class Allocator> bool operator>=(const vector<T,Allocator>& x, const vector<T,Allocator>& y); // removed in C++20
+template <class T, class Allocator> bool operator<=(const vector<T,Allocator>& x, const vector<T,Allocator>& y); // removed in C++20
+template <class T, class Allocator> constexpr
+ constexpr synth-three-way-result<T> operator<=>(const vector<T, Allocator>& x,
+ const vector<T, Allocator>& y); // since C++20
template <class T, class Allocator>
void swap(vector<T,Allocator>& x, vector<T,Allocator>& y)
template <class T, class Allocator, class U>
typename vector<T, Allocator>::size_type
-erase(vector<T, Allocator>& c, const U& value); // C++20
+erase(vector<T, Allocator>& c, const U& value); // since C++20
template <class T, class Allocator, class Predicate>
typename vector<T, Allocator>::size_type
-erase_if(vector<T, Allocator>& c, Predicate pred); // C++20
+erase_if(vector<T, Allocator>& c, Predicate pred); // since C++20
template<class T>
#include <__algorithm/fill_n.h>
#include <__algorithm/iterator_operations.h>
#include <__algorithm/lexicographical_compare.h>
+#include <__algorithm/lexicographical_compare_three_way.h>
#include <__algorithm/remove.h>
#include <__algorithm/remove_if.h>
#include <__algorithm/rotate.h>
return __sz == __y.size() && std::equal(__x.begin(), __x.end(), __y.begin());
}
+#if _LIBCPP_STD_VER <= 17
+
template <class _Tp, class _Allocator>
-_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
bool
operator!=(const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y)
}
template <class _Tp, class _Allocator>
-_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
bool
operator< (const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y)
}
template <class _Tp, class _Allocator>
-_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
bool
operator> (const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y)
}
template <class _Tp, class _Allocator>
-_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
bool
operator>=(const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y)
}
template <class _Tp, class _Allocator>
-_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
bool
operator<=(const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y)
return !(__y < __x);
}
+#else // _LIBCPP_STD_VER <= 17
+
+template <class _Tp, class _Allocator>
+_LIBCPP_HIDE_FROM_ABI constexpr __synth_three_way_result<_Tp>
+operator<=>(const vector<_Tp, _Allocator>& __x, const vector<_Tp, _Allocator>& __y) {
+ return std::lexicographical_compare_three_way(
+ __x.begin(), __x.end(), __y.begin(), __y.end(), std::__synth_three_way<_Tp, _Tp>);
+}
+
+#endif // _LIBCPP_STD_VER <= 17
+
template <class _Tp, class _Allocator>
_LIBCPP_CONSTEXPR_SINCE_CXX20
inline _LIBCPP_HIDE_FROM_ABI
--- /dev/null
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+// UNSUPPORTED: c++03, c++11, c++14, c++17
+
+// <vector>
+
+// class vector<bool, Allocator>
+
+// template<class T, class Allocator>
+// constexpr synth-three-way-result<T> operator<=>(const vector<T, Allocator>& x,
+// const vector<T, Allocator>& y);
+
+#include <cassert>
+#include <vector>
+
+#include "test_comparisons.h"
+
+constexpr bool test_sequence_container_spaceship_vectorbool() {
+ // Empty containers
+ {
+ std::vector<bool> l1;
+ std::vector<bool> l2;
+ assert(testOrder(l1, l2, std::strong_ordering::equivalent));
+ }
+ // Identical contents
+ {
+ std::vector<bool> t1{true, true};
+ std::vector<bool> t2{true, true};
+ assert(testOrder(t1, t2, std::strong_ordering::equivalent));
+
+ std::vector<bool> f1{false, false};
+ std::vector<bool> f2{false, false};
+ assert(testOrder(f1, f2, std::strong_ordering::equivalent));
+ }
+ // Less, due to contained values
+ {
+ std::vector<bool> l1{true, false};
+ std::vector<bool> l2{true, true};
+ assert(testOrder(l1, l2, std::strong_ordering::less));
+ }
+ // Greater, due to contained values
+ {
+ std::vector<bool> l1{true, true};
+ std::vector<bool> l2{true, false};
+ assert(testOrder(l1, l2, std::strong_ordering::greater));
+ }
+ // Shorter list
+ {
+ std::vector<bool> l1{true};
+ std::vector<bool> l2{true, false};
+ assert(testOrder(l1, l2, std::strong_ordering::less));
+
+ std::vector<bool> t1{true};
+ std::vector<bool> t2{true, true};
+ assert(testOrder(t1, t2, std::strong_ordering::less));
+
+ std::vector<bool> f1{false};
+ std::vector<bool> f2{false, false};
+ assert(testOrder(f1, f2, std::strong_ordering::less));
+
+ std::vector<bool> e;
+ assert(testOrder(e, t1, std::strong_ordering::less));
+ assert(testOrder(e, f1, std::strong_ordering::less));
+ }
+ // Longer list
+ {
+ std::vector<bool> l1{true, false};
+ std::vector<bool> l2{true};
+ assert(testOrder(l1, l2, std::strong_ordering::greater));
+
+ std::vector<bool> t1{true, true};
+ std::vector<bool> t2{true};
+ assert(testOrder(t1, t2, std::strong_ordering::greater));
+
+ std::vector<bool> f1{false, false};
+ std::vector<bool> f2{false};
+ assert(testOrder(f1, f2, std::strong_ordering::greater));
+
+ std::vector<bool> e;
+ assert(testOrder(t2, e, std::strong_ordering::greater));
+ assert(testOrder(f2, e, std::strong_ordering::greater));
+ }
+
+ return true;
+}
+
+int main(int, char**) {
+ assert(test_sequence_container_spaceship_vectorbool());
+ static_assert(test_sequence_container_spaceship_vectorbool());
+ return 0;
+}