[libcxx-commits] [libcxx] [libc++] Disallow character types being index types of `extents` (PR #105832)
A. Jiang via libcxx-commits
libcxx-commits at lists.llvm.org
Sun Aug 25 10:57:46 PDT 2024
https://github.com/frederick-vs-ja updated https://github.com/llvm/llvm-project/pull/105832
>From e33f05ff475cc693bac28a1678f9d2cd480e2902 Mon Sep 17 00:00:00 2001
From: "A. Jiang" <de34 at live.cn>
Date: Fri, 23 Aug 2024 22:36:10 +0800
Subject: [PATCH 1/4] [libc++] Disallow character types being index types of
`extents`
PR 78086 (bddd8f46f81477a52ff7ef2873e5671db71c431e) provided the IMO
exact approach - `__libcpp_integer` - for this.
---
libcxx/include/__mdspan/extents.h | 5 +-
.../mdspan/extents/index_type.verify.cpp | 49 +++++++++++++++++++
2 files changed, 52 insertions(+), 2 deletions(-)
create mode 100644 libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
diff --git a/libcxx/include/__mdspan/extents.h b/libcxx/include/__mdspan/extents.h
index 95082ef3d11ac9..8fcfb4b09a2b18 100644
--- a/libcxx/include/__mdspan/extents.h
+++ b/libcxx/include/__mdspan/extents.h
@@ -19,6 +19,8 @@
#include <__assert>
#include <__config>
+
+#include <__concepts/arithmetic.h>
#include <__type_traits/common_type.h>
#include <__type_traits/is_convertible.h>
#include <__type_traits/is_nothrow_constructible.h>
@@ -282,8 +284,7 @@ class extents {
using size_type = make_unsigned_t<index_type>;
using rank_type = size_t;
- static_assert(is_integral<index_type>::value && !is_same<index_type, bool>::value,
- "extents::index_type must be a signed or unsigned integer type");
+ static_assert(__libcpp_integer<index_type>, "extents::index_type must be a signed or unsigned integer type");
static_assert(((__mdspan_detail::__is_representable_as<index_type>(_Extents) || (_Extents == dynamic_extent)) && ...),
"extents ctor: arguments must be representable as index_type and nonnegative");
diff --git a/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp b/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
new file mode 100644
index 00000000000000..e902118aaefaaa
--- /dev/null
+++ b/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
@@ -0,0 +1,49 @@
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+// UNSUPPORTED: c++03, c++11, c++14, c++17, c++20
+
+// <mdspan>
+
+// template<class IndexType, size_t... Extents>
+// class extents;
+//
+// Mandates:
+// - IndexType is a signed or unsigned integer type, and
+// - each element of Extents is either equal to dynamic_extent, or is representable as a value of type IndexType.
+
+#include <cstddef>
+#include <climits>
+#include <mdspan>
+
+void invalid_index_types() {
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ [[maybe_unused]] std::extents<char, '*'> ec;
+#ifndef TEST_HAS_NO_CHAR8_T
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ [[maybe_unused]] std::extents<char8_t, u8'*'> ec8;
+#endif
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ [[maybe_unused]] std::extents<char16_t, u'*'> ec16;
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ [[maybe_unused]] std::extents<char32_t, U'*'> ec32;
+#ifndef TEST_HAS_NO_WIDE_CHARACTERS
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ [[maybe_unused]] std::extents<wchar_t, L'*'> ewc;
+#endif
+}
+
+void invalid_extent_values() {
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents ctor: arguments must be representable as index_type and nonnegative}}
+ [[maybe_unused]] std::extents<signed char, static_cast<std::size_t>(SCHAR_MAX) + 1> esc1;
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents ctor: arguments must be representable as index_type and nonnegative}}
+ [[maybe_unused]] std::extents<signed char, std::dynamic_extent - 1> esc2;
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents ctor: arguments must be representable as index_type and nonnegative}}
+ [[maybe_unused]] std::extents<unsigned char, static_cast<std::size_t>(UCHAR_MAX) + 1> euc1;
+ // expected-error-re@*:* {{static assertion failed {{.*}}extents ctor: arguments must be representable as index_type and nonnegative}}
+ [[maybe_unused]] std::extents<unsigned char, std::dynamic_extent - 1> euc2;
+}
>From 6ffb69deab4ca5e657dc1d978461651c204bea59 Mon Sep 17 00:00:00 2001
From: "A. Jiang" <de34 at live.cn>
Date: Sun, 25 Aug 2024 23:22:55 +0800
Subject: [PATCH 2/4] Try to avoid regex in the expected-error
---
.../views/mdspan/extents/index_type.verify.cpp | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp b/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
index e902118aaefaaa..ba6941a1ab4c11 100644
--- a/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
+++ b/libcxx/test/std/containers/views/mdspan/extents/index_type.verify.cpp
@@ -21,18 +21,18 @@
#include <mdspan>
void invalid_index_types() {
- // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ // expected-error@*:* {{static assertion failed: extents::index_type must be a signed or unsigned integer type}}
[[maybe_unused]] std::extents<char, '*'> ec;
#ifndef TEST_HAS_NO_CHAR8_T
- // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ // expected-error@*:* {{static assertion failed: extents::index_type must be a signed or unsigned integer type}}
[[maybe_unused]] std::extents<char8_t, u8'*'> ec8;
#endif
- // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ // expected-error@*:* {{static assertion failed: extents::index_type must be a signed or unsigned integer type}}
[[maybe_unused]] std::extents<char16_t, u'*'> ec16;
- // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ // expected-error@*:* {{static assertion failed: extents::index_type must be a signed or unsigned integer type}}
[[maybe_unused]] std::extents<char32_t, U'*'> ec32;
#ifndef TEST_HAS_NO_WIDE_CHARACTERS
- // expected-error-re@*:* {{static assertion failed {{.*}}extents::index_type must be a signed or unsigned integer type}}
+ // expected-error@*:* {{static assertion failed: extents::index_type must be a signed or unsigned integer type}}
[[maybe_unused]] std::extents<wchar_t, L'*'> ewc;
#endif
}
>From 2eaa12cb639e0cf85e20747630765f687c532f34 Mon Sep 17 00:00:00 2001
From: "A. Jiang" <de34 at live.cn>
Date: Mon, 26 Aug 2024 01:46:42 +0800
Subject: [PATCH 3/4] Replace `char` with `signed char` in
`libcxx/containers/views/mdspan` tests
---
.../views/mdspan/extents/assert.conversion.pass.cpp | 2 +-
.../mdspan/extents/assert.ctor_from_array.pass.cpp | 4 ++--
.../extents/assert.ctor_from_integral.pass.cpp | 4 ++--
.../mdspan/extents/assert.ctor_from_span.pass.cpp | 4 ++--
.../mdspan/layout_left/assert.conversion.pass.cpp | 13 ++++++++-----
.../mdspan/layout_left/assert.ctor.extents.pass.cpp | 3 +--
.../layout_left/assert.ctor.layout_right.pass.cpp | 9 ++++++---
.../layout_left/assert.ctor.layout_stride.pass.cpp | 4 ++--
.../mdspan/layout_right/assert.conversion.pass.cpp | 13 ++++++++-----
.../layout_right/assert.ctor.extents.pass.cpp | 4 +++-
.../layout_right/assert.ctor.layout_left.pass.cpp | 9 ++++++---
.../layout_right/assert.ctor.layout_stride.pass.cpp | 4 ++--
.../mdspan/layout_stride/assert.conversion.pass.cpp | 10 +++++-----
.../assert.ctor.extents_array.pass.cpp | 4 ++--
.../layout_stride/assert.ctor.extents_span.pass.cpp | 3 ++-
15 files changed, 52 insertions(+), 38 deletions(-)
diff --git a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.conversion.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.conversion.pass.cpp
index 03ed1f78b778b4..31766e4c51c3bf 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.conversion.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.conversion.pass.cpp
@@ -50,7 +50,7 @@ int main(int, char**) {
}
// value out of range
{
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<char, D, 5> e(arg); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<signed char, D, 5> e(arg); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
index 906a6ec87bd446..574bc51bb0b1d9 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
@@ -53,7 +53,7 @@ int main(int, char**) {
{
TEST_LIBCPP_ASSERT_FAILURE(
([] {
- std::extents<char, D, 5> e1(std::array{1000, 5});
+ std::extents<signed char, D, 5> e1(std::array{1000, 5});
}()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
@@ -61,7 +61,7 @@ int main(int, char**) {
{
TEST_LIBCPP_ASSERT_FAILURE(
([] {
- std::extents<char, D, 5> e1(std::array{-1, 5});
+ std::extents<signed char, D, 5> e1(std::array{-1, 5});
}()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
diff --git a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_integral.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_integral.pass.cpp
index af484a300ea8b3..37e79aabf8532f 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_integral.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_integral.pass.cpp
@@ -50,12 +50,12 @@ int main(int, char**) {
}
// value out of range
{
- TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<char, D, 5> e1(1000, 5); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<signed char, D, 5> e1(1000, 5); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
// negative value
{
- TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<char, D, 5> e1(-1, 5); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<signed char, D, 5> e1(-1, 5); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_span.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_span.pass.cpp
index f09515cf1142d1..5bf51435901809 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_span.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_span.pass.cpp
@@ -49,13 +49,13 @@ int main(int, char**) {
// value out of range
{
std::array args{1000, 5};
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<char, D, 5> e1(std::span{args}); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<signed char, D, 5> e1(std::span{args}); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
// negative value
{
std::array args{-1, 5};
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<char, D, 5> e1(std::span{args}); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::extents<signed char, D, 5> e1(std::span{args}); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.conversion.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.conversion.pass.cpp
index 2cdfa2667cfd46..7b6616f19d724a 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.conversion.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.conversion.pass.cpp
@@ -42,17 +42,20 @@ int main(int, char**) {
}
// non-representability of extents itself
{
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_left::mapping<std::extents<char, D>> m(
- std::layout_left::mapping<std::extents<int, D>>(std::extents<int, D>(500))); }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(
+ ([=] {
+ std::layout_left::mapping<std::extents<signed char, D>> m(
+ std::layout_left::mapping<std::extents<int, D>>(std::extents<int, D>(500)));
+ }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
// required_span_size not representable, while individual extents are
{
// check extents would be constructible
- [[maybe_unused]] std::extents<char, D, 5> e(arg_exts);
+ [[maybe_unused]] std::extents<signed char, D, 5> e(arg_exts);
// but the product is not, so we can't use it for layout_left
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_left::mapping<std::extents<char, D, 5>> m(arg); }()),
+ ([=] { std::layout_left::mapping<std::extents<signed char, D, 5>> m(arg); }()),
"layout_left::mapping converting ctor: other.required_span_size() must be representable as index_type.");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.extents.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.extents.pass.cpp
index 6ac7411f1df014..7c96f8ec9353ff 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.extents.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.extents.pass.cpp
@@ -13,7 +13,6 @@
// <mdspan>
-
// constexpr mapping(const extents_type& e) noexcept;
//
// Preconditions: The size of the multidimensional index space e is representable as a value of type index_type ([basic.fundamental]).
@@ -32,7 +31,7 @@ int main(int, char**) {
{
// the extents are representable but the product is not, so we can't use it for layout_left
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_left::mapping<std::extents<char, D, 5>> m(std::extents<char, D, 5>(100)); }()),
+ ([=] { std::layout_left::mapping<std::extents<signed char, D, 5>> m(std::extents<signed char, D, 5>(100)); }()),
"layout_left::mapping extents ctor: product of extents must be representable as index_type.");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_right.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_right.pass.cpp
index ceb3242beb9c2a..e578bac2103b09 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_right.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_right.pass.cpp
@@ -44,9 +44,12 @@ int main(int, char**) {
}
// non-representability of extents itself
{
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_left::mapping<std::extents<char, D>> m(
- std::layout_right::mapping<std::extents<int, D>>(std::extents<int, D>(500))); }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(
+ ([=] {
+ std::layout_left::mapping<std::extents<signed char, D>> m(
+ std::layout_right::mapping<std::extents<int, D>>(std::extents<int, D>(500)));
+ }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
// Can't trigger required_span_size() representability assertion, since for rank-1 the above check will trigger first,
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_stride.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_stride.pass.cpp
index cc9358c853db41..cec8df8aba8d6c 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_stride.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_left/assert.ctor.layout_stride.pass.cpp
@@ -54,14 +54,14 @@ int main(int, char**) {
// non-representability of extents itself
{
std::layout_stride::mapping arg(std::extents<int, D>(500), std::array<int, 1>{1});
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_left::mapping<std::extents<char, D>> m(arg); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_left::mapping<std::extents<signed char, D>> m(arg); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
// non-representability of required span size
{
std::layout_stride::mapping arg(std::extents<int, D, D>(100, 3), std::array<int, 2>{1, 100});
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_left::mapping<std::extents<char, D, D>> m(arg); }()),
+ ([=] { std::layout_left::mapping<std::extents<signed char, D, D>> m(arg); }()),
"layout_left::mapping from layout_stride ctor: other.required_span_size() must be "
"representable as index_type.");
}
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.conversion.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.conversion.pass.cpp
index 4695ea834692ec..df16edb9254070 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.conversion.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.conversion.pass.cpp
@@ -42,17 +42,20 @@ int main(int, char**) {
}
// non-representability of extents itself
{
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_right::mapping<std::extents<char, D>> m(
- std::layout_right::mapping<std::extents<int, D>>(std::extents<int, D>(500))); }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(
+ ([=] {
+ std::layout_right::mapping<std::extents<signed char, D>> m(
+ std::layout_right::mapping<std::extents<int, D>>(std::extents<int, D>(500)));
+ }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
// required_span_size not representable, while individual extents are
{
// check extents would be constructible
- [[maybe_unused]] std::extents<char, D, 5> e(arg_exts);
+ [[maybe_unused]] std::extents<signed char, D, 5> e(arg_exts);
// but the product is not, so we can't use it for layout_right
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_right::mapping<std::extents<char, D, 5>> m(arg); }()),
+ ([=] { std::layout_right::mapping<std::extents<signed char, D, 5>> m(arg); }()),
"layout_right::mapping converting ctor: other.required_span_size() must be representable as index_type.");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.extents.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.extents.pass.cpp
index 797a8e3845c2f7..52095691f6d249 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.extents.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.extents.pass.cpp
@@ -31,7 +31,9 @@ int main(int, char**) {
{
// the extents are representable but the product is not, so we can't use it for layout_right
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_right::mapping<std::extents<char, D, 5>> m(std::extents<char, D, 5>(100)); }()),
+ ([=] {
+ std::layout_right::mapping<std::extents<signed char, D, 5>> m(std::extents<signed char, D, 5>(100));
+ }()),
"layout_right::mapping extents ctor: product of extents must be representable as index_type.");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_left.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_left.pass.cpp
index e4044a94b7f68d..1757ddb286b9c7 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_left.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_left.pass.cpp
@@ -44,9 +44,12 @@ int main(int, char**) {
}
// non-representability of extents itself
{
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_right::mapping<std::extents<char, D>> m(
- std::layout_left::mapping<std::extents<int, D>>(std::extents<int, D>(500))); }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(
+ ([=] {
+ std::layout_right::mapping<std::extents<signed char, D>> m(
+ std::layout_left::mapping<std::extents<int, D>>(std::extents<int, D>(500)));
+ }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
// Can't trigger required_span_size() representability assertion, since for rank-1 the above check will trigger first,
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_stride.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_stride.pass.cpp
index 18d974333a5800..b77d964540f9df 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_stride.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_right/assert.ctor.layout_stride.pass.cpp
@@ -54,14 +54,14 @@ int main(int, char**) {
// non-representability of extents itself
{
std::layout_stride::mapping arg(std::extents<int, D>(500), std::array<int, 1>{1});
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_right::mapping<std::extents<char, D>> m(arg); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_right::mapping<std::extents<signed char, D>> m(arg); }()),
"extents ctor: arguments must be representable as index_type and nonnegative");
}
// non-representability of required span size
{
std::layout_stride::mapping arg(std::extents<int, D, D>(100, 3), std::array<int, 2>{3, 1});
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_right::mapping<std::extents<char, D, D>> m(arg); }()),
+ ([=] { std::layout_right::mapping<std::extents<signed char, D, D>> m(arg); }()),
"layout_right::mapping from layout_stride ctor: other.required_span_size() must be "
"representable as index_type.");
}
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.conversion.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.conversion.pass.cpp
index fbd225b587749c..7deb1215de0dee 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.conversion.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.conversion.pass.cpp
@@ -65,7 +65,7 @@ int main(int, char**) {
{
TEST_LIBCPP_ASSERT_FAILURE(
([=] {
- std::layout_stride::mapping<std::extents<char, D>> m(
+ std::layout_stride::mapping<std::extents<signed char, D>> m(
std::layout_stride::mapping<std::extents<int, D>>(std::extents<int, D>(500), std::array<int, 1>{1}));
}()),
"extents ctor: arguments must be representable as index_type and nonnegative");
@@ -73,7 +73,7 @@ int main(int, char**) {
// all strides must be larger than zero
{
always_convertible_layout::mapping<std::dextents<int, 2>> offset_map(std::dextents<int, 2>{10, 10}, 100, -1);
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_stride::mapping<std::extents<char, D, D>> m(offset_map); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_stride::mapping<std::extents<signed char, D, D>> m(offset_map); }()),
"layout_stride::mapping converting ctor: all strides must be greater than 0");
}
// required_span_size not representable, while individual extents are
@@ -81,10 +81,10 @@ int main(int, char**) {
std::extents<int, D, D> arg_exts{100, 5};
std::layout_stride::mapping<std::extents<int, D, D>> arg(arg_exts, std::array<int, 2>{1, 100});
// check extents would be constructible
- [[maybe_unused]] std::extents<char, D, 5> e(arg_exts);
+ [[maybe_unused]] std::extents<signed char, D, 5> e(arg_exts);
// but the product is not, so we can't use it for layout_stride
TEST_LIBCPP_ASSERT_FAILURE(
- ([=] { std::layout_stride::mapping<std::extents<char, D, 5>> m(arg); }()),
+ ([=] { std::layout_stride::mapping<std::extents<signed char, D, 5>> m(arg); }()),
"layout_stride::mapping converting ctor: other.required_span_size() must be representable as index_type.");
}
// required_span_size not representable, while individual extents are, edge case
@@ -104,7 +104,7 @@ int main(int, char**) {
// base offset must be 0 (i.e. mapping(0,...,0)==0) for a strided layout with positive strides
{
always_convertible_layout::mapping<std::dextents<int, 2>> offset_map(std::dextents<int, 2>{10, 10}, 3);
- TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_stride::mapping<std::extents<char, D, D>> m(offset_map); }()),
+ TEST_LIBCPP_ASSERT_FAILURE(([=] { std::layout_stride::mapping<std::extents<signed char, D, D>> m(offset_map); }()),
"layout_stride::mapping converting ctor: base offset of mapping must be zero.");
}
return 0;
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_array.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_array.pass.cpp
index 31b38bd8079cef..6782a9789f89f9 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_array.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_array.pass.cpp
@@ -41,8 +41,8 @@ int main(int, char**) {
// the extents are representable but the product with strides is not, so we can't use it for layout_stride
TEST_LIBCPP_ASSERT_FAILURE(
([=] {
- std::layout_stride::mapping<std::extents<char, D, 5>> m(
- std::extents<char, D, 5>(20), std::array<int, 2>{20, 1});
+ std::layout_stride::mapping<std::extents<signed char, D, 5>> m(
+ std::extents<signed char, D, 5>(20), std::array<int, 2>{20, 1});
}()),
"layout_stride::mapping ctor: required span size is not representable as index_type.");
diff --git a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_span.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_span.pass.cpp
index 4cd0d8ff896ab6..74e4793c91372b 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_span.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/layout_stride/assert.ctor.extents_span.pass.cpp
@@ -44,7 +44,8 @@ int main(int, char**) {
TEST_LIBCPP_ASSERT_FAILURE(
([=] {
std::array<int, 2> strides{20, 1};
- std::layout_stride::mapping<std::extents<char, D, 5>> m(std::extents<char, D, 5>(20), std::span(strides));
+ std::layout_stride::mapping<std::extents<signed char, D, 5>> m(
+ std::extents<signed char, D, 5>(20), std::span(strides));
}()),
"layout_stride::mapping ctor: required span size is not representable as index_type.");
>From e998394d957556165f49711d663d074c41b0eae3 Mon Sep 17 00:00:00 2001
From: "A. Jiang" <de34 at live.cn>
Date: Mon, 26 Aug 2024 01:57:37 +0800
Subject: [PATCH 4/4] Clang-format `assert.ctor_from_array.pass.cpp`
---
.../mdspan/extents/assert.ctor_from_array.pass.cpp | 14 ++++----------
1 file changed, 4 insertions(+), 10 deletions(-)
diff --git a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
index 574bc51bb0b1d9..7fe78a788bf873 100644
--- a/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
+++ b/libcxx/test/libcxx/containers/views/mdspan/extents/assert.ctor_from_array.pass.cpp
@@ -51,19 +51,13 @@ int main(int, char**) {
}
// value out of range
{
- TEST_LIBCPP_ASSERT_FAILURE(
- ([] {
- std::extents<signed char, D, 5> e1(std::array{1000, 5});
- }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<signed char, D, 5> e1(std::array{1000, 5}); }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
// negative value
{
- TEST_LIBCPP_ASSERT_FAILURE(
- ([] {
- std::extents<signed char, D, 5> e1(std::array{-1, 5});
- }()),
- "extents ctor: arguments must be representable as index_type and nonnegative");
+ TEST_LIBCPP_ASSERT_FAILURE(([] { std::extents<signed char, D, 5> e1(std::array{-1, 5}); }()),
+ "extents ctor: arguments must be representable as index_type and nonnegative");
}
return 0;
}
More information about the libcxx-commits
mailing list