From db7fa111abe868b217443bcaafc47de53bdb0e48 Mon Sep 17 00:00:00 2001 From: Marshall Clow Date: Mon, 14 Nov 2016 18:22:19 +0000 Subject: [PATCH] Fixes for LWG 2598, 2686, 2739, 2742, 2747, and 2759, which were adopted last week in Issaquah git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@286858 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/algorithm | 2 +- include/chrono | 3 +- include/memory | 3 +- include/numeric | 4 + include/string | 20 +++ include/string_view | 5 +- include/system_error | 12 ++ include/type_traits | 4 + .../syserr.hash/error_condition.pass.cpp | 44 +++++ .../numeric.ops.gcd/gcd.bool1.fail.cpp | 25 +++ .../numeric.ops.gcd/gcd.bool2.fail.cpp | 25 +++ .../numeric.ops.gcd/gcd.bool3.fail.cpp | 25 +++ .../numeric.ops.gcd/gcd.bool4.fail.cpp | 25 +++ .../gcd.not_integral1.fail.cpp | 3 +- .../gcd.not_integral2.fail.cpp | 3 +- .../numeric.ops.lcm/lcm.bool1.fail.cpp | 25 +++ .../numeric.ops.lcm/lcm.bool2.fail.cpp | 25 +++ .../numeric.ops.lcm/lcm.bool3.fail.cpp | 25 +++ .../numeric.ops.lcm/lcm.bool4.fail.cpp | 25 +++ .../lcm.not_integral1.fail.cpp | 3 +- .../lcm.not_integral2.fail.cpp | 3 +- .../string.cons/T_size_size.pass.cpp | 166 ++++++++++++++++++ .../addressof.temp.fail.cpp | 20 +++ .../op_-duration.pass.cpp | 13 ++ www/cxx1z_status.html | 12 +- 25 files changed, 504 insertions(+), 16 deletions(-) create mode 100644 test/std/diagnostics/syserr/syserr.hash/error_condition.pass.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool1.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool2.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool3.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool4.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool1.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool2.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool3.fail.cpp create mode 100644 test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool4.fail.cpp create mode 100644 test/std/strings/basic.string/string.cons/T_size_size.pass.cpp create mode 100644 test/std/utilities/memory/specialized.algorithms/specialized.addressof/addressof.temp.fail.cpp diff --git a/include/algorithm b/include/algorithm index 3bafd3df7..c5a5d0ad8 100644 --- a/include/algorithm +++ b/include/algorithm @@ -877,7 +877,7 @@ for_each(_InputIterator __first, _InputIterator __last, _Function __f) { for (; __first != __last; ++__first) __f(*__first); - return _LIBCPP_EXPLICIT_MOVE(__f); // explicitly moved for (emulated) C++03 + return __f; } // find diff --git a/include/chrono b/include/chrono index 68484e982..3cef9ed44 100644 --- a/include/chrono +++ b/include/chrono @@ -1026,7 +1026,8 @@ inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> operator-(const time_point<_Clock, _Duration1>& __lhs, const duration<_Rep2, _Period2>& __rhs) { - return __lhs + (-__rhs); + typedef time_point<_Clock, typename common_type<_Duration1, duration<_Rep2, _Period2> >::type> _Ret; + return _Ret(__lhs.time_since_epoch() -__rhs); } // duration operator-(time_point x, time_point y); diff --git a/include/memory b/include/memory index 69068f34d..daa17403e 100644 --- a/include/memory +++ b/include/memory @@ -164,6 +164,7 @@ template pair get_temporary_buffer(ptrdiff_t n) noexcept template void return_temporary_buffer(T* p) noexcept; template T* addressof(T& r) noexcept; +template T* addressof(const T&& r) noexcept = delete; template ForwardIterator @@ -675,7 +676,7 @@ _ValueType __libcpp_acquire_load(_ValueType const* __value) { #endif } -// addressof moved to <__functional_base> +// addressof moved to template class allocator; diff --git a/include/numeric b/include/numeric index 1643d6400..e00580854 100644 --- a/include/numeric +++ b/include/numeric @@ -230,6 +230,8 @@ common_type_t<_Tp,_Up> gcd(_Tp __m, _Up __n) { static_assert((is_integral<_Tp>::value && is_integral<_Up>::value), "Arguments to gcd must be integer types"); + static_assert((!is_same::type, bool>::value), "First argument to gcd cannot be bool" ); + static_assert((!is_same::type, bool>::value), "Second argument to gcd cannot be bool" ); using _Rp = common_type_t<_Tp,_Up>; using _Wp = make_unsigned_t<_Rp>; return static_cast<_Rp>(__gcd(static_cast<_Wp>(__abs<_Tp>()(__m)), @@ -242,6 +244,8 @@ common_type_t<_Tp,_Up> lcm(_Tp __m, _Up __n) { static_assert((is_integral<_Tp>::value && is_integral<_Up>::value), "Arguments to lcm must be integer types"); + static_assert((!is_same::type, bool>::value), "First argument to lcm cannot be bool" ); + static_assert((!is_same::type, bool>::value), "Second argument to lcm cannot be bool" ); if (__m == 0 || __n == 0) return 0; diff --git a/include/string b/include/string index 347cb6813..840fd0098 100644 --- a/include/string +++ b/include/string @@ -102,6 +102,8 @@ public: const allocator_type& a = allocator_type()); basic_string(const basic_string& str, size_type pos, size_type n, const Allocator& a = Allocator()); + template + basic_string(const T& t, size_type pos, size_type n, const Allocator& a = Allocator()); // C++17 explicit basic_string(const basic_string_view sv, const Allocator& a = Allocator()); basic_string(const value_type* s, const allocator_type& a = allocator_type()); basic_string(const value_type* s, size_type n, const allocator_type& a = allocator_type()); @@ -789,6 +791,10 @@ public: _LIBCPP_INLINE_VISIBILITY basic_string(const basic_string& __str, size_type __pos, const allocator_type& __a = allocator_type()); + template + basic_string(const _Tp& __t, size_type __pos, size_type __n, + const allocator_type& __a = allocator_type(), + typename enable_if<__can_be_converted_to_string_view<_CharT, _Traits, _Tp>::value, void>::type* = 0); _LIBCPP_INLINE_VISIBILITY explicit basic_string(__self_view __sv); _LIBCPP_INLINE_VISIBILITY @@ -1716,6 +1722,20 @@ basic_string<_CharT, _Traits, _Allocator>::basic_string(const basic_string& __st #endif } +template +template +basic_string<_CharT, _Traits, _Allocator>::basic_string( + const _Tp& __t, size_type __pos, size_type __n, const allocator_type& __a, + typename enable_if<__can_be_converted_to_string_view<_CharT, _Traits, _Tp>::value, void>::type *) + : __r_(__a) +{ + __self_view __sv = __self_view(__t).substr(__pos, __n); + __init(__sv.data(), __sv.size()); +#if _LIBCPP_DEBUG_LEVEL >= 2 + __get_db()->__insert_c(this); +#endif +} + template inline _LIBCPP_INLINE_VISIBILITY basic_string<_CharT, _Traits, _Allocator>::basic_string(__self_view __sv) diff --git a/include/string_view b/include/string_view index baba46445..60c0ad00f 100644 --- a/include/string_view +++ b/include/string_view @@ -164,7 +164,6 @@ namespace std { #include <__config> #include <__string> -#include #include #include <__debug> @@ -320,8 +319,8 @@ public: { if (__pos > size()) __throw_out_of_range("string_view::copy"); - size_type __rlen = _VSTD::min( __n, size() - __pos ); - copy_n(begin() + __pos, __rlen, __s ); + size_type __rlen = _VSTD::min(__n, size() - __pos); + _Traits::copy(__s, data() + __pos, __rlen); return __rlen; } diff --git a/include/system_error b/include/system_error index faaeaa06d..c7e73d4ab 100644 --- a/include/system_error +++ b/include/system_error @@ -219,6 +219,7 @@ bool operator!=(const error_condition& lhs, const error_code& rhs) noexcept; bool operator!=(const error_condition& lhs, const error_condition& rhs) noexcept; template <> struct hash; +template <> struct hash; } // std @@ -629,6 +630,17 @@ struct _LIBCPP_TYPE_VIS_ONLY hash } }; +template <> +struct _LIBCPP_TYPE_VIS_ONLY hash + : public unary_function +{ + _LIBCPP_INLINE_VISIBILITY + size_t operator()(const error_condition& __ec) const _NOEXCEPT + { + return static_cast(__ec.value()); + } +}; + // system_error class _LIBCPP_TYPE_VIS system_error diff --git a/include/type_traits b/include/type_traits index 4d24886ee..fbfc9d337 100644 --- a/include/type_traits +++ b/include/type_traits @@ -488,6 +488,10 @@ addressof(__unsafe_unretained _Tp& __x) _NOEXCEPT } #endif +#if !defined(_LIBCPP_HAS_NO_RVALUE_REFERENCES) && !defined(_LIBCPP_HAS_NO_DELETED_FUNCTIONS) +template _Tp* addressof(const _Tp&&) noexcept = delete; +#endif + struct __two {char __lx[2];}; // helper class: diff --git a/test/std/diagnostics/syserr/syserr.hash/error_condition.pass.cpp b/test/std/diagnostics/syserr/syserr.hash/error_condition.pass.cpp new file mode 100644 index 000000000..eb3c06f2e --- /dev/null +++ b/test/std/diagnostics/syserr/syserr.hash/error_condition.pass.cpp @@ -0,0 +1,44 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// + +// template +// struct hash +// : public unary_function +// { +// size_t operator()(T val) const; +// }; + +#include +#include +#include + +#include "test_macros.h" + +void +test(int i) +{ + typedef std::error_condition T; + typedef std::hash H; + static_assert((std::is_same::value), "" ); + static_assert((std::is_same::value), "" ); + H h; + T ec(i, std::system_category()); + const std::size_t result = h(ec); + LIBCPP_ASSERT(result == i); + ((void)result); // Prevent unused warning +} + +int main() +{ + test(0); + test(2); + test(10); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool1.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool1.fail.cpp new file mode 100644 index 000000000..cc821e1d8 --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool1.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::gcd(false, 4); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool2.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool2.fail.cpp new file mode 100644 index 000000000..1e5ee2565 --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool2.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::gcd(2, true); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool3.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool3.fail.cpp new file mode 100644 index 000000000..76d1030d8 --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool3.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::gcd(false, 4); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool4.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool4.fail.cpp new file mode 100644 index 000000000..2c685c94b --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.bool4.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::gcd(2, true); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral1.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral1.fail.cpp index 585e40bac..0707eca1e 100644 --- a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral1.fail.cpp +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral1.fail.cpp @@ -13,7 +13,8 @@ // template // constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) -// Remarks: If either M or N is not an integer type, the program is ill-formed. +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. #include diff --git a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral2.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral2.fail.cpp index 7a2709aa9..113dd3d42 100644 --- a/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral2.fail.cpp +++ b/test/std/numerics/numeric.ops/numeric.ops.gcd/gcd.not_integral2.fail.cpp @@ -13,7 +13,8 @@ // template // constexpr common_type_t<_M,_N> gcd(_M __m, _N __n) -// Remarks: If either M or N is not an integer type, the program is ill-formed. +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. #include diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool1.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool1.fail.cpp new file mode 100644 index 000000000..79c5f62db --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool1.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::lcm(false, 4); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool2.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool2.fail.cpp new file mode 100644 index 000000000..c34efea17 --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool2.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::lcm(2, true); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool3.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool3.fail.cpp new file mode 100644 index 000000000..8cb38eb2a --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool3.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::lcm(false, 4); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool4.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool4.fail.cpp new file mode 100644 index 000000000..464eb03be --- /dev/null +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.bool4.fail.cpp @@ -0,0 +1,25 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// UNSUPPORTED: c++98, c++03, c++11, c++14 +// + +// template +// constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) + +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. + +#include + + +int main() +{ + std::lcm(2, true); +} diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral1.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral1.fail.cpp index 1e69b25b1..ce6bcf88b 100644 --- a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral1.fail.cpp +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral1.fail.cpp @@ -13,7 +13,8 @@ // template // constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) -// Remarks: If either M or N is not an integer type, the program is ill-formed. +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. #include diff --git a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral2.fail.cpp b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral2.fail.cpp index d58d903a2..a9100989b 100644 --- a/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral2.fail.cpp +++ b/test/std/numerics/numeric.ops/numeric.ops.lcm/lcm.not_integral2.fail.cpp @@ -13,7 +13,8 @@ // template // constexpr common_type_t<_M,_N> lcm(_M __m, _N __n) -// Remarks: If either M or N is not an integer type, the program is ill-formed. +// Remarks: If either M or N is not an integer type, +// or if either is (a possibly cv-qualified) bool, the program is ill-formed. #include diff --git a/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp b/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp new file mode 100644 index 000000000..edc0f124f --- /dev/null +++ b/test/std/strings/basic.string/string.cons/T_size_size.pass.cpp @@ -0,0 +1,166 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// + +// template +// basic_string(const _Tp& __t, size_type __pos, size_type __n, +// const allocator_type& __a = allocator_type()); +// +// Mostly we're testing string_view here + +#include +#include +#include +#include +#include + +#include "test_macros.h" +#include "test_allocator.h" +#include "min_allocator.h" + +template +void +test(SV sv, unsigned pos, unsigned n) +{ + typedef typename S::traits_type T; + typedef typename S::allocator_type A; + try + { + S s2(sv, pos, n); + LIBCPP_ASSERT(s2.__invariants()); + assert(pos <= sv.size()); + unsigned rlen = std::min(sv.size() - pos, n); + assert(s2.size() == rlen); + assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); + assert(s2.get_allocator() == A()); + assert(s2.capacity() >= s2.size()); + } + catch (std::out_of_range&) + { + assert(pos > sv.size()); + } +} + +template +void +test(SV sv, unsigned pos, unsigned n, const typename S::allocator_type& a) +{ + typedef typename S::traits_type T; + typedef typename S::allocator_type A; + try + { + S s2(sv, pos, n, a); + LIBCPP_ASSERT(s2.__invariants()); + assert(pos <= sv.size()); + unsigned rlen = std::min(sv.size() - pos, n); + assert(s2.size() == rlen); + assert(T::compare(s2.data(), sv.data() + pos, rlen) == 0); + assert(s2.get_allocator() == a); + assert(s2.capacity() >= s2.size()); + } + catch (std::out_of_range&) + { + assert(pos > sv.size()); + } +} + +int main() +{ + + { + typedef test_allocator A; + typedef std::basic_string_view > SV; + typedef std::basic_string , A> S; + + test(SV(), 0, 0); + test(SV(), 0, 1); + test(SV(), 1, 0); + test(SV(), 1, 1); + test(SV(), 1, 2); + test(SV("1"), 0, 0); + test(SV("1"), 0, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); + + test(SV(), 0, 0, A(4)); + test(SV(), 0, 1, A(4)); + test(SV(), 1, 0, A(4)); + test(SV(), 1, 1, A(4)); + test(SV(), 1, 2, A(4)); + test(SV("1"), 0, 0, A(6)); + test(SV("1"), 0, 1, A(6)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A(8)); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A(8)); + } + +#if TEST_STD_VER >= 11 + { + typedef min_allocator A; + typedef std::basic_string_view > SV; + typedef std::basic_string , A> S; + + test(SV(), 0, 0); + test(SV(), 0, 1); + test(SV(), 1, 0); + test(SV(), 1, 1); + test(SV(), 1, 2); + test(SV("1"), 0, 0); + test(SV("1"), 0, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100); + + test(SV(), 0, 0, A()); + test(SV(), 0, 1, A()); + test(SV(), 1, 0, A()); + test(SV(), 1, 1, A()); + test(SV(), 1, 2, A()); + test(SV("1"), 0, 0, A()); + test(SV("1"), 0, 1, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 0, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 1, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 10, A()); + test(SV("1234567890123456789012345678901234567890123456789012345678901234567890"), 50, 100, A()); + } +#endif + { + typedef std::string S; + typedef std::string_view SV; + S s = "ABCD"; + SV sv = "EFGH"; + char arr[] = "IJKL"; + + S s1("CDEF", 4); // calls ctor(const char *, len) + assert(s1 == "CDEF"); + + S s2("QRST", 0, 3); // calls ctor(string("QRST", pos, len) + assert(s2 == "QRS"); + + S s3(sv, 0, std::string::npos); // calls ctor(T, pos, npos) + assert(s3 == sv); + + S s4(sv, 0, 3); // calls ctor(T, pos, len) + assert(s4 == "EFG"); + + S s5(arr, 0, 2); // calls ctor(const char *, len) + assert(s5 == "IJ"); + + S s6(arr, 0); // calls ctor(const char *, len) + assert(s6 == ""); + + S s7(s.data(), 2); // calls ctor(const char *, len) + assert(s7 == "AB"); + } +} diff --git a/test/std/utilities/memory/specialized.algorithms/specialized.addressof/addressof.temp.fail.cpp b/test/std/utilities/memory/specialized.algorithms/specialized.addressof/addressof.temp.fail.cpp new file mode 100644 index 000000000..8bac4480e --- /dev/null +++ b/test/std/utilities/memory/specialized.algorithms/specialized.addressof/addressof.temp.fail.cpp @@ -0,0 +1,20 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// + +// template T* addressof(T&& r) = delete; + +#include +#include + +int main() +{ + const int *p = std::addressof(0); +} diff --git a/test/std/utilities/time/time.point/time.point.nonmember/op_-duration.pass.cpp b/test/std/utilities/time/time.point/time.point.nonmember/op_-duration.pass.cpp index 4c681fa32..978f09d66 100644 --- a/test/std/utilities/time/time.point/time.point.nonmember/op_-duration.pass.cpp +++ b/test/std/utilities/time/time.point/time.point.nonmember/op_-duration.pass.cpp @@ -20,6 +20,17 @@ #include "test_macros.h" +template +void test2739() // LWG2739 +{ + typedef std::chrono::time_point TimePoint; + typedef std::chrono::duration Dur; + const Dur d(5); + TimePoint t0 = std::chrono::system_clock::from_time_t(200); + TimePoint t1 = t0 - d; + assert(t1 < t0); +} + int main() { typedef std::chrono::system_clock Clock; @@ -37,4 +48,6 @@ int main() static_assert(t2.time_since_epoch() == Duration2(2995), ""); } #endif + test2739(); + test2739(); } diff --git a/www/cxx1z_status.html b/www/cxx1z_status.html index c32b89d3c..f8e90bb5d 100644 --- a/www/cxx1z_status.html +++ b/www/cxx1z_status.html @@ -367,7 +367,7 @@ 2588[fund.ts.v2] "Convertible to bool" requirement in conjunction and disjunctionIssaquah 2589match_results can't satisfy the requirements of a containerIssaquahComplete 2591std::function's member template target() should not lead to undefined behaviourIssaquah - 2598addressof works on temporariesIssaquahPatch ready + 2598addressof works on temporariesIssaquahComplete 2664operator/ (and other append) semantics not useful if argument has rootIssaquahComplete 2665remove_filename() post condition is incorrectIssaquahSee Below 2672Should is_empty use error_code in its specification?IssaquahComplete @@ -388,12 +388,12 @@ 2735std::abs(short), std::abs(signed char) and others should return int instead of double in order to be compatible with C++98 and CIssaquah 2736nullopt_t insufficiently constrainedIssaquah 2738is_constructible with void typesIssaquahComplete - 2739Issue with time_point non-member subtraction with an unsigned durationIssaquahPatch Ready + 2739Issue with time_point non-member subtraction with an unsigned durationIssaquahComplete 2740constexpr optional::operator->IssaquahComplete - 2742Inconsistent string interface taking string_viewIssaquahPatch Ready + 2742Inconsistent string interface taking string_viewIssaquahComplete 2744any's in_place constructorsIssaquahComplete 2745[fund.ts.v2] Implementability of LWG 2451Issaquah - 2747Possibly redundant std::move in [alg.foreach]IssaquahPatch ready + 2747Possibly redundant std::move in [alg.foreach]IssaquahComplete 2748swappable traits for optionalsIssaquahComplete 2749swappable traits for variantsIssaquah 2750[fund.ts.v2] LWG 2451 conversion constructor constraintIssaquah @@ -401,14 +401,14 @@ 2755[string.view.io] uses non-existent basic_string_view::to_string functionIssaquahComplete 2756C++ WP optional should 'forward' T's implicit conversionsIssaquahComplete 2758std::string{}.assign("ABCDE", 0, 1) is ambiguousComplete - 2759gcd / lcm and bool for the WPIssaquahPatch ready + 2759gcd / lcm and bool for the WPIssaquahComplete 2760non-const basic_string::data should not invalidate iteratorsIssaquahComplete 2765Did LWG 1123 go too far?Issaquah 2767not_fn call_wrapper can form invalid typesIssaquahComplete 2769Redundant const in the return type of any_cast(const any&)IssaquahComplete 2771Broken Effects of some basic_string::compare functions in terms of basic_string_viewIssaquahComplete 2773Making std::ignore constexprIssaquah - 2777basic_string_view::copy should use char_traits::copyIssaquahPatch Ready + 2777basic_string_view::copy should use char_traits::copyIssaquahComplete 2778basic_string_view is missing constexprIssaquah