diff --git a/libcxx/cmake/caches/Generic-cxx2a.cmake b/libcxx/cmake/caches/Generic-cxx20.cmake rename from libcxx/cmake/caches/Generic-cxx2a.cmake rename to libcxx/cmake/caches/Generic-cxx20.cmake diff --git a/libcxx/docs/DesignDocs/FeatureTestMacros.rst b/libcxx/docs/DesignDocs/FeatureTestMacros.rst --- a/libcxx/docs/DesignDocs/FeatureTestMacros.rst +++ b/libcxx/docs/DesignDocs/FeatureTestMacros.rst @@ -8,7 +8,7 @@ Overview ======== -Libc++ implements the C++ feature test macros as specified in the C++2a standard, +Libc++ implements the C++ feature test macros as specified in the C++20 standard, and before that in non-normative guiding documents (`See cppreference `_) diff --git a/libcxx/docs/FeatureTestMacroTable.rst b/libcxx/docs/FeatureTestMacroTable.rst --- a/libcxx/docs/FeatureTestMacroTable.rst +++ b/libcxx/docs/FeatureTestMacroTable.rst @@ -166,7 +166,7 @@ ------------------------------------------------- ----------------- ``__cpp_lib_void_t`` ``201411L`` ------------------------------------------------- ----------------- - **C++ 2a** + **C++ 20** ------------------------------------------------------------------- ``__cpp_lib_array_constexpr`` ``201811L`` ------------------------------------------------- ----------------- diff --git a/libcxx/docs/UsingLibcxx.rst b/libcxx/docs/UsingLibcxx.rst --- a/libcxx/docs/UsingLibcxx.rst +++ b/libcxx/docs/UsingLibcxx.rst @@ -254,7 +254,7 @@ **_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR**: This macro is used to re-enable `std::auto_ptr` in C++17. -C++2a Specific Configuration Macros: +C++20 Specific Configuration Macros: ------------------------------------ **_LIBCPP_DISABLE_NODISCARD_AFTER_CXX17**: This macro can be used to disable diagnostics emitted from functions marked diff --git a/libcxx/include/__config b/libcxx/include/__config --- a/libcxx/include/__config +++ b/libcxx/include/__config @@ -49,8 +49,10 @@ # define _LIBCPP_STD_VER 14 # elif __cplusplus <= 201703L # define _LIBCPP_STD_VER 17 +# elif __cplusplus <= 202002L +# define _LIBCPP_STD_VER 20 # else -# define _LIBCPP_STD_VER 18 // current year, or date of c++2a ratification +# define _LIBCPP_STD_VER 21 // current year, or date of c++2b ratification # endif #endif // _LIBCPP_STD_VER diff --git a/libcxx/include/new b/libcxx/include/new --- a/libcxx/include/new +++ b/libcxx/include/new @@ -49,11 +49,11 @@ template constexpr T* launder(T* p) noexcept; // C++17 } // std -void* operator new(std::size_t size); // replaceable, nodiscard in C++2a -void* operator new(std::size_t size, std::align_val_t alignment); // replaceable, C++17, nodiscard in C++2a -void* operator new(std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a +void* operator new(std::size_t size); // replaceable, nodiscard in C++20 +void* operator new(std::size_t size, std::align_val_t alignment); // replaceable, C++17, nodiscard in C++20 +void* operator new(std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++20 void* operator new(std::size_t size, std::align_val_t alignment, - const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a + const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++20 void operator delete(void* ptr) noexcept; // replaceable void operator delete(void* ptr, std::size_t size) noexcept; // replaceable, C++14 void operator delete(void* ptr, std::align_val_t alignment) noexcept; // replaceable, C++17 @@ -63,12 +63,12 @@ void operator delete(void* ptr, std:align_val_t alignment, const std::nothrow_t&) noexcept; // replaceable, C++17 -void* operator new[](std::size_t size); // replaceable, nodiscard in C++2a +void* operator new[](std::size_t size); // replaceable, nodiscard in C++20 void* operator new[](std::size_t size, - std::align_val_t alignment) noexcept; // replaceable, C++17, nodiscard in C++2a -void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++2a + std::align_val_t alignment) noexcept; // replaceable, C++17, nodiscard in C++20 +void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; // replaceable, nodiscard in C++20 void* operator new[](std::size_t size, std::align_val_t alignment, - const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++2a + const std::nothrow_t&) noexcept; // replaceable, C++17, nodiscard in C++20 void operator delete[](void* ptr) noexcept; // replaceable void operator delete[](void* ptr, std::size_t size) noexcept; // replaceable, C++14 void operator delete[](void* ptr, @@ -79,8 +79,8 @@ void operator delete[](void* ptr, std::align_val_t alignment, const std::nothrow_t&) noexcept; // replaceable, C++17 -void* operator new (std::size_t size, void* ptr) noexcept; // nodiscard in C++2a -void* operator new[](std::size_t size, void* ptr) noexcept; // nodiscard in C++2a +void* operator new (std::size_t size, void* ptr) noexcept; // nodiscard in C++20 +void* operator new[](std::size_t size, void* ptr) noexcept; // nodiscard in C++20 void operator delete (void* ptr, void*) noexcept; void operator delete[](void* ptr, void*) noexcept; diff --git a/libcxx/include/string b/libcxx/include/string --- a/libcxx/include/string +++ b/libcxx/include/string @@ -317,12 +317,12 @@ int compare(size_type pos1, size_type n1, const value_type* s) const; int compare(size_type pos1, size_type n1, const value_type* s, size_type n2) const; - bool starts_with(basic_string_view sv) const noexcept; // C++2a - bool starts_with(charT c) const noexcept; // C++2a - bool starts_with(const charT* s) const; // C++2a - bool ends_with(basic_string_view sv) const noexcept; // C++2a - bool ends_with(charT c) const noexcept; // C++2a - bool ends_with(const charT* s) const; // C++2a + bool starts_with(basic_string_view sv) const noexcept; // C++20 + bool starts_with(charT c) const noexcept; // C++20 + bool starts_with(const charT* s) const; // C++20 + bool ends_with(basic_string_view sv) const noexcept; // C++20 + bool ends_with(charT c) const noexcept; // C++20 + bool ends_with(const charT* s) const; // C++20 bool __invariants() const; }; diff --git a/libcxx/include/string_view b/libcxx/include/string_view --- a/libcxx/include/string_view +++ b/libcxx/include/string_view @@ -142,12 +142,12 @@ constexpr size_type find_last_not_of(const charT* s, size_type pos, size_type n) const; constexpr size_type find_last_not_of(const charT* s, size_type pos = npos) const; - constexpr bool starts_with(basic_string_view s) const noexcept; // C++2a - constexpr bool starts_with(charT c) const noexcept; // C++2a - constexpr bool starts_with(const charT* s) const; // C++2a - constexpr bool ends_with(basic_string_view s) const noexcept; // C++2a - constexpr bool ends_with(charT c) const noexcept; // C++2a - constexpr bool ends_with(const charT* s) const; // C++2a + constexpr bool starts_with(basic_string_view s) const noexcept; // C++20 + constexpr bool starts_with(charT c) const noexcept; // C++20 + constexpr bool starts_with(const charT* s) const; // C++20 + constexpr bool ends_with(basic_string_view s) const noexcept; // C++20 + constexpr bool ends_with(charT c) const noexcept; // C++20 + constexpr bool ends_with(const charT* s) const; // C++20 private: const_pointer data_; // exposition only diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/algorithm.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/algorithm.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/algorithm.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/algorithm.version.pass.cpp @@ -15,9 +15,9 @@ /* Constant Value __cpp_lib_clamp 201603L [C++17] - __cpp_lib_constexpr_swap_algorithms 201806L [C++2a] + __cpp_lib_constexpr_swap_algorithms 201806L [C++20] __cpp_lib_parallel_algorithm 201603L [C++17] - __cpp_lib_ranges 201811L [C++2a] + __cpp_lib_ranges 201811L [C++20] __cpp_lib_robust_nonmodifying_seq_ops 201304L [C++14] __cpp_lib_sample 201603L [C++17] */ @@ -32,7 +32,7 @@ # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # ifdef __cpp_lib_parallel_algorithm @@ -40,7 +40,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_robust_nonmodifying_seq_ops @@ -58,7 +58,7 @@ # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # ifdef __cpp_lib_parallel_algorithm @@ -66,7 +66,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_robust_nonmodifying_seq_ops @@ -90,7 +90,7 @@ # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -107,7 +107,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_robust_nonmodifying_seq_ops @@ -127,18 +127,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_clamp -# error "__cpp_lib_clamp should be defined in c++2a" +# error "__cpp_lib_clamp should be defined in c++20" # endif # if __cpp_lib_clamp != 201603L -# error "__cpp_lib_clamp should have the value 201603L in c++2a" +# error "__cpp_lib_clamp should have the value 201603L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should be defined in c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should be defined in c++20" # endif # if __cpp_lib_constexpr_swap_algorithms != 201806L -# error "__cpp_lib_constexpr_swap_algorithms should have the value 201806L in c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_swap_algorithms @@ -148,10 +148,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_parallel_algorithm -# error "__cpp_lib_parallel_algorithm should be defined in c++2a" +# error "__cpp_lib_parallel_algorithm should be defined in c++20" # endif # if __cpp_lib_parallel_algorithm != 201603L -# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++2a" +# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_parallel_algorithm @@ -161,10 +161,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_ranges -# error "__cpp_lib_ranges should be defined in c++2a" +# error "__cpp_lib_ranges should be defined in c++20" # endif # if __cpp_lib_ranges != 201811L -# error "__cpp_lib_ranges should have the value 201811L in c++2a" +# error "__cpp_lib_ranges should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_ranges @@ -173,17 +173,17 @@ # endif # ifndef __cpp_lib_robust_nonmodifying_seq_ops -# error "__cpp_lib_robust_nonmodifying_seq_ops should be defined in c++2a" +# error "__cpp_lib_robust_nonmodifying_seq_ops should be defined in c++20" # endif # if __cpp_lib_robust_nonmodifying_seq_ops != 201304L -# error "__cpp_lib_robust_nonmodifying_seq_ops should have the value 201304L in c++2a" +# error "__cpp_lib_robust_nonmodifying_seq_ops should have the value 201304L in c++20" # endif # ifndef __cpp_lib_sample -# error "__cpp_lib_sample should be defined in c++2a" +# error "__cpp_lib_sample should be defined in c++20" # endif # if __cpp_lib_sample != 201603L -# error "__cpp_lib_sample should have the value 201603L in c++2a" +# error "__cpp_lib_sample should have the value 201603L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/any.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/any.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/any.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/any.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_any -# error "__cpp_lib_any should be defined in c++2a" +# error "__cpp_lib_any should be defined in c++20" # endif # if __cpp_lib_any != 201606L -# error "__cpp_lib_any should have the value 201606L in c++2a" +# error "__cpp_lib_any should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/array.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/array.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/array.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/array.version.pass.cpp @@ -15,10 +15,10 @@ /* Constant Value __cpp_lib_array_constexpr 201603L [C++17] - 201811L [C++2a] - __cpp_lib_constexpr_misc 201811L [C++2a] + 201811L [C++20] + __cpp_lib_constexpr_misc 201811L [C++20] __cpp_lib_nonmember_container_access 201411L [C++17] - __cpp_lib_to_array 201907L [C++2a] + __cpp_lib_to_array 201907L [C++20] */ #include @@ -31,7 +31,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -39,7 +39,7 @@ # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif #elif TEST_STD_VER == 14 @@ -49,7 +49,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -57,7 +57,7 @@ # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif #elif TEST_STD_VER == 17 @@ -70,7 +70,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_nonmember_container_access @@ -81,24 +81,24 @@ # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # ifndef __cpp_lib_array_constexpr -# error "__cpp_lib_array_constexpr should be defined in c++2a" +# error "__cpp_lib_array_constexpr should be defined in c++20" # endif # if __cpp_lib_array_constexpr != 201811L -# error "__cpp_lib_array_constexpr should have the value 201811L in c++2a" +# error "__cpp_lib_array_constexpr should have the value 201811L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -107,17 +107,17 @@ # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif # ifndef __cpp_lib_to_array -# error "__cpp_lib_to_array should be defined in c++2a" +# error "__cpp_lib_to_array should be defined in c++20" # endif # if __cpp_lib_to_array != 201907L -# error "__cpp_lib_to_array should have the value 201907L in c++2a" +# error "__cpp_lib_to_array should have the value 201907L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/atomic.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/atomic.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/atomic.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/atomic.version.pass.cpp @@ -16,15 +16,15 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_atomic_flag_test 201907L [C++2a] - __cpp_lib_atomic_float 201711L [C++2a] + __cpp_lib_atomic_flag_test 201907L [C++20] + __cpp_lib_atomic_float 201711L [C++20] __cpp_lib_atomic_is_always_lock_free 201603L [C++17] - __cpp_lib_atomic_lock_free_type_aliases 201907L [C++2a] - __cpp_lib_atomic_ref 201806L [C++2a] - __cpp_lib_atomic_shared_ptr 201711L [C++2a] - __cpp_lib_atomic_value_initialization 201911L [C++2a] - __cpp_lib_atomic_wait 201907L [C++2a] - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_atomic_lock_free_type_aliases 201907L [C++20] + __cpp_lib_atomic_ref 201806L [C++20] + __cpp_lib_atomic_shared_ptr 201711L [C++20] + __cpp_lib_atomic_value_initialization 201911L [C++20] + __cpp_lib_atomic_wait 201907L [C++20] + __cpp_lib_char8_t 201811L [C++20] */ #include @@ -33,11 +33,11 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_is_always_lock_free @@ -45,37 +45,37 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_is_always_lock_free @@ -83,37 +83,37 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # if !defined(_LIBCPP_HAS_NO_THREADS) @@ -130,37 +130,37 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should be defined in c++2a" +# error "__cpp_lib_atomic_flag_test should be defined in c++20" # endif # if __cpp_lib_atomic_flag_test != 201907L -# error "__cpp_lib_atomic_flag_test should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_flag_test should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_flag_test @@ -170,10 +170,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should be defined in c++2a" +# error "__cpp_lib_atomic_float should be defined in c++20" # endif # if __cpp_lib_atomic_float != 201711L -# error "__cpp_lib_atomic_float should have the value 201711L in c++2a" +# error "__cpp_lib_atomic_float should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_float @@ -183,10 +183,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_is_always_lock_free -# error "__cpp_lib_atomic_is_always_lock_free should be defined in c++2a" +# error "__cpp_lib_atomic_is_always_lock_free should be defined in c++20" # endif # if __cpp_lib_atomic_is_always_lock_free != 201603L -# error "__cpp_lib_atomic_is_always_lock_free should have the value 201603L in c++2a" +# error "__cpp_lib_atomic_is_always_lock_free should have the value 201603L in c++20" # endif # else # ifdef __cpp_lib_atomic_is_always_lock_free @@ -196,10 +196,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should be defined in c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should be defined in c++20" # endif # if __cpp_lib_atomic_lock_free_type_aliases != 201907L -# error "__cpp_lib_atomic_lock_free_type_aliases should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_lock_free_type_aliases @@ -209,10 +209,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should be defined in c++2a" +# error "__cpp_lib_atomic_ref should be defined in c++20" # endif # if __cpp_lib_atomic_ref != 201806L -# error "__cpp_lib_atomic_ref should have the value 201806L in c++2a" +# error "__cpp_lib_atomic_ref should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_ref @@ -222,10 +222,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should be defined in c++2a" +# error "__cpp_lib_atomic_shared_ptr should be defined in c++20" # endif # if __cpp_lib_atomic_shared_ptr != 201711L -# error "__cpp_lib_atomic_shared_ptr should have the value 201711L in c++2a" +# error "__cpp_lib_atomic_shared_ptr should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_shared_ptr @@ -235,10 +235,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should be defined in c++2a" +# error "__cpp_lib_atomic_value_initialization should be defined in c++20" # endif # if __cpp_lib_atomic_value_initialization != 201911L -# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++2a" +# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_value_initialization @@ -248,10 +248,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should be defined in c++2a" +# error "__cpp_lib_atomic_wait should be defined in c++20" # endif # if __cpp_lib_atomic_wait != 201907L -# error "__cpp_lib_atomic_wait should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_wait should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_wait @@ -261,10 +261,10 @@ # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/bit.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/bit.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/bit.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/bit.version.pass.cpp @@ -14,9 +14,9 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_bit_cast 201806L [C++2a] - __cpp_lib_endian 201907L [C++2a] - __cpp_lib_int_pow2 202002L [C++2a] + __cpp_lib_bit_cast 201806L [C++20] + __cpp_lib_endian 201907L [C++20] + __cpp_lib_int_pow2 202002L [C++20] */ #include @@ -25,53 +25,53 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should be defined in c++2a" +# error "__cpp_lib_bit_cast should be defined in c++20" # endif # if __cpp_lib_bit_cast != 201806L -# error "__cpp_lib_bit_cast should have the value 201806L in c++2a" +# error "__cpp_lib_bit_cast should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_bit_cast @@ -80,17 +80,17 @@ # endif # ifndef __cpp_lib_endian -# error "__cpp_lib_endian should be defined in c++2a" +# error "__cpp_lib_endian should be defined in c++20" # endif # if __cpp_lib_endian != 201907L -# error "__cpp_lib_endian should have the value 201907L in c++2a" +# error "__cpp_lib_endian should have the value 201907L in c++20" # endif # ifndef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should be defined in c++2a" +# error "__cpp_lib_int_pow2 should be defined in c++20" # endif # if __cpp_lib_int_pow2 != 202002L -# error "__cpp_lib_int_pow2 should have the value 202002L in c++2a" +# error "__cpp_lib_int_pow2 should have the value 202002L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/chrono.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/chrono.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/chrono.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/chrono.version.pass.cpp @@ -63,17 +63,17 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_chrono -# error "__cpp_lib_chrono should be defined in c++2a" +# error "__cpp_lib_chrono should be defined in c++20" # endif # if __cpp_lib_chrono != 201611L -# error "__cpp_lib_chrono should have the value 201611L in c++2a" +# error "__cpp_lib_chrono should have the value 201611L in c++20" # endif # ifndef __cpp_lib_chrono_udls -# error "__cpp_lib_chrono_udls should be defined in c++2a" +# error "__cpp_lib_chrono_udls should be defined in c++20" # endif # if __cpp_lib_chrono_udls != 201304L -# error "__cpp_lib_chrono_udls should have the value 201304L in c++2a" +# error "__cpp_lib_chrono_udls should have the value 201304L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/cmath.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/cmath.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/cmath.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/cmath.version.pass.cpp @@ -66,18 +66,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_hypot -# error "__cpp_lib_hypot should be defined in c++2a" +# error "__cpp_lib_hypot should be defined in c++20" # endif # if __cpp_lib_hypot != 201603L -# error "__cpp_lib_hypot should have the value 201603L in c++2a" +# error "__cpp_lib_hypot should have the value 201603L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_math_special_functions -# error "__cpp_lib_math_special_functions should be defined in c++2a" +# error "__cpp_lib_math_special_functions should be defined in c++20" # endif # if __cpp_lib_math_special_functions != 201603L -# error "__cpp_lib_math_special_functions should have the value 201603L in c++2a" +# error "__cpp_lib_math_special_functions should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_math_special_functions diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/compare.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/compare.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/compare.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/compare.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_three_way_comparison 201711L [C++2a] + __cpp_lib_three_way_comparison 201711L [C++20] */ #include @@ -23,29 +23,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should be defined in c++2a" +# error "__cpp_lib_three_way_comparison should be defined in c++20" # endif # if __cpp_lib_three_way_comparison != 201711L -# error "__cpp_lib_three_way_comparison should have the value 201711L in c++2a" +# error "__cpp_lib_three_way_comparison should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_three_way_comparison diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/complex.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/complex.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/complex.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/complex.version.pass.cpp @@ -47,10 +47,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_complex_udls -# error "__cpp_lib_complex_udls should be defined in c++2a" +# error "__cpp_lib_complex_udls should be defined in c++20" # endif # if __cpp_lib_complex_udls != 201309L -# error "__cpp_lib_complex_udls should have the value 201309L in c++2a" +# error "__cpp_lib_complex_udls should have the value 201309L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/concepts.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/concepts.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/concepts.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/concepts.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_concepts 201806L [C++2a] + __cpp_lib_concepts 201806L [C++20] */ #include @@ -23,29 +23,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_concepts -# error "__cpp_lib_concepts should be defined in c++2a" +# error "__cpp_lib_concepts should be defined in c++20" # endif # if __cpp_lib_concepts != 201806L -# error "__cpp_lib_concepts should have the value 201806L in c++2a" +# error "__cpp_lib_concepts should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_concepts diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/cstddef.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/cstddef.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/cstddef.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/cstddef.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_byte -# error "__cpp_lib_byte should be defined in c++2a" +# error "__cpp_lib_byte should be defined in c++20" # endif # if __cpp_lib_byte != 201603L -# error "__cpp_lib_byte should have the value 201603L in c++2a" +# error "__cpp_lib_byte should have the value 201603L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/deque.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/deque.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/deque.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/deque.version.pass.cpp @@ -15,7 +15,7 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_nonmember_container_access 201411L [C++17] */ @@ -29,7 +29,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -43,7 +43,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -60,7 +60,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_nonmember_container_access @@ -73,24 +73,24 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/exception.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/exception.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/exception.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/exception.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_uncaught_exceptions -# error "__cpp_lib_uncaught_exceptions should be defined in c++2a" +# error "__cpp_lib_uncaught_exceptions should be defined in c++20" # endif # if __cpp_lib_uncaught_exceptions != 201411L -# error "__cpp_lib_uncaught_exceptions should have the value 201411L in c++2a" +# error "__cpp_lib_uncaught_exceptions should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/execution.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/execution.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/execution.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/execution.version.pass.cpp @@ -51,10 +51,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_execution -# error "__cpp_lib_execution should be defined in c++2a" +# error "__cpp_lib_execution should be defined in c++20" # endif # if __cpp_lib_execution != 201603L -# error "__cpp_lib_execution should have the value 201603L in c++2a" +# error "__cpp_lib_execution should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_execution diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/filesystem.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/filesystem.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/filesystem.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/filesystem.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] __cpp_lib_filesystem 201703L [C++17] */ @@ -24,7 +24,7 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_filesystem @@ -34,7 +34,7 @@ #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_filesystem @@ -44,7 +44,7 @@ #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifndef __cpp_lib_filesystem @@ -58,10 +58,10 @@ # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t @@ -70,10 +70,10 @@ # endif # ifndef __cpp_lib_filesystem -# error "__cpp_lib_filesystem should be defined in c++2a" +# error "__cpp_lib_filesystem should be defined in c++20" # endif # if __cpp_lib_filesystem != 201703L -# error "__cpp_lib_filesystem should have the value 201703L in c++2a" +# error "__cpp_lib_filesystem should have the value 201703L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/forward_list.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/forward_list.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/forward_list.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/forward_list.version.pass.cpp @@ -15,9 +15,9 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_incomplete_container_elements 201505L [C++17] - __cpp_lib_list_remove_return_type 201806L [C++2a] + __cpp_lib_list_remove_return_type 201806L [C++20] __cpp_lib_nonmember_container_access 201411L [C++17] */ @@ -31,7 +31,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -39,7 +39,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -53,7 +53,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -61,7 +61,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -78,7 +78,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_incomplete_container_elements @@ -89,7 +89,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifndef __cpp_lib_nonmember_container_access @@ -102,38 +102,38 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_incomplete_container_elements -# error "__cpp_lib_incomplete_container_elements should be defined in c++2a" +# error "__cpp_lib_incomplete_container_elements should be defined in c++20" # endif # if __cpp_lib_incomplete_container_elements != 201505L -# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++2a" +# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++20" # endif # ifndef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should be defined in c++2a" +# error "__cpp_lib_list_remove_return_type should be defined in c++20" # endif # if __cpp_lib_list_remove_return_type != 201806L -# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++2a" +# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/functional.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/functional.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/functional.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/functional.version.pass.cpp @@ -14,12 +14,12 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_bind_front 201811L [C++2a] + __cpp_lib_bind_front 201811L [C++20] __cpp_lib_boyer_moore_searcher 201603L [C++17] - __cpp_lib_constexpr_misc 201811L [C++2a] + __cpp_lib_constexpr_misc 201811L [C++20] __cpp_lib_invoke 201411L [C++17] __cpp_lib_not_fn 201603L [C++17] - __cpp_lib_ranges 201811L [C++2a] + __cpp_lib_ranges 201811L [C++20] __cpp_lib_result_of_sfinae 201210L [C++14] __cpp_lib_transparent_operators 201210L [C++14] 201510L [C++17] @@ -31,7 +31,7 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # ifdef __cpp_lib_boyer_moore_searcher @@ -39,7 +39,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_invoke @@ -51,7 +51,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_result_of_sfinae @@ -65,7 +65,7 @@ #elif TEST_STD_VER == 14 # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # ifdef __cpp_lib_boyer_moore_searcher @@ -73,7 +73,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_invoke @@ -85,7 +85,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_result_of_sfinae @@ -105,7 +105,7 @@ #elif TEST_STD_VER == 17 # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -122,7 +122,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_invoke @@ -140,7 +140,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_result_of_sfinae @@ -161,10 +161,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should be defined in c++2a" +# error "__cpp_lib_bind_front should be defined in c++20" # endif # if __cpp_lib_bind_front != 201811L -# error "__cpp_lib_bind_front should have the value 201811L in c++2a" +# error "__cpp_lib_bind_front should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_bind_front @@ -174,10 +174,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_boyer_moore_searcher -# error "__cpp_lib_boyer_moore_searcher should be defined in c++2a" +# error "__cpp_lib_boyer_moore_searcher should be defined in c++20" # endif # if __cpp_lib_boyer_moore_searcher != 201603L -# error "__cpp_lib_boyer_moore_searcher should have the value 201603L in c++2a" +# error "__cpp_lib_boyer_moore_searcher should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_boyer_moore_searcher @@ -187,10 +187,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -199,25 +199,25 @@ # endif # ifndef __cpp_lib_invoke -# error "__cpp_lib_invoke should be defined in c++2a" +# error "__cpp_lib_invoke should be defined in c++20" # endif # if __cpp_lib_invoke != 201411L -# error "__cpp_lib_invoke should have the value 201411L in c++2a" +# error "__cpp_lib_invoke should have the value 201411L in c++20" # endif # ifndef __cpp_lib_not_fn -# error "__cpp_lib_not_fn should be defined in c++2a" +# error "__cpp_lib_not_fn should be defined in c++20" # endif # if __cpp_lib_not_fn != 201603L -# error "__cpp_lib_not_fn should have the value 201603L in c++2a" +# error "__cpp_lib_not_fn should have the value 201603L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_ranges -# error "__cpp_lib_ranges should be defined in c++2a" +# error "__cpp_lib_ranges should be defined in c++20" # endif # if __cpp_lib_ranges != 201811L -# error "__cpp_lib_ranges should have the value 201811L in c++2a" +# error "__cpp_lib_ranges should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_ranges @@ -226,17 +226,17 @@ # endif # ifndef __cpp_lib_result_of_sfinae -# error "__cpp_lib_result_of_sfinae should be defined in c++2a" +# error "__cpp_lib_result_of_sfinae should be defined in c++20" # endif # if __cpp_lib_result_of_sfinae != 201210L -# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++2a" +# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++20" # endif # ifndef __cpp_lib_transparent_operators -# error "__cpp_lib_transparent_operators should be defined in c++2a" +# error "__cpp_lib_transparent_operators should be defined in c++20" # endif # if __cpp_lib_transparent_operators != 201510L -# error "__cpp_lib_transparent_operators should have the value 201510L in c++2a" +# error "__cpp_lib_transparent_operators should have the value 201510L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/iomanip.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/iomanip.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/iomanip.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/iomanip.version.pass.cpp @@ -49,10 +49,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_quoted_string_io -# error "__cpp_lib_quoted_string_io should be defined in c++2a" +# error "__cpp_lib_quoted_string_io should be defined in c++20" # endif # if __cpp_lib_quoted_string_io != 201304L -# error "__cpp_lib_quoted_string_io should have the value 201304L in c++2a" +# error "__cpp_lib_quoted_string_io should have the value 201304L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/istream.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/istream.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/istream.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/istream.version.pass.cpp @@ -16,7 +16,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] */ #include @@ -25,29 +25,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/iterator.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/iterator.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/iterator.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/iterator.version.pass.cpp @@ -15,12 +15,12 @@ /* Constant Value __cpp_lib_array_constexpr 201603L [C++17] - 201811L [C++2a] - __cpp_lib_constexpr_misc 201811L [C++2a] + 201811L [C++20] + __cpp_lib_constexpr_misc 201811L [C++20] __cpp_lib_make_reverse_iterator 201402L [C++14] __cpp_lib_nonmember_container_access 201411L [C++17] __cpp_lib_null_iterators 201304L [C++14] - __cpp_lib_ranges 201811L [C++2a] + __cpp_lib_ranges 201811L [C++20] */ #include @@ -33,7 +33,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_make_reverse_iterator @@ -49,7 +49,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif #elif TEST_STD_VER == 14 @@ -59,7 +59,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_make_reverse_iterator @@ -81,7 +81,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif #elif TEST_STD_VER == 17 @@ -94,7 +94,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_make_reverse_iterator @@ -119,24 +119,24 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # ifndef __cpp_lib_array_constexpr -# error "__cpp_lib_array_constexpr should be defined in c++2a" +# error "__cpp_lib_array_constexpr should be defined in c++20" # endif # if __cpp_lib_array_constexpr != 201811L -# error "__cpp_lib_array_constexpr should have the value 201811L in c++2a" +# error "__cpp_lib_array_constexpr should have the value 201811L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -145,32 +145,32 @@ # endif # ifndef __cpp_lib_make_reverse_iterator -# error "__cpp_lib_make_reverse_iterator should be defined in c++2a" +# error "__cpp_lib_make_reverse_iterator should be defined in c++20" # endif # if __cpp_lib_make_reverse_iterator != 201402L -# error "__cpp_lib_make_reverse_iterator should have the value 201402L in c++2a" +# error "__cpp_lib_make_reverse_iterator should have the value 201402L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif # ifndef __cpp_lib_null_iterators -# error "__cpp_lib_null_iterators should be defined in c++2a" +# error "__cpp_lib_null_iterators should be defined in c++20" # endif # if __cpp_lib_null_iterators != 201304L -# error "__cpp_lib_null_iterators should have the value 201304L in c++2a" +# error "__cpp_lib_null_iterators should have the value 201304L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_ranges -# error "__cpp_lib_ranges should be defined in c++2a" +# error "__cpp_lib_ranges should be defined in c++20" # endif # if __cpp_lib_ranges != 201811L -# error "__cpp_lib_ranges should have the value 201811L in c++2a" +# error "__cpp_lib_ranges should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_ranges diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/limits.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/limits.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/limits.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/limits.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] */ #include @@ -23,29 +23,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/list.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/list.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/list.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/list.version.pass.cpp @@ -15,9 +15,9 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_incomplete_container_elements 201505L [C++17] - __cpp_lib_list_remove_return_type 201806L [C++2a] + __cpp_lib_list_remove_return_type 201806L [C++20] __cpp_lib_nonmember_container_access 201411L [C++17] */ @@ -31,7 +31,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -39,7 +39,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -53,7 +53,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -61,7 +61,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -78,7 +78,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_incomplete_container_elements @@ -89,7 +89,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifndef __cpp_lib_nonmember_container_access @@ -102,38 +102,38 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_incomplete_container_elements -# error "__cpp_lib_incomplete_container_elements should be defined in c++2a" +# error "__cpp_lib_incomplete_container_elements should be defined in c++20" # endif # if __cpp_lib_incomplete_container_elements != 201505L -# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++2a" +# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++20" # endif # ifndef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should be defined in c++2a" +# error "__cpp_lib_list_remove_return_type should be defined in c++20" # endif # if __cpp_lib_list_remove_return_type != 201806L -# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++2a" +# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/locale.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/locale.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/locale.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/locale.version.pass.cpp @@ -16,7 +16,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] */ #include @@ -25,29 +25,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/map.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/map.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/map.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/map.version.pass.cpp @@ -15,7 +15,7 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_generic_associative_lookup 201304L [C++14] __cpp_lib_map_try_emplace 201411L [C++17] __cpp_lib_node_extract 201606L [C++17] @@ -32,7 +32,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_associative_lookup @@ -58,7 +58,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_generic_associative_lookup @@ -90,7 +90,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_generic_associative_lookup @@ -124,45 +124,45 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_generic_associative_lookup -# error "__cpp_lib_generic_associative_lookup should be defined in c++2a" +# error "__cpp_lib_generic_associative_lookup should be defined in c++20" # endif # if __cpp_lib_generic_associative_lookup != 201304L -# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++2a" +# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++20" # endif # ifndef __cpp_lib_map_try_emplace -# error "__cpp_lib_map_try_emplace should be defined in c++2a" +# error "__cpp_lib_map_try_emplace should be defined in c++20" # endif # if __cpp_lib_map_try_emplace != 201411L -# error "__cpp_lib_map_try_emplace should have the value 201411L in c++2a" +# error "__cpp_lib_map_try_emplace should have the value 201411L in c++20" # endif # ifndef __cpp_lib_node_extract -# error "__cpp_lib_node_extract should be defined in c++2a" +# error "__cpp_lib_node_extract should be defined in c++20" # endif # if __cpp_lib_node_extract != 201606L -# error "__cpp_lib_node_extract should have the value 201606L in c++2a" +# error "__cpp_lib_node_extract should have the value 201606L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/memory.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/memory.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/memory.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/memory.version.pass.cpp @@ -16,11 +16,11 @@ /* Constant Value __cpp_lib_addressof_constexpr 201603L [C++17] __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_atomic_value_initialization 201911L [C++2a] - __cpp_lib_constexpr_dynamic_alloc 201907L [C++2a] + __cpp_lib_atomic_value_initialization 201911L [C++20] + __cpp_lib_constexpr_dynamic_alloc 201907L [C++20] __cpp_lib_enable_shared_from_this 201603L [C++17] __cpp_lib_make_unique 201304L [C++14] - __cpp_lib_ranges 201811L [C++2a] + __cpp_lib_ranges 201811L [C++20] __cpp_lib_raw_memory_algorithms 201606L [C++17] __cpp_lib_shared_ptr_arrays 201611L [C++17] __cpp_lib_shared_ptr_weak_type 201606L [C++17] @@ -40,11 +40,11 @@ # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifdef __cpp_lib_enable_shared_from_this @@ -56,7 +56,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_raw_memory_algorithms @@ -82,11 +82,11 @@ # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifdef __cpp_lib_enable_shared_from_this @@ -101,7 +101,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_raw_memory_algorithms @@ -139,11 +139,11 @@ # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifndef __cpp_lib_enable_shared_from_this @@ -161,7 +161,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_raw_memory_algorithms @@ -189,10 +189,10 @@ # if TEST_HAS_BUILTIN(__builtin_addressof) || TEST_GCC_VER >= 700 # ifndef __cpp_lib_addressof_constexpr -# error "__cpp_lib_addressof_constexpr should be defined in c++2a" +# error "__cpp_lib_addressof_constexpr should be defined in c++20" # endif # if __cpp_lib_addressof_constexpr != 201603L -# error "__cpp_lib_addressof_constexpr should have the value 201603L in c++2a" +# error "__cpp_lib_addressof_constexpr should have the value 201603L in c++20" # endif # else # ifdef __cpp_lib_addressof_constexpr @@ -201,18 +201,18 @@ # endif # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should be defined in c++2a" +# error "__cpp_lib_atomic_value_initialization should be defined in c++20" # endif # if __cpp_lib_atomic_value_initialization != 201911L -# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++2a" +# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_value_initialization @@ -221,32 +221,32 @@ # endif # ifndef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should be defined in c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should be defined in c++20" # endif # if __cpp_lib_constexpr_dynamic_alloc != 201907L -# error "__cpp_lib_constexpr_dynamic_alloc should have the value 201907L in c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should have the value 201907L in c++20" # endif # ifndef __cpp_lib_enable_shared_from_this -# error "__cpp_lib_enable_shared_from_this should be defined in c++2a" +# error "__cpp_lib_enable_shared_from_this should be defined in c++20" # endif # if __cpp_lib_enable_shared_from_this != 201603L -# error "__cpp_lib_enable_shared_from_this should have the value 201603L in c++2a" +# error "__cpp_lib_enable_shared_from_this should have the value 201603L in c++20" # endif # ifndef __cpp_lib_make_unique -# error "__cpp_lib_make_unique should be defined in c++2a" +# error "__cpp_lib_make_unique should be defined in c++20" # endif # if __cpp_lib_make_unique != 201304L -# error "__cpp_lib_make_unique should have the value 201304L in c++2a" +# error "__cpp_lib_make_unique should have the value 201304L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_ranges -# error "__cpp_lib_ranges should be defined in c++2a" +# error "__cpp_lib_ranges should be defined in c++20" # endif # if __cpp_lib_ranges != 201811L -# error "__cpp_lib_ranges should have the value 201811L in c++2a" +# error "__cpp_lib_ranges should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_ranges @@ -255,24 +255,24 @@ # endif # ifndef __cpp_lib_raw_memory_algorithms -# error "__cpp_lib_raw_memory_algorithms should be defined in c++2a" +# error "__cpp_lib_raw_memory_algorithms should be defined in c++20" # endif # if __cpp_lib_raw_memory_algorithms != 201606L -# error "__cpp_lib_raw_memory_algorithms should have the value 201606L in c++2a" +# error "__cpp_lib_raw_memory_algorithms should have the value 201606L in c++20" # endif # ifndef __cpp_lib_shared_ptr_arrays -# error "__cpp_lib_shared_ptr_arrays should be defined in c++2a" +# error "__cpp_lib_shared_ptr_arrays should be defined in c++20" # endif # if __cpp_lib_shared_ptr_arrays != 201611L -# error "__cpp_lib_shared_ptr_arrays should have the value 201611L in c++2a" +# error "__cpp_lib_shared_ptr_arrays should have the value 201611L in c++20" # endif # ifndef __cpp_lib_shared_ptr_weak_type -# error "__cpp_lib_shared_ptr_weak_type should be defined in c++2a" +# error "__cpp_lib_shared_ptr_weak_type should be defined in c++20" # endif # if __cpp_lib_shared_ptr_weak_type != 201606L -# error "__cpp_lib_shared_ptr_weak_type should have the value 201606L in c++2a" +# error "__cpp_lib_shared_ptr_weak_type should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/mutex.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/mutex.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/mutex.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/mutex.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_scoped_lock -# error "__cpp_lib_scoped_lock should be defined in c++2a" +# error "__cpp_lib_scoped_lock should be defined in c++20" # endif # if __cpp_lib_scoped_lock != 201703L -# error "__cpp_lib_scoped_lock should have the value 201703L in c++2a" +# error "__cpp_lib_scoped_lock should have the value 201703L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/new.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/new.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/new.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/new.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_destroying_delete 201806L [C++2a] + __cpp_lib_destroying_delete 201806L [C++20] __cpp_lib_hardware_interference_size 201703L [C++17] __cpp_lib_launder 201606L [C++17] */ @@ -25,7 +25,7 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # ifdef __cpp_lib_hardware_interference_size @@ -39,7 +39,7 @@ #elif TEST_STD_VER == 14 # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # ifdef __cpp_lib_hardware_interference_size @@ -53,7 +53,7 @@ #elif TEST_STD_VER == 17 # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -80,10 +80,10 @@ # if TEST_STD_VER > 17 && defined(__cpp_impl_destroying_delete) && __cpp_impl_destroying_delete >= 201806L # ifndef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should be defined in c++2a" +# error "__cpp_lib_destroying_delete should be defined in c++20" # endif # if __cpp_lib_destroying_delete != 201806L -# error "__cpp_lib_destroying_delete should have the value 201806L in c++2a" +# error "__cpp_lib_destroying_delete should have the value 201806L in c++20" # endif # else # ifdef __cpp_lib_destroying_delete @@ -93,10 +93,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_hardware_interference_size -# error "__cpp_lib_hardware_interference_size should be defined in c++2a" +# error "__cpp_lib_hardware_interference_size should be defined in c++20" # endif # if __cpp_lib_hardware_interference_size != 201703L -# error "__cpp_lib_hardware_interference_size should have the value 201703L in c++2a" +# error "__cpp_lib_hardware_interference_size should have the value 201703L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_hardware_interference_size @@ -105,10 +105,10 @@ # endif # ifndef __cpp_lib_launder -# error "__cpp_lib_launder should be defined in c++2a" +# error "__cpp_lib_launder should be defined in c++20" # endif # if __cpp_lib_launder != 201606L -# error "__cpp_lib_launder should have the value 201606L in c++2a" +# error "__cpp_lib_launder should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/numbers.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/numbers.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/numbers.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/numbers.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_math_constants 201907L [C++2a] + __cpp_lib_math_constants 201907L [C++20] */ #include @@ -23,29 +23,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if defined(__cpp_concepts) && __cpp_concepts >= 201811L # ifndef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should be defined in c++2a" +# error "__cpp_lib_math_constants should be defined in c++20" # endif # if __cpp_lib_math_constants != 201907L -# error "__cpp_lib_math_constants should have the value 201907L in c++2a" +# error "__cpp_lib_math_constants should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_math_constants diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/numeric.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/numeric.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/numeric.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/numeric.version.pass.cpp @@ -14,9 +14,9 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_constexpr_numeric 201911L [C++2a] + __cpp_lib_constexpr_numeric 201911L [C++20] __cpp_lib_gcd_lcm 201606L [C++17] - __cpp_lib_interpolate 201902L [C++2a] + __cpp_lib_interpolate 201902L [C++20] __cpp_lib_parallel_algorithm 201603L [C++17] */ @@ -26,7 +26,7 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifdef __cpp_lib_gcd_lcm @@ -34,7 +34,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # ifdef __cpp_lib_parallel_algorithm @@ -44,7 +44,7 @@ #elif TEST_STD_VER == 14 # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifdef __cpp_lib_gcd_lcm @@ -52,7 +52,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # ifdef __cpp_lib_parallel_algorithm @@ -62,7 +62,7 @@ #elif TEST_STD_VER == 17 # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifndef __cpp_lib_gcd_lcm @@ -73,7 +73,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -92,32 +92,32 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should be defined in c++2a" +# error "__cpp_lib_constexpr_numeric should be defined in c++20" # endif # if __cpp_lib_constexpr_numeric != 201911L -# error "__cpp_lib_constexpr_numeric should have the value 201911L in c++2a" +# error "__cpp_lib_constexpr_numeric should have the value 201911L in c++20" # endif # ifndef __cpp_lib_gcd_lcm -# error "__cpp_lib_gcd_lcm should be defined in c++2a" +# error "__cpp_lib_gcd_lcm should be defined in c++20" # endif # if __cpp_lib_gcd_lcm != 201606L -# error "__cpp_lib_gcd_lcm should have the value 201606L in c++2a" +# error "__cpp_lib_gcd_lcm should have the value 201606L in c++20" # endif # ifndef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should be defined in c++2a" +# error "__cpp_lib_interpolate should be defined in c++20" # endif # if __cpp_lib_interpolate != 201902L -# error "__cpp_lib_interpolate should have the value 201902L in c++2a" +# error "__cpp_lib_interpolate should have the value 201902L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_parallel_algorithm -# error "__cpp_lib_parallel_algorithm should be defined in c++2a" +# error "__cpp_lib_parallel_algorithm should be defined in c++20" # endif # if __cpp_lib_parallel_algorithm != 201603L -# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++2a" +# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_parallel_algorithm diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/optional.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/optional.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/optional.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/optional.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_optional -# error "__cpp_lib_optional should be defined in c++2a" +# error "__cpp_lib_optional should be defined in c++20" # endif # if __cpp_lib_optional != 201606L -# error "__cpp_lib_optional should have the value 201606L in c++2a" +# error "__cpp_lib_optional should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/ostream.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/ostream.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/ostream.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/ostream.version.pass.cpp @@ -16,7 +16,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] */ #include @@ -25,29 +25,29 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/regex.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/regex.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/regex.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/regex.version.pass.cpp @@ -46,10 +46,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/scoped_allocator.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/scoped_allocator.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/scoped_allocator.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/scoped_allocator.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/set.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/set.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/set.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/set.version.pass.cpp @@ -15,7 +15,7 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_generic_associative_lookup 201304L [C++14] __cpp_lib_node_extract 201606L [C++17] __cpp_lib_nonmember_container_access 201411L [C++17] @@ -31,7 +31,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_associative_lookup @@ -53,7 +53,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_generic_associative_lookup @@ -81,7 +81,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_generic_associative_lookup @@ -108,38 +108,38 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_generic_associative_lookup -# error "__cpp_lib_generic_associative_lookup should be defined in c++2a" +# error "__cpp_lib_generic_associative_lookup should be defined in c++20" # endif # if __cpp_lib_generic_associative_lookup != 201304L -# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++2a" +# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++20" # endif # ifndef __cpp_lib_node_extract -# error "__cpp_lib_node_extract should be defined in c++2a" +# error "__cpp_lib_node_extract should be defined in c++20" # endif # if __cpp_lib_node_extract != 201606L -# error "__cpp_lib_node_extract should have the value 201606L in c++2a" +# error "__cpp_lib_node_extract should have the value 201606L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/shared_mutex.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/shared_mutex.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/shared_mutex.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/shared_mutex.version.pass.cpp @@ -84,10 +84,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_shared_mutex -# error "__cpp_lib_shared_mutex should be defined in c++2a" +# error "__cpp_lib_shared_mutex should be defined in c++20" # endif # if __cpp_lib_shared_mutex != 201505L -# error "__cpp_lib_shared_mutex should have the value 201505L in c++2a" +# error "__cpp_lib_shared_mutex should have the value 201505L in c++20" # endif # else # ifdef __cpp_lib_shared_mutex @@ -97,10 +97,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_shared_timed_mutex -# error "__cpp_lib_shared_timed_mutex should be defined in c++2a" +# error "__cpp_lib_shared_timed_mutex should be defined in c++20" # endif # if __cpp_lib_shared_timed_mutex != 201402L -# error "__cpp_lib_shared_timed_mutex should have the value 201402L in c++2a" +# error "__cpp_lib_shared_timed_mutex should have the value 201402L in c++20" # endif # else # ifdef __cpp_lib_shared_timed_mutex diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/span.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/span.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/span.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/span.version.pass.cpp @@ -14,7 +14,7 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_span 202002L [C++2a] + __cpp_lib_span 202002L [C++20] */ #include @@ -23,28 +23,28 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif #elif TEST_STD_VER == 14 # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif #elif TEST_STD_VER == 17 # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif #elif TEST_STD_VER > 17 # ifndef __cpp_lib_span -# error "__cpp_lib_span should be defined in c++2a" +# error "__cpp_lib_span should be defined in c++20" # endif # if __cpp_lib_span != 202002L -# error "__cpp_lib_span should have the value 202002L in c++2a" +# error "__cpp_lib_span should have the value 202002L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/string.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/string.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/string.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/string.version.pass.cpp @@ -15,8 +15,8 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_char8_t 201811L [C++2a] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_char8_t 201811L [C++20] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_nonmember_container_access 201411L [C++17] __cpp_lib_string_udls 201304L [C++14] __cpp_lib_string_view 201606L [C++17] @@ -32,11 +32,11 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -58,11 +58,11 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_nonmember_container_access @@ -90,11 +90,11 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_nonmember_container_access @@ -121,18 +121,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t @@ -141,31 +141,31 @@ # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif # ifndef __cpp_lib_string_udls -# error "__cpp_lib_string_udls should be defined in c++2a" +# error "__cpp_lib_string_udls should be defined in c++20" # endif # if __cpp_lib_string_udls != 201304L -# error "__cpp_lib_string_udls should have the value 201304L in c++2a" +# error "__cpp_lib_string_udls should have the value 201304L in c++20" # endif # ifndef __cpp_lib_string_view -# error "__cpp_lib_string_view should be defined in c++2a" +# error "__cpp_lib_string_view should be defined in c++20" # endif # if __cpp_lib_string_view != 201606L -# error "__cpp_lib_string_view should have the value 201606L in c++2a" +# error "__cpp_lib_string_view should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/string_view.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/string_view.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/string_view.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/string_view.version.pass.cpp @@ -14,8 +14,8 @@ // Test the feature test macros defined by /* Constant Value - __cpp_lib_char8_t 201811L [C++2a] - __cpp_lib_constexpr_misc 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] + __cpp_lib_constexpr_misc 201811L [C++20] __cpp_lib_string_view 201606L [C++17] */ @@ -25,11 +25,11 @@ #if TEST_STD_VER < 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_string_view @@ -39,11 +39,11 @@ #elif TEST_STD_VER == 14 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_string_view @@ -53,11 +53,11 @@ #elif TEST_STD_VER == 17 # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_string_view @@ -71,10 +71,10 @@ # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t @@ -84,10 +84,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -96,10 +96,10 @@ # endif # ifndef __cpp_lib_string_view -# error "__cpp_lib_string_view should be defined in c++2a" +# error "__cpp_lib_string_view should be defined in c++20" # endif # if __cpp_lib_string_view != 201606L -# error "__cpp_lib_string_view should have the value 201606L in c++2a" +# error "__cpp_lib_string_view should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/tuple.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/tuple.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/tuple.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/tuple.version.pass.cpp @@ -15,7 +15,7 @@ /* Constant Value __cpp_lib_apply 201603L [C++17] - __cpp_lib_constexpr_misc 201811L [C++2a] + __cpp_lib_constexpr_misc 201811L [C++20] __cpp_lib_make_from_tuple 201606L [C++17] __cpp_lib_tuple_element_t 201402L [C++14] __cpp_lib_tuples_by_type 201304L [C++14] @@ -31,7 +31,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_make_from_tuple @@ -53,7 +53,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_make_from_tuple @@ -84,7 +84,7 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifndef __cpp_lib_make_from_tuple @@ -111,18 +111,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_apply -# error "__cpp_lib_apply should be defined in c++2a" +# error "__cpp_lib_apply should be defined in c++20" # endif # if __cpp_lib_apply != 201603L -# error "__cpp_lib_apply should have the value 201603L in c++2a" +# error "__cpp_lib_apply should have the value 201603L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -131,24 +131,24 @@ # endif # ifndef __cpp_lib_make_from_tuple -# error "__cpp_lib_make_from_tuple should be defined in c++2a" +# error "__cpp_lib_make_from_tuple should be defined in c++20" # endif # if __cpp_lib_make_from_tuple != 201606L -# error "__cpp_lib_make_from_tuple should have the value 201606L in c++2a" +# error "__cpp_lib_make_from_tuple should have the value 201606L in c++20" # endif # ifndef __cpp_lib_tuple_element_t -# error "__cpp_lib_tuple_element_t should be defined in c++2a" +# error "__cpp_lib_tuple_element_t should be defined in c++20" # endif # if __cpp_lib_tuple_element_t != 201402L -# error "__cpp_lib_tuple_element_t should have the value 201402L in c++2a" +# error "__cpp_lib_tuple_element_t should have the value 201402L in c++20" # endif # ifndef __cpp_lib_tuples_by_type -# error "__cpp_lib_tuples_by_type should be defined in c++2a" +# error "__cpp_lib_tuples_by_type should be defined in c++20" # endif # if __cpp_lib_tuples_by_type != 201304L -# error "__cpp_lib_tuples_by_type should have the value 201304L in c++2a" +# error "__cpp_lib_tuples_by_type should have the value 201304L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/type_traits.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/type_traits.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/type_traits.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/type_traits.version.pass.cpp @@ -18,7 +18,7 @@ __cpp_lib_has_unique_object_representations 201606L [C++17] __cpp_lib_integral_constant_callable 201304L [C++14] __cpp_lib_is_aggregate 201703L [C++17] - __cpp_lib_is_constant_evaluated 201811L [C++2a] + __cpp_lib_is_constant_evaluated 201811L [C++20] __cpp_lib_is_final 201402L [C++14] __cpp_lib_is_invocable 201703L [C++17] __cpp_lib_is_null_pointer 201309L [C++14] @@ -52,7 +52,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifdef __cpp_lib_is_final @@ -113,7 +113,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifndef __cpp_lib_is_final @@ -207,7 +207,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifndef __cpp_lib_is_final @@ -276,18 +276,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_bool_constant -# error "__cpp_lib_bool_constant should be defined in c++2a" +# error "__cpp_lib_bool_constant should be defined in c++20" # endif # if __cpp_lib_bool_constant != 201505L -# error "__cpp_lib_bool_constant should have the value 201505L in c++2a" +# error "__cpp_lib_bool_constant should have the value 201505L in c++20" # endif # if TEST_HAS_BUILTIN_IDENTIFIER(__has_unique_object_representations) || TEST_GCC_VER >= 700 # ifndef __cpp_lib_has_unique_object_representations -# error "__cpp_lib_has_unique_object_representations should be defined in c++2a" +# error "__cpp_lib_has_unique_object_representations should be defined in c++20" # endif # if __cpp_lib_has_unique_object_representations != 201606L -# error "__cpp_lib_has_unique_object_representations should have the value 201606L in c++2a" +# error "__cpp_lib_has_unique_object_representations should have the value 201606L in c++20" # endif # else # ifdef __cpp_lib_has_unique_object_representations @@ -296,18 +296,18 @@ # endif # ifndef __cpp_lib_integral_constant_callable -# error "__cpp_lib_integral_constant_callable should be defined in c++2a" +# error "__cpp_lib_integral_constant_callable should be defined in c++20" # endif # if __cpp_lib_integral_constant_callable != 201304L -# error "__cpp_lib_integral_constant_callable should have the value 201304L in c++2a" +# error "__cpp_lib_integral_constant_callable should have the value 201304L in c++20" # endif # if TEST_HAS_BUILTIN_IDENTIFIER(__is_aggregate) || TEST_GCC_VER_NEW >= 7001 # ifndef __cpp_lib_is_aggregate -# error "__cpp_lib_is_aggregate should be defined in c++2a" +# error "__cpp_lib_is_aggregate should be defined in c++20" # endif # if __cpp_lib_is_aggregate != 201703L -# error "__cpp_lib_is_aggregate should have the value 201703L in c++2a" +# error "__cpp_lib_is_aggregate should have the value 201703L in c++20" # endif # else # ifdef __cpp_lib_is_aggregate @@ -317,10 +317,10 @@ # if TEST_HAS_BUILTIN(__builtin_is_constant_evaluated) || TEST_GCC_VER >= 900 # ifndef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should be defined in c++2a" +# error "__cpp_lib_is_constant_evaluated should be defined in c++20" # endif # if __cpp_lib_is_constant_evaluated != 201811L -# error "__cpp_lib_is_constant_evaluated should have the value 201811L in c++2a" +# error "__cpp_lib_is_constant_evaluated should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_is_constant_evaluated @@ -329,66 +329,66 @@ # endif # ifndef __cpp_lib_is_final -# error "__cpp_lib_is_final should be defined in c++2a" +# error "__cpp_lib_is_final should be defined in c++20" # endif # if __cpp_lib_is_final != 201402L -# error "__cpp_lib_is_final should have the value 201402L in c++2a" +# error "__cpp_lib_is_final should have the value 201402L in c++20" # endif # ifndef __cpp_lib_is_invocable -# error "__cpp_lib_is_invocable should be defined in c++2a" +# error "__cpp_lib_is_invocable should be defined in c++20" # endif # if __cpp_lib_is_invocable != 201703L -# error "__cpp_lib_is_invocable should have the value 201703L in c++2a" +# error "__cpp_lib_is_invocable should have the value 201703L in c++20" # endif # ifndef __cpp_lib_is_null_pointer -# error "__cpp_lib_is_null_pointer should be defined in c++2a" +# error "__cpp_lib_is_null_pointer should be defined in c++20" # endif # if __cpp_lib_is_null_pointer != 201309L -# error "__cpp_lib_is_null_pointer should have the value 201309L in c++2a" +# error "__cpp_lib_is_null_pointer should have the value 201309L in c++20" # endif # ifndef __cpp_lib_is_swappable -# error "__cpp_lib_is_swappable should be defined in c++2a" +# error "__cpp_lib_is_swappable should be defined in c++20" # endif # if __cpp_lib_is_swappable != 201603L -# error "__cpp_lib_is_swappable should have the value 201603L in c++2a" +# error "__cpp_lib_is_swappable should have the value 201603L in c++20" # endif # ifndef __cpp_lib_logical_traits -# error "__cpp_lib_logical_traits should be defined in c++2a" +# error "__cpp_lib_logical_traits should be defined in c++20" # endif # if __cpp_lib_logical_traits != 201510L -# error "__cpp_lib_logical_traits should have the value 201510L in c++2a" +# error "__cpp_lib_logical_traits should have the value 201510L in c++20" # endif # ifndef __cpp_lib_result_of_sfinae -# error "__cpp_lib_result_of_sfinae should be defined in c++2a" +# error "__cpp_lib_result_of_sfinae should be defined in c++20" # endif # if __cpp_lib_result_of_sfinae != 201210L -# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++2a" +# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++20" # endif # ifndef __cpp_lib_transformation_trait_aliases -# error "__cpp_lib_transformation_trait_aliases should be defined in c++2a" +# error "__cpp_lib_transformation_trait_aliases should be defined in c++20" # endif # if __cpp_lib_transformation_trait_aliases != 201304L -# error "__cpp_lib_transformation_trait_aliases should have the value 201304L in c++2a" +# error "__cpp_lib_transformation_trait_aliases should have the value 201304L in c++20" # endif # ifndef __cpp_lib_type_trait_variable_templates -# error "__cpp_lib_type_trait_variable_templates should be defined in c++2a" +# error "__cpp_lib_type_trait_variable_templates should be defined in c++20" # endif # if __cpp_lib_type_trait_variable_templates != 201510L -# error "__cpp_lib_type_trait_variable_templates should have the value 201510L in c++2a" +# error "__cpp_lib_type_trait_variable_templates should have the value 201510L in c++20" # endif # ifndef __cpp_lib_void_t -# error "__cpp_lib_void_t should be defined in c++2a" +# error "__cpp_lib_void_t should be defined in c++20" # endif # if __cpp_lib_void_t != 201411L -# error "__cpp_lib_void_t should have the value 201411L in c++2a" +# error "__cpp_lib_void_t should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_map.version.pass.cpp @@ -15,8 +15,8 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] - __cpp_lib_generic_unordered_lookup 201811L [C++2a] + __cpp_lib_erase_if 202002L [C++20] + __cpp_lib_generic_unordered_lookup 201811L [C++20] __cpp_lib_node_extract 201606L [C++17] __cpp_lib_nonmember_container_access 201411L [C++17] __cpp_lib_unordered_map_try_emplace 201411L [C++17] @@ -32,11 +32,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_node_extract @@ -58,11 +58,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_node_extract @@ -87,11 +87,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifndef __cpp_lib_node_extract @@ -118,45 +118,45 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# error "__cpp_lib_generic_unordered_lookup should be defined in c++20" # endif # if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++20" # endif # ifndef __cpp_lib_node_extract -# error "__cpp_lib_node_extract should be defined in c++2a" +# error "__cpp_lib_node_extract should be defined in c++20" # endif # if __cpp_lib_node_extract != 201606L -# error "__cpp_lib_node_extract should have the value 201606L in c++2a" +# error "__cpp_lib_node_extract should have the value 201606L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif # ifndef __cpp_lib_unordered_map_try_emplace -# error "__cpp_lib_unordered_map_try_emplace should be defined in c++2a" +# error "__cpp_lib_unordered_map_try_emplace should be defined in c++20" # endif # if __cpp_lib_unordered_map_try_emplace != 201411L -# error "__cpp_lib_unordered_map_try_emplace should have the value 201411L in c++2a" +# error "__cpp_lib_unordered_map_try_emplace should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/unordered_set.version.pass.cpp @@ -15,8 +15,8 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] - __cpp_lib_generic_unordered_lookup 201811L [C++2a] + __cpp_lib_erase_if 202002L [C++20] + __cpp_lib_generic_unordered_lookup 201811L [C++20] __cpp_lib_node_extract 201606L [C++17] __cpp_lib_nonmember_container_access 201411L [C++17] */ @@ -31,11 +31,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_node_extract @@ -53,11 +53,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_node_extract @@ -78,11 +78,11 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifndef __cpp_lib_node_extract @@ -102,38 +102,38 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# error "__cpp_lib_generic_unordered_lookup should be defined in c++20" # endif # if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++20" # endif # ifndef __cpp_lib_node_extract -# error "__cpp_lib_node_extract should be defined in c++2a" +# error "__cpp_lib_node_extract should be defined in c++20" # endif # if __cpp_lib_node_extract != 201606L -# error "__cpp_lib_node_extract should have the value 201606L in c++2a" +# error "__cpp_lib_node_extract should have the value 201606L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/utility.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/utility.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/utility.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/utility.version.pass.cpp @@ -15,8 +15,8 @@ /* Constant Value __cpp_lib_as_const 201510L [C++17] - __cpp_lib_constexpr_misc 201811L [C++2a] - __cpp_lib_constexpr_utility 201811L [C++2a] + __cpp_lib_constexpr_misc 201811L [C++20] + __cpp_lib_constexpr_utility 201811L [C++20] __cpp_lib_exchange_function 201304L [C++14] __cpp_lib_integer_sequence 201304L [C++14] __cpp_lib_to_chars 201611L [C++17] @@ -33,11 +33,11 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifdef __cpp_lib_exchange_function @@ -63,11 +63,11 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifndef __cpp_lib_exchange_function @@ -105,11 +105,11 @@ # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifndef __cpp_lib_exchange_function @@ -149,18 +149,18 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_as_const -# error "__cpp_lib_as_const should be defined in c++2a" +# error "__cpp_lib_as_const should be defined in c++20" # endif # if __cpp_lib_as_const != 201510L -# error "__cpp_lib_as_const should have the value 201510L in c++2a" +# error "__cpp_lib_as_const should have the value 201510L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -169,32 +169,32 @@ # endif # ifndef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should be defined in c++2a" +# error "__cpp_lib_constexpr_utility should be defined in c++20" # endif # if __cpp_lib_constexpr_utility != 201811L -# error "__cpp_lib_constexpr_utility should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_utility should have the value 201811L in c++20" # endif # ifndef __cpp_lib_exchange_function -# error "__cpp_lib_exchange_function should be defined in c++2a" +# error "__cpp_lib_exchange_function should be defined in c++20" # endif # if __cpp_lib_exchange_function != 201304L -# error "__cpp_lib_exchange_function should have the value 201304L in c++2a" +# error "__cpp_lib_exchange_function should have the value 201304L in c++20" # endif # ifndef __cpp_lib_integer_sequence -# error "__cpp_lib_integer_sequence should be defined in c++2a" +# error "__cpp_lib_integer_sequence should be defined in c++20" # endif # if __cpp_lib_integer_sequence != 201304L -# error "__cpp_lib_integer_sequence should have the value 201304L in c++2a" +# error "__cpp_lib_integer_sequence should have the value 201304L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_to_chars -# error "__cpp_lib_to_chars should be defined in c++2a" +# error "__cpp_lib_to_chars should be defined in c++20" # endif # if __cpp_lib_to_chars != 201611L -# error "__cpp_lib_to_chars should have the value 201611L in c++2a" +# error "__cpp_lib_to_chars should have the value 201611L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_to_chars @@ -203,10 +203,10 @@ # endif # ifndef __cpp_lib_tuples_by_type -# error "__cpp_lib_tuples_by_type should be defined in c++2a" +# error "__cpp_lib_tuples_by_type should be defined in c++20" # endif # if __cpp_lib_tuples_by_type != 201304L -# error "__cpp_lib_tuples_by_type should have the value 201304L in c++2a" +# error "__cpp_lib_tuples_by_type should have the value 201304L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/variant.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/variant.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/variant.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/variant.version.pass.cpp @@ -44,10 +44,10 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_variant -# error "__cpp_lib_variant should be defined in c++2a" +# error "__cpp_lib_variant should be defined in c++20" # endif # if __cpp_lib_variant != 201606L -# error "__cpp_lib_variant should have the value 201606L in c++2a" +# error "__cpp_lib_variant should have the value 201606L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/vector.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/vector.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/vector.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/vector.version.pass.cpp @@ -15,7 +15,7 @@ /* Constant Value __cpp_lib_allocator_traits_is_always_equal 201411L [C++17] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_incomplete_container_elements 201505L [C++17] __cpp_lib_nonmember_container_access 201411L [C++17] */ @@ -30,7 +30,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -48,7 +48,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_incomplete_container_elements @@ -69,7 +69,7 @@ # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_incomplete_container_elements @@ -89,31 +89,31 @@ #elif TEST_STD_VER > 17 # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_incomplete_container_elements -# error "__cpp_lib_incomplete_container_elements should be defined in c++2a" +# error "__cpp_lib_incomplete_container_elements should be defined in c++20" # endif # if __cpp_lib_incomplete_container_elements != 201505L -# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++2a" +# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp b/libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp --- a/libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp +++ b/libcxx/test/std/language.support/support.limits/support.limits.general/version.version.pass.cpp @@ -19,65 +19,65 @@ __cpp_lib_any 201606L [C++17] __cpp_lib_apply 201603L [C++17] __cpp_lib_array_constexpr 201603L [C++17] - 201811L [C++2a] + 201811L [C++20] __cpp_lib_as_const 201510L [C++17] - __cpp_lib_atomic_flag_test 201907L [C++2a] - __cpp_lib_atomic_float 201711L [C++2a] + __cpp_lib_atomic_flag_test 201907L [C++20] + __cpp_lib_atomic_float 201711L [C++20] __cpp_lib_atomic_is_always_lock_free 201603L [C++17] - __cpp_lib_atomic_lock_free_type_aliases 201907L [C++2a] - __cpp_lib_atomic_ref 201806L [C++2a] - __cpp_lib_atomic_shared_ptr 201711L [C++2a] - __cpp_lib_atomic_value_initialization 201911L [C++2a] - __cpp_lib_atomic_wait 201907L [C++2a] - __cpp_lib_bind_front 201811L [C++2a] - __cpp_lib_bit_cast 201806L [C++2a] + __cpp_lib_atomic_lock_free_type_aliases 201907L [C++20] + __cpp_lib_atomic_ref 201806L [C++20] + __cpp_lib_atomic_shared_ptr 201711L [C++20] + __cpp_lib_atomic_value_initialization 201911L [C++20] + __cpp_lib_atomic_wait 201907L [C++20] + __cpp_lib_bind_front 201811L [C++20] + __cpp_lib_bit_cast 201806L [C++20] __cpp_lib_bool_constant 201505L [C++17] __cpp_lib_boyer_moore_searcher 201603L [C++17] __cpp_lib_byte 201603L [C++17] - __cpp_lib_char8_t 201811L [C++2a] + __cpp_lib_char8_t 201811L [C++20] __cpp_lib_chrono 201611L [C++17] __cpp_lib_chrono_udls 201304L [C++14] __cpp_lib_clamp 201603L [C++17] __cpp_lib_complex_udls 201309L [C++14] - __cpp_lib_concepts 201806L [C++2a] - __cpp_lib_constexpr_dynamic_alloc 201907L [C++2a] - __cpp_lib_constexpr_misc 201811L [C++2a] - __cpp_lib_constexpr_numeric 201911L [C++2a] - __cpp_lib_constexpr_swap_algorithms 201806L [C++2a] - __cpp_lib_constexpr_utility 201811L [C++2a] - __cpp_lib_destroying_delete 201806L [C++2a] + __cpp_lib_concepts 201806L [C++20] + __cpp_lib_constexpr_dynamic_alloc 201907L [C++20] + __cpp_lib_constexpr_misc 201811L [C++20] + __cpp_lib_constexpr_numeric 201911L [C++20] + __cpp_lib_constexpr_swap_algorithms 201806L [C++20] + __cpp_lib_constexpr_utility 201811L [C++20] + __cpp_lib_destroying_delete 201806L [C++20] __cpp_lib_enable_shared_from_this 201603L [C++17] - __cpp_lib_endian 201907L [C++2a] - __cpp_lib_erase_if 202002L [C++2a] + __cpp_lib_endian 201907L [C++20] + __cpp_lib_erase_if 202002L [C++20] __cpp_lib_exchange_function 201304L [C++14] __cpp_lib_execution 201603L [C++17] __cpp_lib_filesystem 201703L [C++17] __cpp_lib_gcd_lcm 201606L [C++17] __cpp_lib_generic_associative_lookup 201304L [C++14] - __cpp_lib_generic_unordered_lookup 201811L [C++2a] + __cpp_lib_generic_unordered_lookup 201811L [C++20] __cpp_lib_hardware_interference_size 201703L [C++17] __cpp_lib_has_unique_object_representations 201606L [C++17] __cpp_lib_hypot 201603L [C++17] __cpp_lib_incomplete_container_elements 201505L [C++17] - __cpp_lib_int_pow2 202002L [C++2a] + __cpp_lib_int_pow2 202002L [C++20] __cpp_lib_integer_sequence 201304L [C++14] __cpp_lib_integral_constant_callable 201304L [C++14] - __cpp_lib_interpolate 201902L [C++2a] + __cpp_lib_interpolate 201902L [C++20] __cpp_lib_invoke 201411L [C++17] __cpp_lib_is_aggregate 201703L [C++17] - __cpp_lib_is_constant_evaluated 201811L [C++2a] + __cpp_lib_is_constant_evaluated 201811L [C++20] __cpp_lib_is_final 201402L [C++14] __cpp_lib_is_invocable 201703L [C++17] __cpp_lib_is_null_pointer 201309L [C++14] __cpp_lib_is_swappable 201603L [C++17] __cpp_lib_launder 201606L [C++17] - __cpp_lib_list_remove_return_type 201806L [C++2a] + __cpp_lib_list_remove_return_type 201806L [C++20] __cpp_lib_logical_traits 201510L [C++17] __cpp_lib_make_from_tuple 201606L [C++17] __cpp_lib_make_reverse_iterator 201402L [C++14] __cpp_lib_make_unique 201304L [C++14] __cpp_lib_map_try_emplace 201411L [C++17] - __cpp_lib_math_constants 201907L [C++2a] + __cpp_lib_math_constants 201907L [C++20] __cpp_lib_math_special_functions 201603L [C++17] __cpp_lib_memory_resource 201603L [C++17] __cpp_lib_node_extract 201606L [C++17] @@ -87,7 +87,7 @@ __cpp_lib_optional 201606L [C++17] __cpp_lib_parallel_algorithm 201603L [C++17] __cpp_lib_quoted_string_io 201304L [C++14] - __cpp_lib_ranges 201811L [C++2a] + __cpp_lib_ranges 201811L [C++20] __cpp_lib_raw_memory_algorithms 201606L [C++17] __cpp_lib_result_of_sfinae 201210L [C++14] __cpp_lib_robust_nonmodifying_seq_ops 201304L [C++14] @@ -97,11 +97,11 @@ __cpp_lib_shared_ptr_arrays 201611L [C++17] __cpp_lib_shared_ptr_weak_type 201606L [C++17] __cpp_lib_shared_timed_mutex 201402L [C++14] - __cpp_lib_span 202002L [C++2a] + __cpp_lib_span 202002L [C++20] __cpp_lib_string_udls 201304L [C++14] __cpp_lib_string_view 201606L [C++17] - __cpp_lib_three_way_comparison 201711L [C++2a] - __cpp_lib_to_array 201907L [C++2a] + __cpp_lib_three_way_comparison 201711L [C++20] + __cpp_lib_to_array 201907L [C++20] __cpp_lib_to_chars 201611L [C++17] __cpp_lib_transformation_trait_aliases 201304L [C++14] __cpp_lib_transparent_operators 201210L [C++14] @@ -145,11 +145,11 @@ # endif # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_is_always_lock_free @@ -157,31 +157,31 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifdef __cpp_lib_bool_constant @@ -197,7 +197,7 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_chrono @@ -217,31 +217,31 @@ # endif # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # ifdef __cpp_lib_enable_shared_from_this @@ -249,11 +249,11 @@ # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifdef __cpp_lib_exchange_function @@ -277,7 +277,7 @@ # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_hardware_interference_size @@ -297,7 +297,7 @@ # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif # ifdef __cpp_lib_integer_sequence @@ -309,7 +309,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # ifdef __cpp_lib_invoke @@ -321,7 +321,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifdef __cpp_lib_is_final @@ -345,7 +345,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_logical_traits @@ -369,7 +369,7 @@ # endif # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif # ifdef __cpp_lib_math_special_functions @@ -409,7 +409,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_raw_memory_algorithms @@ -449,7 +449,7 @@ # endif # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif # ifdef __cpp_lib_string_udls @@ -461,11 +461,11 @@ # endif # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif # ifdef __cpp_lib_to_chars @@ -535,11 +535,11 @@ # endif # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_is_always_lock_free @@ -547,31 +547,31 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifdef __cpp_lib_bool_constant @@ -587,7 +587,7 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifdef __cpp_lib_chrono @@ -613,31 +613,31 @@ # endif # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # ifdef __cpp_lib_enable_shared_from_this @@ -645,11 +645,11 @@ # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_exchange_function @@ -679,7 +679,7 @@ # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # ifdef __cpp_lib_hardware_interference_size @@ -699,7 +699,7 @@ # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif # ifndef __cpp_lib_integer_sequence @@ -717,7 +717,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # ifdef __cpp_lib_invoke @@ -729,7 +729,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifndef __cpp_lib_is_final @@ -759,7 +759,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifdef __cpp_lib_logical_traits @@ -789,7 +789,7 @@ # endif # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif # ifdef __cpp_lib_math_special_functions @@ -835,7 +835,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifdef __cpp_lib_raw_memory_algorithms @@ -890,7 +890,7 @@ # endif # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif # ifndef __cpp_lib_string_udls @@ -905,11 +905,11 @@ # endif # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif # ifdef __cpp_lib_to_chars @@ -1015,11 +1015,11 @@ # endif # ifdef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should not be defined before c++2a" +# error "__cpp_lib_atomic_flag_test should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should not be defined before c++2a" +# error "__cpp_lib_atomic_float should not be defined before c++20" # endif # if !defined(_LIBCPP_HAS_NO_THREADS) @@ -1036,31 +1036,31 @@ # endif # ifdef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should not be defined before c++2a" +# error "__cpp_lib_atomic_ref should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should not be defined before c++2a" +# error "__cpp_lib_atomic_shared_ptr should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should not be defined before c++2a" +# error "__cpp_lib_atomic_value_initialization should not be defined before c++20" # endif # ifdef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should not be defined before c++2a" +# error "__cpp_lib_atomic_wait should not be defined before c++20" # endif # ifdef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should not be defined before c++2a" +# error "__cpp_lib_bind_front should not be defined before c++20" # endif # ifdef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should not be defined before c++2a" +# error "__cpp_lib_bit_cast should not be defined before c++20" # endif # ifndef __cpp_lib_bool_constant @@ -1091,7 +1091,7 @@ # endif # ifdef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should not be defined before c++2a" +# error "__cpp_lib_char8_t should not be defined before c++20" # endif # ifndef __cpp_lib_chrono @@ -1123,31 +1123,31 @@ # endif # ifdef __cpp_lib_concepts -# error "__cpp_lib_concepts should not be defined before c++2a" +# error "__cpp_lib_concepts should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should not be defined before c++2a" +# error "__cpp_lib_constexpr_misc should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should not be defined before c++2a" +# error "__cpp_lib_constexpr_numeric should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should not be defined before c++20" # endif # ifdef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should not be defined before c++2a" +# error "__cpp_lib_constexpr_utility should not be defined before c++20" # endif # ifdef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should not be defined before c++2a" +# error "__cpp_lib_destroying_delete should not be defined before c++20" # endif # ifndef __cpp_lib_enable_shared_from_this @@ -1158,11 +1158,11 @@ # endif # ifdef __cpp_lib_endian -# error "__cpp_lib_endian should not be defined before c++2a" +# error "__cpp_lib_endian should not be defined before c++20" # endif # ifdef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should not be defined before c++2a" +# error "__cpp_lib_erase_if should not be defined before c++20" # endif # ifndef __cpp_lib_exchange_function @@ -1207,7 +1207,7 @@ # endif # ifdef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should not be defined before c++2a" +# error "__cpp_lib_generic_unordered_lookup should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -1251,7 +1251,7 @@ # endif # ifdef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should not be defined before c++2a" +# error "__cpp_lib_int_pow2 should not be defined before c++20" # endif # ifndef __cpp_lib_integer_sequence @@ -1269,7 +1269,7 @@ # endif # ifdef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should not be defined before c++2a" +# error "__cpp_lib_interpolate should not be defined before c++20" # endif # ifndef __cpp_lib_invoke @@ -1293,7 +1293,7 @@ # endif # ifdef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should not be defined before c++2a" +# error "__cpp_lib_is_constant_evaluated should not be defined before c++20" # endif # ifndef __cpp_lib_is_final @@ -1332,7 +1332,7 @@ # endif # ifdef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should not be defined before c++2a" +# error "__cpp_lib_list_remove_return_type should not be defined before c++20" # endif # ifndef __cpp_lib_logical_traits @@ -1371,7 +1371,7 @@ # endif # ifdef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should not be defined before c++2a" +# error "__cpp_lib_math_constants should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -1456,7 +1456,7 @@ # endif # ifdef __cpp_lib_ranges -# error "__cpp_lib_ranges should not be defined before c++2a" +# error "__cpp_lib_ranges should not be defined before c++20" # endif # ifndef __cpp_lib_raw_memory_algorithms @@ -1535,7 +1535,7 @@ # endif # ifdef __cpp_lib_span -# error "__cpp_lib_span should not be defined before c++2a" +# error "__cpp_lib_span should not be defined before c++20" # endif # ifndef __cpp_lib_string_udls @@ -1553,11 +1553,11 @@ # endif # ifdef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should not be defined before c++2a" +# error "__cpp_lib_three_way_comparison should not be defined before c++20" # endif # ifdef __cpp_lib_to_array -# error "__cpp_lib_to_array should not be defined before c++2a" +# error "__cpp_lib_to_array should not be defined before c++20" # endif # if !defined(_LIBCPP_VERSION) @@ -1640,10 +1640,10 @@ # if TEST_HAS_BUILTIN(__builtin_addressof) || TEST_GCC_VER >= 700 # ifndef __cpp_lib_addressof_constexpr -# error "__cpp_lib_addressof_constexpr should be defined in c++2a" +# error "__cpp_lib_addressof_constexpr should be defined in c++20" # endif # if __cpp_lib_addressof_constexpr != 201603L -# error "__cpp_lib_addressof_constexpr should have the value 201603L in c++2a" +# error "__cpp_lib_addressof_constexpr should have the value 201603L in c++20" # endif # else # ifdef __cpp_lib_addressof_constexpr @@ -1652,46 +1652,46 @@ # endif # ifndef __cpp_lib_allocator_traits_is_always_equal -# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should be defined in c++20" # endif # if __cpp_lib_allocator_traits_is_always_equal != 201411L -# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++2a" +# error "__cpp_lib_allocator_traits_is_always_equal should have the value 201411L in c++20" # endif # ifndef __cpp_lib_any -# error "__cpp_lib_any should be defined in c++2a" +# error "__cpp_lib_any should be defined in c++20" # endif # if __cpp_lib_any != 201606L -# error "__cpp_lib_any should have the value 201606L in c++2a" +# error "__cpp_lib_any should have the value 201606L in c++20" # endif # ifndef __cpp_lib_apply -# error "__cpp_lib_apply should be defined in c++2a" +# error "__cpp_lib_apply should be defined in c++20" # endif # if __cpp_lib_apply != 201603L -# error "__cpp_lib_apply should have the value 201603L in c++2a" +# error "__cpp_lib_apply should have the value 201603L in c++20" # endif # ifndef __cpp_lib_array_constexpr -# error "__cpp_lib_array_constexpr should be defined in c++2a" +# error "__cpp_lib_array_constexpr should be defined in c++20" # endif # if __cpp_lib_array_constexpr != 201811L -# error "__cpp_lib_array_constexpr should have the value 201811L in c++2a" +# error "__cpp_lib_array_constexpr should have the value 201811L in c++20" # endif # ifndef __cpp_lib_as_const -# error "__cpp_lib_as_const should be defined in c++2a" +# error "__cpp_lib_as_const should be defined in c++20" # endif # if __cpp_lib_as_const != 201510L -# error "__cpp_lib_as_const should have the value 201510L in c++2a" +# error "__cpp_lib_as_const should have the value 201510L in c++20" # endif # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_flag_test -# error "__cpp_lib_atomic_flag_test should be defined in c++2a" +# error "__cpp_lib_atomic_flag_test should be defined in c++20" # endif # if __cpp_lib_atomic_flag_test != 201907L -# error "__cpp_lib_atomic_flag_test should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_flag_test should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_flag_test @@ -1701,10 +1701,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_float -# error "__cpp_lib_atomic_float should be defined in c++2a" +# error "__cpp_lib_atomic_float should be defined in c++20" # endif # if __cpp_lib_atomic_float != 201711L -# error "__cpp_lib_atomic_float should have the value 201711L in c++2a" +# error "__cpp_lib_atomic_float should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_float @@ -1714,10 +1714,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_is_always_lock_free -# error "__cpp_lib_atomic_is_always_lock_free should be defined in c++2a" +# error "__cpp_lib_atomic_is_always_lock_free should be defined in c++20" # endif # if __cpp_lib_atomic_is_always_lock_free != 201603L -# error "__cpp_lib_atomic_is_always_lock_free should have the value 201603L in c++2a" +# error "__cpp_lib_atomic_is_always_lock_free should have the value 201603L in c++20" # endif # else # ifdef __cpp_lib_atomic_is_always_lock_free @@ -1727,10 +1727,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_lock_free_type_aliases -# error "__cpp_lib_atomic_lock_free_type_aliases should be defined in c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should be defined in c++20" # endif # if __cpp_lib_atomic_lock_free_type_aliases != 201907L -# error "__cpp_lib_atomic_lock_free_type_aliases should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_lock_free_type_aliases should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_lock_free_type_aliases @@ -1740,10 +1740,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_ref -# error "__cpp_lib_atomic_ref should be defined in c++2a" +# error "__cpp_lib_atomic_ref should be defined in c++20" # endif # if __cpp_lib_atomic_ref != 201806L -# error "__cpp_lib_atomic_ref should have the value 201806L in c++2a" +# error "__cpp_lib_atomic_ref should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_ref @@ -1753,10 +1753,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_shared_ptr -# error "__cpp_lib_atomic_shared_ptr should be defined in c++2a" +# error "__cpp_lib_atomic_shared_ptr should be defined in c++20" # endif # if __cpp_lib_atomic_shared_ptr != 201711L -# error "__cpp_lib_atomic_shared_ptr should have the value 201711L in c++2a" +# error "__cpp_lib_atomic_shared_ptr should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_shared_ptr @@ -1766,10 +1766,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_atomic_value_initialization -# error "__cpp_lib_atomic_value_initialization should be defined in c++2a" +# error "__cpp_lib_atomic_value_initialization should be defined in c++20" # endif # if __cpp_lib_atomic_value_initialization != 201911L -# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++2a" +# error "__cpp_lib_atomic_value_initialization should have the value 201911L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_atomic_value_initialization @@ -1779,10 +1779,10 @@ # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_atomic_wait -# error "__cpp_lib_atomic_wait should be defined in c++2a" +# error "__cpp_lib_atomic_wait should be defined in c++20" # endif # if __cpp_lib_atomic_wait != 201907L -# error "__cpp_lib_atomic_wait should have the value 201907L in c++2a" +# error "__cpp_lib_atomic_wait should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_atomic_wait @@ -1792,10 +1792,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_bind_front -# error "__cpp_lib_bind_front should be defined in c++2a" +# error "__cpp_lib_bind_front should be defined in c++20" # endif # if __cpp_lib_bind_front != 201811L -# error "__cpp_lib_bind_front should have the value 201811L in c++2a" +# error "__cpp_lib_bind_front should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_bind_front @@ -1805,10 +1805,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_bit_cast -# error "__cpp_lib_bit_cast should be defined in c++2a" +# error "__cpp_lib_bit_cast should be defined in c++20" # endif # if __cpp_lib_bit_cast != 201806L -# error "__cpp_lib_bit_cast should have the value 201806L in c++2a" +# error "__cpp_lib_bit_cast should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_bit_cast @@ -1817,18 +1817,18 @@ # endif # ifndef __cpp_lib_bool_constant -# error "__cpp_lib_bool_constant should be defined in c++2a" +# error "__cpp_lib_bool_constant should be defined in c++20" # endif # if __cpp_lib_bool_constant != 201505L -# error "__cpp_lib_bool_constant should have the value 201505L in c++2a" +# error "__cpp_lib_bool_constant should have the value 201505L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_boyer_moore_searcher -# error "__cpp_lib_boyer_moore_searcher should be defined in c++2a" +# error "__cpp_lib_boyer_moore_searcher should be defined in c++20" # endif # if __cpp_lib_boyer_moore_searcher != 201603L -# error "__cpp_lib_boyer_moore_searcher should have the value 201603L in c++2a" +# error "__cpp_lib_boyer_moore_searcher should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_boyer_moore_searcher @@ -1837,18 +1837,18 @@ # endif # ifndef __cpp_lib_byte -# error "__cpp_lib_byte should be defined in c++2a" +# error "__cpp_lib_byte should be defined in c++20" # endif # if __cpp_lib_byte != 201603L -# error "__cpp_lib_byte should have the value 201603L in c++2a" +# error "__cpp_lib_byte should have the value 201603L in c++20" # endif # if defined(__cpp_char8_t) # ifndef __cpp_lib_char8_t -# error "__cpp_lib_char8_t should be defined in c++2a" +# error "__cpp_lib_char8_t should be defined in c++20" # endif # if __cpp_lib_char8_t != 201811L -# error "__cpp_lib_char8_t should have the value 201811L in c++2a" +# error "__cpp_lib_char8_t should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_char8_t @@ -1857,39 +1857,39 @@ # endif # ifndef __cpp_lib_chrono -# error "__cpp_lib_chrono should be defined in c++2a" +# error "__cpp_lib_chrono should be defined in c++20" # endif # if __cpp_lib_chrono != 201611L -# error "__cpp_lib_chrono should have the value 201611L in c++2a" +# error "__cpp_lib_chrono should have the value 201611L in c++20" # endif # ifndef __cpp_lib_chrono_udls -# error "__cpp_lib_chrono_udls should be defined in c++2a" +# error "__cpp_lib_chrono_udls should be defined in c++20" # endif # if __cpp_lib_chrono_udls != 201304L -# error "__cpp_lib_chrono_udls should have the value 201304L in c++2a" +# error "__cpp_lib_chrono_udls should have the value 201304L in c++20" # endif # ifndef __cpp_lib_clamp -# error "__cpp_lib_clamp should be defined in c++2a" +# error "__cpp_lib_clamp should be defined in c++20" # endif # if __cpp_lib_clamp != 201603L -# error "__cpp_lib_clamp should have the value 201603L in c++2a" +# error "__cpp_lib_clamp should have the value 201603L in c++20" # endif # ifndef __cpp_lib_complex_udls -# error "__cpp_lib_complex_udls should be defined in c++2a" +# error "__cpp_lib_complex_udls should be defined in c++20" # endif # if __cpp_lib_complex_udls != 201309L -# error "__cpp_lib_complex_udls should have the value 201309L in c++2a" +# error "__cpp_lib_complex_udls should have the value 201309L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_concepts -# error "__cpp_lib_concepts should be defined in c++2a" +# error "__cpp_lib_concepts should be defined in c++20" # endif # if __cpp_lib_concepts != 201806L -# error "__cpp_lib_concepts should have the value 201806L in c++2a" +# error "__cpp_lib_concepts should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_concepts @@ -1898,18 +1898,18 @@ # endif # ifndef __cpp_lib_constexpr_dynamic_alloc -# error "__cpp_lib_constexpr_dynamic_alloc should be defined in c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should be defined in c++20" # endif # if __cpp_lib_constexpr_dynamic_alloc != 201907L -# error "__cpp_lib_constexpr_dynamic_alloc should have the value 201907L in c++2a" +# error "__cpp_lib_constexpr_dynamic_alloc should have the value 201907L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_misc -# error "__cpp_lib_constexpr_misc should be defined in c++2a" +# error "__cpp_lib_constexpr_misc should be defined in c++20" # endif # if __cpp_lib_constexpr_misc != 201811L -# error "__cpp_lib_constexpr_misc should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_misc should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_misc @@ -1918,18 +1918,18 @@ # endif # ifndef __cpp_lib_constexpr_numeric -# error "__cpp_lib_constexpr_numeric should be defined in c++2a" +# error "__cpp_lib_constexpr_numeric should be defined in c++20" # endif # if __cpp_lib_constexpr_numeric != 201911L -# error "__cpp_lib_constexpr_numeric should have the value 201911L in c++2a" +# error "__cpp_lib_constexpr_numeric should have the value 201911L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_constexpr_swap_algorithms -# error "__cpp_lib_constexpr_swap_algorithms should be defined in c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should be defined in c++20" # endif # if __cpp_lib_constexpr_swap_algorithms != 201806L -# error "__cpp_lib_constexpr_swap_algorithms should have the value 201806L in c++2a" +# error "__cpp_lib_constexpr_swap_algorithms should have the value 201806L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_constexpr_swap_algorithms @@ -1938,18 +1938,18 @@ # endif # ifndef __cpp_lib_constexpr_utility -# error "__cpp_lib_constexpr_utility should be defined in c++2a" +# error "__cpp_lib_constexpr_utility should be defined in c++20" # endif # if __cpp_lib_constexpr_utility != 201811L -# error "__cpp_lib_constexpr_utility should have the value 201811L in c++2a" +# error "__cpp_lib_constexpr_utility should have the value 201811L in c++20" # endif # if TEST_STD_VER > 17 && defined(__cpp_impl_destroying_delete) && __cpp_impl_destroying_delete >= 201806L # ifndef __cpp_lib_destroying_delete -# error "__cpp_lib_destroying_delete should be defined in c++2a" +# error "__cpp_lib_destroying_delete should be defined in c++20" # endif # if __cpp_lib_destroying_delete != 201806L -# error "__cpp_lib_destroying_delete should have the value 201806L in c++2a" +# error "__cpp_lib_destroying_delete should have the value 201806L in c++20" # endif # else # ifdef __cpp_lib_destroying_delete @@ -1958,39 +1958,39 @@ # endif # ifndef __cpp_lib_enable_shared_from_this -# error "__cpp_lib_enable_shared_from_this should be defined in c++2a" +# error "__cpp_lib_enable_shared_from_this should be defined in c++20" # endif # if __cpp_lib_enable_shared_from_this != 201603L -# error "__cpp_lib_enable_shared_from_this should have the value 201603L in c++2a" +# error "__cpp_lib_enable_shared_from_this should have the value 201603L in c++20" # endif # ifndef __cpp_lib_endian -# error "__cpp_lib_endian should be defined in c++2a" +# error "__cpp_lib_endian should be defined in c++20" # endif # if __cpp_lib_endian != 201907L -# error "__cpp_lib_endian should have the value 201907L in c++2a" +# error "__cpp_lib_endian should have the value 201907L in c++20" # endif # ifndef __cpp_lib_erase_if -# error "__cpp_lib_erase_if should be defined in c++2a" +# error "__cpp_lib_erase_if should be defined in c++20" # endif # if __cpp_lib_erase_if != 202002L -# error "__cpp_lib_erase_if should have the value 202002L in c++2a" +# error "__cpp_lib_erase_if should have the value 202002L in c++20" # endif # ifndef __cpp_lib_exchange_function -# error "__cpp_lib_exchange_function should be defined in c++2a" +# error "__cpp_lib_exchange_function should be defined in c++20" # endif # if __cpp_lib_exchange_function != 201304L -# error "__cpp_lib_exchange_function should have the value 201304L in c++2a" +# error "__cpp_lib_exchange_function should have the value 201304L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_execution -# error "__cpp_lib_execution should be defined in c++2a" +# error "__cpp_lib_execution should be defined in c++20" # endif # if __cpp_lib_execution != 201603L -# error "__cpp_lib_execution should have the value 201603L in c++2a" +# error "__cpp_lib_execution should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_execution @@ -1999,39 +1999,39 @@ # endif # ifndef __cpp_lib_filesystem -# error "__cpp_lib_filesystem should be defined in c++2a" +# error "__cpp_lib_filesystem should be defined in c++20" # endif # if __cpp_lib_filesystem != 201703L -# error "__cpp_lib_filesystem should have the value 201703L in c++2a" +# error "__cpp_lib_filesystem should have the value 201703L in c++20" # endif # ifndef __cpp_lib_gcd_lcm -# error "__cpp_lib_gcd_lcm should be defined in c++2a" +# error "__cpp_lib_gcd_lcm should be defined in c++20" # endif # if __cpp_lib_gcd_lcm != 201606L -# error "__cpp_lib_gcd_lcm should have the value 201606L in c++2a" +# error "__cpp_lib_gcd_lcm should have the value 201606L in c++20" # endif # ifndef __cpp_lib_generic_associative_lookup -# error "__cpp_lib_generic_associative_lookup should be defined in c++2a" +# error "__cpp_lib_generic_associative_lookup should be defined in c++20" # endif # if __cpp_lib_generic_associative_lookup != 201304L -# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++2a" +# error "__cpp_lib_generic_associative_lookup should have the value 201304L in c++20" # endif # ifndef __cpp_lib_generic_unordered_lookup -# error "__cpp_lib_generic_unordered_lookup should be defined in c++2a" +# error "__cpp_lib_generic_unordered_lookup should be defined in c++20" # endif # if __cpp_lib_generic_unordered_lookup != 201811L -# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++2a" +# error "__cpp_lib_generic_unordered_lookup should have the value 201811L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_hardware_interference_size -# error "__cpp_lib_hardware_interference_size should be defined in c++2a" +# error "__cpp_lib_hardware_interference_size should be defined in c++20" # endif # if __cpp_lib_hardware_interference_size != 201703L -# error "__cpp_lib_hardware_interference_size should have the value 201703L in c++2a" +# error "__cpp_lib_hardware_interference_size should have the value 201703L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_hardware_interference_size @@ -2041,10 +2041,10 @@ # if TEST_HAS_BUILTIN_IDENTIFIER(__has_unique_object_representations) || TEST_GCC_VER >= 700 # ifndef __cpp_lib_has_unique_object_representations -# error "__cpp_lib_has_unique_object_representations should be defined in c++2a" +# error "__cpp_lib_has_unique_object_representations should be defined in c++20" # endif # if __cpp_lib_has_unique_object_representations != 201606L -# error "__cpp_lib_has_unique_object_representations should have the value 201606L in c++2a" +# error "__cpp_lib_has_unique_object_representations should have the value 201606L in c++20" # endif # else # ifdef __cpp_lib_has_unique_object_representations @@ -2053,60 +2053,60 @@ # endif # ifndef __cpp_lib_hypot -# error "__cpp_lib_hypot should be defined in c++2a" +# error "__cpp_lib_hypot should be defined in c++20" # endif # if __cpp_lib_hypot != 201603L -# error "__cpp_lib_hypot should have the value 201603L in c++2a" +# error "__cpp_lib_hypot should have the value 201603L in c++20" # endif # ifndef __cpp_lib_incomplete_container_elements -# error "__cpp_lib_incomplete_container_elements should be defined in c++2a" +# error "__cpp_lib_incomplete_container_elements should be defined in c++20" # endif # if __cpp_lib_incomplete_container_elements != 201505L -# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++2a" +# error "__cpp_lib_incomplete_container_elements should have the value 201505L in c++20" # endif # ifndef __cpp_lib_int_pow2 -# error "__cpp_lib_int_pow2 should be defined in c++2a" +# error "__cpp_lib_int_pow2 should be defined in c++20" # endif # if __cpp_lib_int_pow2 != 202002L -# error "__cpp_lib_int_pow2 should have the value 202002L in c++2a" +# error "__cpp_lib_int_pow2 should have the value 202002L in c++20" # endif # ifndef __cpp_lib_integer_sequence -# error "__cpp_lib_integer_sequence should be defined in c++2a" +# error "__cpp_lib_integer_sequence should be defined in c++20" # endif # if __cpp_lib_integer_sequence != 201304L -# error "__cpp_lib_integer_sequence should have the value 201304L in c++2a" +# error "__cpp_lib_integer_sequence should have the value 201304L in c++20" # endif # ifndef __cpp_lib_integral_constant_callable -# error "__cpp_lib_integral_constant_callable should be defined in c++2a" +# error "__cpp_lib_integral_constant_callable should be defined in c++20" # endif # if __cpp_lib_integral_constant_callable != 201304L -# error "__cpp_lib_integral_constant_callable should have the value 201304L in c++2a" +# error "__cpp_lib_integral_constant_callable should have the value 201304L in c++20" # endif # ifndef __cpp_lib_interpolate -# error "__cpp_lib_interpolate should be defined in c++2a" +# error "__cpp_lib_interpolate should be defined in c++20" # endif # if __cpp_lib_interpolate != 201902L -# error "__cpp_lib_interpolate should have the value 201902L in c++2a" +# error "__cpp_lib_interpolate should have the value 201902L in c++20" # endif # ifndef __cpp_lib_invoke -# error "__cpp_lib_invoke should be defined in c++2a" +# error "__cpp_lib_invoke should be defined in c++20" # endif # if __cpp_lib_invoke != 201411L -# error "__cpp_lib_invoke should have the value 201411L in c++2a" +# error "__cpp_lib_invoke should have the value 201411L in c++20" # endif # if TEST_HAS_BUILTIN_IDENTIFIER(__is_aggregate) || TEST_GCC_VER_NEW >= 7001 # ifndef __cpp_lib_is_aggregate -# error "__cpp_lib_is_aggregate should be defined in c++2a" +# error "__cpp_lib_is_aggregate should be defined in c++20" # endif # if __cpp_lib_is_aggregate != 201703L -# error "__cpp_lib_is_aggregate should have the value 201703L in c++2a" +# error "__cpp_lib_is_aggregate should have the value 201703L in c++20" # endif # else # ifdef __cpp_lib_is_aggregate @@ -2116,10 +2116,10 @@ # if TEST_HAS_BUILTIN(__builtin_is_constant_evaluated) || TEST_GCC_VER >= 900 # ifndef __cpp_lib_is_constant_evaluated -# error "__cpp_lib_is_constant_evaluated should be defined in c++2a" +# error "__cpp_lib_is_constant_evaluated should be defined in c++20" # endif # if __cpp_lib_is_constant_evaluated != 201811L -# error "__cpp_lib_is_constant_evaluated should have the value 201811L in c++2a" +# error "__cpp_lib_is_constant_evaluated should have the value 201811L in c++20" # endif # else # ifdef __cpp_lib_is_constant_evaluated @@ -2128,88 +2128,88 @@ # endif # ifndef __cpp_lib_is_final -# error "__cpp_lib_is_final should be defined in c++2a" +# error "__cpp_lib_is_final should be defined in c++20" # endif # if __cpp_lib_is_final != 201402L -# error "__cpp_lib_is_final should have the value 201402L in c++2a" +# error "__cpp_lib_is_final should have the value 201402L in c++20" # endif # ifndef __cpp_lib_is_invocable -# error "__cpp_lib_is_invocable should be defined in c++2a" +# error "__cpp_lib_is_invocable should be defined in c++20" # endif # if __cpp_lib_is_invocable != 201703L -# error "__cpp_lib_is_invocable should have the value 201703L in c++2a" +# error "__cpp_lib_is_invocable should have the value 201703L in c++20" # endif # ifndef __cpp_lib_is_null_pointer -# error "__cpp_lib_is_null_pointer should be defined in c++2a" +# error "__cpp_lib_is_null_pointer should be defined in c++20" # endif # if __cpp_lib_is_null_pointer != 201309L -# error "__cpp_lib_is_null_pointer should have the value 201309L in c++2a" +# error "__cpp_lib_is_null_pointer should have the value 201309L in c++20" # endif # ifndef __cpp_lib_is_swappable -# error "__cpp_lib_is_swappable should be defined in c++2a" +# error "__cpp_lib_is_swappable should be defined in c++20" # endif # if __cpp_lib_is_swappable != 201603L -# error "__cpp_lib_is_swappable should have the value 201603L in c++2a" +# error "__cpp_lib_is_swappable should have the value 201603L in c++20" # endif # ifndef __cpp_lib_launder -# error "__cpp_lib_launder should be defined in c++2a" +# error "__cpp_lib_launder should be defined in c++20" # endif # if __cpp_lib_launder != 201606L -# error "__cpp_lib_launder should have the value 201606L in c++2a" +# error "__cpp_lib_launder should have the value 201606L in c++20" # endif # ifndef __cpp_lib_list_remove_return_type -# error "__cpp_lib_list_remove_return_type should be defined in c++2a" +# error "__cpp_lib_list_remove_return_type should be defined in c++20" # endif # if __cpp_lib_list_remove_return_type != 201806L -# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++2a" +# error "__cpp_lib_list_remove_return_type should have the value 201806L in c++20" # endif # ifndef __cpp_lib_logical_traits -# error "__cpp_lib_logical_traits should be defined in c++2a" +# error "__cpp_lib_logical_traits should be defined in c++20" # endif # if __cpp_lib_logical_traits != 201510L -# error "__cpp_lib_logical_traits should have the value 201510L in c++2a" +# error "__cpp_lib_logical_traits should have the value 201510L in c++20" # endif # ifndef __cpp_lib_make_from_tuple -# error "__cpp_lib_make_from_tuple should be defined in c++2a" +# error "__cpp_lib_make_from_tuple should be defined in c++20" # endif # if __cpp_lib_make_from_tuple != 201606L -# error "__cpp_lib_make_from_tuple should have the value 201606L in c++2a" +# error "__cpp_lib_make_from_tuple should have the value 201606L in c++20" # endif # ifndef __cpp_lib_make_reverse_iterator -# error "__cpp_lib_make_reverse_iterator should be defined in c++2a" +# error "__cpp_lib_make_reverse_iterator should be defined in c++20" # endif # if __cpp_lib_make_reverse_iterator != 201402L -# error "__cpp_lib_make_reverse_iterator should have the value 201402L in c++2a" +# error "__cpp_lib_make_reverse_iterator should have the value 201402L in c++20" # endif # ifndef __cpp_lib_make_unique -# error "__cpp_lib_make_unique should be defined in c++2a" +# error "__cpp_lib_make_unique should be defined in c++20" # endif # if __cpp_lib_make_unique != 201304L -# error "__cpp_lib_make_unique should have the value 201304L in c++2a" +# error "__cpp_lib_make_unique should have the value 201304L in c++20" # endif # ifndef __cpp_lib_map_try_emplace -# error "__cpp_lib_map_try_emplace should be defined in c++2a" +# error "__cpp_lib_map_try_emplace should be defined in c++20" # endif # if __cpp_lib_map_try_emplace != 201411L -# error "__cpp_lib_map_try_emplace should have the value 201411L in c++2a" +# error "__cpp_lib_map_try_emplace should have the value 201411L in c++20" # endif # if defined(__cpp_concepts) && __cpp_concepts >= 201811L # ifndef __cpp_lib_math_constants -# error "__cpp_lib_math_constants should be defined in c++2a" +# error "__cpp_lib_math_constants should be defined in c++20" # endif # if __cpp_lib_math_constants != 201907L -# error "__cpp_lib_math_constants should have the value 201907L in c++2a" +# error "__cpp_lib_math_constants should have the value 201907L in c++20" # endif # else # ifdef __cpp_lib_math_constants @@ -2219,10 +2219,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_math_special_functions -# error "__cpp_lib_math_special_functions should be defined in c++2a" +# error "__cpp_lib_math_special_functions should be defined in c++20" # endif # if __cpp_lib_math_special_functions != 201603L -# error "__cpp_lib_math_special_functions should have the value 201603L in c++2a" +# error "__cpp_lib_math_special_functions should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_math_special_functions @@ -2232,10 +2232,10 @@ # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_memory_resource -# error "__cpp_lib_memory_resource should be defined in c++2a" +# error "__cpp_lib_memory_resource should be defined in c++20" # endif # if __cpp_lib_memory_resource != 201603L -# error "__cpp_lib_memory_resource should have the value 201603L in c++2a" +# error "__cpp_lib_memory_resource should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_memory_resource @@ -2244,46 +2244,46 @@ # endif # ifndef __cpp_lib_node_extract -# error "__cpp_lib_node_extract should be defined in c++2a" +# error "__cpp_lib_node_extract should be defined in c++20" # endif # if __cpp_lib_node_extract != 201606L -# error "__cpp_lib_node_extract should have the value 201606L in c++2a" +# error "__cpp_lib_node_extract should have the value 201606L in c++20" # endif # ifndef __cpp_lib_nonmember_container_access -# error "__cpp_lib_nonmember_container_access should be defined in c++2a" +# error "__cpp_lib_nonmember_container_access should be defined in c++20" # endif # if __cpp_lib_nonmember_container_access != 201411L -# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++2a" +# error "__cpp_lib_nonmember_container_access should have the value 201411L in c++20" # endif # ifndef __cpp_lib_not_fn -# error "__cpp_lib_not_fn should be defined in c++2a" +# error "__cpp_lib_not_fn should be defined in c++20" # endif # if __cpp_lib_not_fn != 201603L -# error "__cpp_lib_not_fn should have the value 201603L in c++2a" +# error "__cpp_lib_not_fn should have the value 201603L in c++20" # endif # ifndef __cpp_lib_null_iterators -# error "__cpp_lib_null_iterators should be defined in c++2a" +# error "__cpp_lib_null_iterators should be defined in c++20" # endif # if __cpp_lib_null_iterators != 201304L -# error "__cpp_lib_null_iterators should have the value 201304L in c++2a" +# error "__cpp_lib_null_iterators should have the value 201304L in c++20" # endif # ifndef __cpp_lib_optional -# error "__cpp_lib_optional should be defined in c++2a" +# error "__cpp_lib_optional should be defined in c++20" # endif # if __cpp_lib_optional != 201606L -# error "__cpp_lib_optional should have the value 201606L in c++2a" +# error "__cpp_lib_optional should have the value 201606L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_parallel_algorithm -# error "__cpp_lib_parallel_algorithm should be defined in c++2a" +# error "__cpp_lib_parallel_algorithm should be defined in c++20" # endif # if __cpp_lib_parallel_algorithm != 201603L -# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++2a" +# error "__cpp_lib_parallel_algorithm should have the value 201603L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_parallel_algorithm @@ -2292,18 +2292,18 @@ # endif # ifndef __cpp_lib_quoted_string_io -# error "__cpp_lib_quoted_string_io should be defined in c++2a" +# error "__cpp_lib_quoted_string_io should be defined in c++20" # endif # if __cpp_lib_quoted_string_io != 201304L -# error "__cpp_lib_quoted_string_io should have the value 201304L in c++2a" +# error "__cpp_lib_quoted_string_io should have the value 201304L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_ranges -# error "__cpp_lib_ranges should be defined in c++2a" +# error "__cpp_lib_ranges should be defined in c++20" # endif # if __cpp_lib_ranges != 201811L -# error "__cpp_lib_ranges should have the value 201811L in c++2a" +# error "__cpp_lib_ranges should have the value 201811L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_ranges @@ -2312,46 +2312,46 @@ # endif # ifndef __cpp_lib_raw_memory_algorithms -# error "__cpp_lib_raw_memory_algorithms should be defined in c++2a" +# error "__cpp_lib_raw_memory_algorithms should be defined in c++20" # endif # if __cpp_lib_raw_memory_algorithms != 201606L -# error "__cpp_lib_raw_memory_algorithms should have the value 201606L in c++2a" +# error "__cpp_lib_raw_memory_algorithms should have the value 201606L in c++20" # endif # ifndef __cpp_lib_result_of_sfinae -# error "__cpp_lib_result_of_sfinae should be defined in c++2a" +# error "__cpp_lib_result_of_sfinae should be defined in c++20" # endif # if __cpp_lib_result_of_sfinae != 201210L -# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++2a" +# error "__cpp_lib_result_of_sfinae should have the value 201210L in c++20" # endif # ifndef __cpp_lib_robust_nonmodifying_seq_ops -# error "__cpp_lib_robust_nonmodifying_seq_ops should be defined in c++2a" +# error "__cpp_lib_robust_nonmodifying_seq_ops should be defined in c++20" # endif # if __cpp_lib_robust_nonmodifying_seq_ops != 201304L -# error "__cpp_lib_robust_nonmodifying_seq_ops should have the value 201304L in c++2a" +# error "__cpp_lib_robust_nonmodifying_seq_ops should have the value 201304L in c++20" # endif # ifndef __cpp_lib_sample -# error "__cpp_lib_sample should be defined in c++2a" +# error "__cpp_lib_sample should be defined in c++20" # endif # if __cpp_lib_sample != 201603L -# error "__cpp_lib_sample should have the value 201603L in c++2a" +# error "__cpp_lib_sample should have the value 201603L in c++20" # endif # ifndef __cpp_lib_scoped_lock -# error "__cpp_lib_scoped_lock should be defined in c++2a" +# error "__cpp_lib_scoped_lock should be defined in c++20" # endif # if __cpp_lib_scoped_lock != 201703L -# error "__cpp_lib_scoped_lock should have the value 201703L in c++2a" +# error "__cpp_lib_scoped_lock should have the value 201703L in c++20" # endif # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_shared_mutex -# error "__cpp_lib_shared_mutex should be defined in c++2a" +# error "__cpp_lib_shared_mutex should be defined in c++20" # endif # if __cpp_lib_shared_mutex != 201505L -# error "__cpp_lib_shared_mutex should have the value 201505L in c++2a" +# error "__cpp_lib_shared_mutex should have the value 201505L in c++20" # endif # else # ifdef __cpp_lib_shared_mutex @@ -2360,25 +2360,25 @@ # endif # ifndef __cpp_lib_shared_ptr_arrays -# error "__cpp_lib_shared_ptr_arrays should be defined in c++2a" +# error "__cpp_lib_shared_ptr_arrays should be defined in c++20" # endif # if __cpp_lib_shared_ptr_arrays != 201611L -# error "__cpp_lib_shared_ptr_arrays should have the value 201611L in c++2a" +# error "__cpp_lib_shared_ptr_arrays should have the value 201611L in c++20" # endif # ifndef __cpp_lib_shared_ptr_weak_type -# error "__cpp_lib_shared_ptr_weak_type should be defined in c++2a" +# error "__cpp_lib_shared_ptr_weak_type should be defined in c++20" # endif # if __cpp_lib_shared_ptr_weak_type != 201606L -# error "__cpp_lib_shared_ptr_weak_type should have the value 201606L in c++2a" +# error "__cpp_lib_shared_ptr_weak_type should have the value 201606L in c++20" # endif # if !defined(_LIBCPP_HAS_NO_THREADS) # ifndef __cpp_lib_shared_timed_mutex -# error "__cpp_lib_shared_timed_mutex should be defined in c++2a" +# error "__cpp_lib_shared_timed_mutex should be defined in c++20" # endif # if __cpp_lib_shared_timed_mutex != 201402L -# error "__cpp_lib_shared_timed_mutex should have the value 201402L in c++2a" +# error "__cpp_lib_shared_timed_mutex should have the value 201402L in c++20" # endif # else # ifdef __cpp_lib_shared_timed_mutex @@ -2387,32 +2387,32 @@ # endif # ifndef __cpp_lib_span -# error "__cpp_lib_span should be defined in c++2a" +# error "__cpp_lib_span should be defined in c++20" # endif # if __cpp_lib_span != 202002L -# error "__cpp_lib_span should have the value 202002L in c++2a" +# error "__cpp_lib_span should have the value 202002L in c++20" # endif # ifndef __cpp_lib_string_udls -# error "__cpp_lib_string_udls should be defined in c++2a" +# error "__cpp_lib_string_udls should be defined in c++20" # endif # if __cpp_lib_string_udls != 201304L -# error "__cpp_lib_string_udls should have the value 201304L in c++2a" +# error "__cpp_lib_string_udls should have the value 201304L in c++20" # endif # ifndef __cpp_lib_string_view -# error "__cpp_lib_string_view should be defined in c++2a" +# error "__cpp_lib_string_view should be defined in c++20" # endif # if __cpp_lib_string_view != 201606L -# error "__cpp_lib_string_view should have the value 201606L in c++2a" +# error "__cpp_lib_string_view should have the value 201606L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_three_way_comparison -# error "__cpp_lib_three_way_comparison should be defined in c++2a" +# error "__cpp_lib_three_way_comparison should be defined in c++20" # endif # if __cpp_lib_three_way_comparison != 201711L -# error "__cpp_lib_three_way_comparison should have the value 201711L in c++2a" +# error "__cpp_lib_three_way_comparison should have the value 201711L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_three_way_comparison @@ -2421,18 +2421,18 @@ # endif # ifndef __cpp_lib_to_array -# error "__cpp_lib_to_array should be defined in c++2a" +# error "__cpp_lib_to_array should be defined in c++20" # endif # if __cpp_lib_to_array != 201907L -# error "__cpp_lib_to_array should have the value 201907L in c++2a" +# error "__cpp_lib_to_array should have the value 201907L in c++20" # endif # if !defined(_LIBCPP_VERSION) # ifndef __cpp_lib_to_chars -# error "__cpp_lib_to_chars should be defined in c++2a" +# error "__cpp_lib_to_chars should be defined in c++20" # endif # if __cpp_lib_to_chars != 201611L -# error "__cpp_lib_to_chars should have the value 201611L in c++2a" +# error "__cpp_lib_to_chars should have the value 201611L in c++20" # endif # else // _LIBCPP_VERSION # ifdef __cpp_lib_to_chars @@ -2441,66 +2441,66 @@ # endif # ifndef __cpp_lib_transformation_trait_aliases -# error "__cpp_lib_transformation_trait_aliases should be defined in c++2a" +# error "__cpp_lib_transformation_trait_aliases should be defined in c++20" # endif # if __cpp_lib_transformation_trait_aliases != 201304L -# error "__cpp_lib_transformation_trait_aliases should have the value 201304L in c++2a" +# error "__cpp_lib_transformation_trait_aliases should have the value 201304L in c++20" # endif # ifndef __cpp_lib_transparent_operators -# error "__cpp_lib_transparent_operators should be defined in c++2a" +# error "__cpp_lib_transparent_operators should be defined in c++20" # endif # if __cpp_lib_transparent_operators != 201510L -# error "__cpp_lib_transparent_operators should have the value 201510L in c++2a" +# error "__cpp_lib_transparent_operators should have the value 201510L in c++20" # endif # ifndef __cpp_lib_tuple_element_t -# error "__cpp_lib_tuple_element_t should be defined in c++2a" +# error "__cpp_lib_tuple_element_t should be defined in c++20" # endif # if __cpp_lib_tuple_element_t != 201402L -# error "__cpp_lib_tuple_element_t should have the value 201402L in c++2a" +# error "__cpp_lib_tuple_element_t should have the value 201402L in c++20" # endif # ifndef __cpp_lib_tuples_by_type -# error "__cpp_lib_tuples_by_type should be defined in c++2a" +# error "__cpp_lib_tuples_by_type should be defined in c++20" # endif # if __cpp_lib_tuples_by_type != 201304L -# error "__cpp_lib_tuples_by_type should have the value 201304L in c++2a" +# error "__cpp_lib_tuples_by_type should have the value 201304L in c++20" # endif # ifndef __cpp_lib_type_trait_variable_templates -# error "__cpp_lib_type_trait_variable_templates should be defined in c++2a" +# error "__cpp_lib_type_trait_variable_templates should be defined in c++20" # endif # if __cpp_lib_type_trait_variable_templates != 201510L -# error "__cpp_lib_type_trait_variable_templates should have the value 201510L in c++2a" +# error "__cpp_lib_type_trait_variable_templates should have the value 201510L in c++20" # endif # ifndef __cpp_lib_uncaught_exceptions -# error "__cpp_lib_uncaught_exceptions should be defined in c++2a" +# error "__cpp_lib_uncaught_exceptions should be defined in c++20" # endif # if __cpp_lib_uncaught_exceptions != 201411L -# error "__cpp_lib_uncaught_exceptions should have the value 201411L in c++2a" +# error "__cpp_lib_uncaught_exceptions should have the value 201411L in c++20" # endif # ifndef __cpp_lib_unordered_map_try_emplace -# error "__cpp_lib_unordered_map_try_emplace should be defined in c++2a" +# error "__cpp_lib_unordered_map_try_emplace should be defined in c++20" # endif # if __cpp_lib_unordered_map_try_emplace != 201411L -# error "__cpp_lib_unordered_map_try_emplace should have the value 201411L in c++2a" +# error "__cpp_lib_unordered_map_try_emplace should have the value 201411L in c++20" # endif # ifndef __cpp_lib_variant -# error "__cpp_lib_variant should be defined in c++2a" +# error "__cpp_lib_variant should be defined in c++20" # endif # if __cpp_lib_variant != 201606L -# error "__cpp_lib_variant should have the value 201606L in c++2a" +# error "__cpp_lib_variant should have the value 201606L in c++20" # endif # ifndef __cpp_lib_void_t -# error "__cpp_lib_void_t should be defined in c++2a" +# error "__cpp_lib_void_t should be defined in c++20" # endif # if __cpp_lib_void_t != 201411L -# error "__cpp_lib_void_t should have the value 201411L in c++2a" +# error "__cpp_lib_void_t should have the value 201411L in c++20" # endif #endif // TEST_STD_VER > 17 diff --git a/libcxx/test/support/test_macros.h b/libcxx/test/support/test_macros.h --- a/libcxx/test/support/test_macros.h +++ b/libcxx/test/support/test_macros.h @@ -101,6 +101,8 @@ # define TEST_STD_VER 14 #elif __cplusplus <= 201703L # define TEST_STD_VER 17 +#elif __cplusplus <= 202002L +# define TEST_STD_VER 20 #else # define TEST_STD_VER 99 // greater than current standard // This is deliberately different than _LIBCPP_STD_VER to discourage matching them up. diff --git a/libcxx/utils/ci/buildkite-pipeline.yml b/libcxx/utils/ci/buildkite-pipeline.yml --- a/libcxx/utils/ci/buildkite-pipeline.yml +++ b/libcxx/utils/ci/buildkite-pipeline.yml @@ -64,7 +64,7 @@ limit: 2 - label: "C++20" - command: "libcxx/utils/ci/run-buildbot generic-cxx2a" + command: "libcxx/utils/ci/run-buildbot generic-cxx20" artifact_paths: - "**/test-results.xml" - "**/*.abilist" @@ -186,7 +186,7 @@ limit: 2 - label: "MacOS C++20" - command: "libcxx/utils/ci/run-buildbot generic-cxx2a" + command: "libcxx/utils/ci/run-buildbot generic-cxx20" artifact_paths: - "**/test-results.xml" - "**/*.abilist" diff --git a/libcxx/utils/ci/run-buildbot b/libcxx/utils/ci/run-buildbot --- a/libcxx/utils/ci/run-buildbot +++ b/libcxx/utils/ci/run-buildbot @@ -137,11 +137,11 @@ check-cxx-cxxabi check-abi-list ;; -generic-cxx2a) +generic-cxx20) export CC=clang export CXX=clang++ clean - generate-cmake -C "${MONOREPO_ROOT}/libcxx/cmake/caches/Generic-cxx2a.cmake" + generate-cmake -C "${MONOREPO_ROOT}/libcxx/cmake/caches/Generic-cxx20.cmake" check-cxx-cxxabi check-abi-list ;; diff --git a/libcxx/utils/generate_feature_test_macro_components.py b/libcxx/utils/generate_feature_test_macro_components.py --- a/libcxx/utils/generate_feature_test_macro_components.py +++ b/libcxx/utils/generate_feature_test_macro_components.py @@ -289,7 +289,7 @@ "headers": ["unordered_map"], }, { "name": "__cpp_lib_array_constexpr", - "values": { "c++17": int(201603), "c++2a": int(201811) }, + "values": { "c++17": int(201603), "c++20": int(201811) }, "headers": ["iterator", "array"], }, { "name": "__cpp_lib_nonmember_container_access", @@ -328,22 +328,22 @@ "values": { "c++17": int(201703) }, "headers": ["mutex"], }, - # C++2a + # C++20 { "name": "__cpp_lib_char8_t", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["atomic", "filesystem", "istream", "limits", "locale", "ostream", "string", "string_view"], "depends": "defined(__cpp_char8_t)", "internal_depends": "!defined(_LIBCPP_NO_HAS_CHAR8_T)", }, { "name": "__cpp_lib_erase_if", - "values": { "c++2a": int(202002) }, + "values": { "c++20": int(202002) }, "headers": ["string", "deque", "forward_list", "list", "vector", "map", "set", "unordered_map", "unordered_set"] }, { "name": "__cpp_lib_destroying_delete", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["new"], "depends": "TEST_STD_VER > 17" @@ -355,136 +355,136 @@ " && __cpp_impl_destroying_delete >= 201806L", }, { "name": "__cpp_lib_three_way_comparison", - "values": { "c++2a": int(201711) }, + "values": { "c++20": int(201711) }, "headers": ["compare"], "unimplemented": True, }, { "name": "__cpp_lib_concepts", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["concepts"], "unimplemented": True, }, { "name": "__cpp_lib_constexpr_swap_algorithms", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["algorithm"], "unimplemented": True, }, { "name": "__cpp_lib_constexpr_misc", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["array", "functional", "iterator", "string_view", "tuple", "utility"], "unimplemented": True, }, { "name": "__cpp_lib_constexpr_numeric", - "values": { "c++2a": int(201911) }, + "values": { "c++20": int(201911) }, "headers": ["numeric"], }, { "name": "__cpp_lib_bind_front", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["functional"], "unimplemented": True, }, { "name": "__cpp_lib_is_constant_evaluated", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["type_traits"], "depends": "TEST_HAS_BUILTIN(__builtin_is_constant_evaluated) || TEST_GCC_VER >= 900", "internal_depends": "!defined(_LIBCPP_HAS_NO_BUILTIN_IS_CONSTANT_EVALUATED)", }, { "name": "__cpp_lib_list_remove_return_type", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["forward_list", "list"], }, { "name": "__cpp_lib_generic_unordered_lookup", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["unordered_map", "unordered_set"], }, { "name": "__cpp_lib_ranges", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["algorithm", "functional", "iterator", "memory", "ranges"], "unimplemented": True, }, { "name": "__cpp_lib_bit_cast", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["bit"], "unimplemented": True, }, { "name": "__cpp_lib_atomic_ref", - "values": { "c++2a": int(201806) }, + "values": { "c++20": int(201806) }, "headers": ["atomic"], "unimplemented": True, "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_int_pow2", - "values": { "c++2a": int(202002) }, + "values": { "c++20": int(202002) }, "headers": ["bit"], }, { "name": "__cpp_lib_interpolate", - "values": { "c++2a": int(201902) }, + "values": { "c++20": int(201902) }, "headers": ["numeric"], }, { "name": "__cpp_lib_endian", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["bit"], }, { "name": "__cpp_lib_to_array", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["array"], }, { "name": "__cpp_lib_span", - "values": { "c++2a": int(202002) }, + "values": { "c++20": int(202002) }, "headers": ["span"], }, { "name": "__cpp_lib_math_constants", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["numbers"], "depends": "defined(__cpp_concepts) && __cpp_concepts >= 201811L", "internal_depends": "defined(__cpp_concepts) && __cpp_concepts >= 201811L", }, { "name": "__cpp_lib_constexpr_utility", - "values": { "c++2a": int(201811) }, + "values": { "c++20": int(201811) }, "headers": ["utility"], }, { "name": "__cpp_lib_atomic_flag_test", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["atomic"], "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_atomic_lock_free_type_aliases", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["atomic"], "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_atomic_wait", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["atomic"], "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_atomic_float", - "values": { "c++2a": int(201711) }, + "values": { "c++20": int(201711) }, "headers": ["atomic"], "unimplemented": True, "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_atomic_shared_ptr", - "values": { "c++2a": int(201711) }, + "values": { "c++20": int(201711) }, "headers": ["atomic"], "unimplemented": True, "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_atomic_value_initialization", - "values": { "c++2a": int(201911) }, + "values": { "c++20": int(201911) }, "headers": ["atomic", "memory"], "unimplemented": True, "depends": "!defined(_LIBCPP_HAS_NO_THREADS)", "internal_depends": "!defined(_LIBCPP_HAS_NO_THREADS)", }, { "name": "__cpp_lib_constexpr_dynamic_alloc", - "values": { "c++2a": int(201907) }, + "values": { "c++20": int(201907) }, "headers": ["memory"] }, ]], key=lambda tc: tc["name"]) @@ -507,7 +507,7 @@ } def get_std_dialects(): - std_dialects = ['c++14', 'c++17', 'c++2a'] + std_dialects = ['c++14', 'c++17', 'c++20'] return list(std_dialects) def get_first_std(d): @@ -657,7 +657,7 @@ #endif #if _LIBCPP_STD_VER > 17 -{cxx2a_macros} +{cxx20_macros} #endif #endif // _LIBCPP_VERSIONH @@ -667,7 +667,7 @@ synopsis=produce_version_synopsis().strip(), cxx14_macros=produce_macros_definition_for_std('c++14').strip(), cxx17_macros=produce_macros_definition_for_std('c++17').strip(), - cxx2a_macros=produce_macros_definition_for_std('c++2a').strip()) + cxx20_macros=produce_macros_definition_for_std('c++20').strip()) version_header_path = os.path.join(include_path, 'version') with open(version_header_path, 'w', newline='\n') as f: @@ -799,11 +799,11 @@ {cxx17_tests} -#elif TEST_STD_VER > 17 +#elif TEST_STD_VER == 20 -{cxx2a_tests} +{cxx20_tests} -#endif // TEST_STD_VER > 17 +#endif // TEST_STD_VER == 20 int main(int, char**) {{ return 0; }} """.format(script_name=script_name, @@ -813,7 +813,7 @@ cxx11_tests=generate_std_test(test_list, 'c++11').strip(), cxx14_tests=generate_std_test(test_list, 'c++14').strip(), cxx17_tests=generate_std_test(test_list, 'c++17').strip(), - cxx2a_tests=generate_std_test(test_list, 'c++2a').strip()) + cxx20_tests=generate_std_test(test_list, 'c++20').strip()) test_name = "{header}.version.pass.cpp".format(header=h) out_path = os.path.join(macro_test_path, test_name) with open(out_path, 'w', newline='\n') as f: