From 6b12cf284832c250d02e7eab438af3652b5333b2 Mon Sep 17 00:00:00 2001 From: youyu3 Date: Thu, 5 Jan 2023 23:37:40 -0800 Subject: [PATCH] Fix the inequality operator in layout_left and layout_right, after #197 --- include/experimental/__p0009_bits/layout_left.hpp | 2 +- include/experimental/__p0009_bits/layout_right.hpp | 2 +- tests/test_layout_ctors.cpp | 1 + 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/include/experimental/__p0009_bits/layout_left.hpp b/include/experimental/__p0009_bits/layout_left.hpp index 2b3a9bdf..bb17c449 100644 --- a/include/experimental/__p0009_bits/layout_left.hpp +++ b/include/experimental/__p0009_bits/layout_left.hpp @@ -188,7 +188,7 @@ class layout_left::mapping { } // In C++ 20 the not equal exists if equal is found -#if MDSPAN_HAS_CXX_20 +#if !(MDSPAN_HAS_CXX_20) template MDSPAN_INLINE_FUNCTION friend constexpr bool operator!=(mapping const& lhs, mapping const& rhs) noexcept { diff --git a/include/experimental/__p0009_bits/layout_right.hpp b/include/experimental/__p0009_bits/layout_right.hpp index 2ab20f19..dc345806 100644 --- a/include/experimental/__p0009_bits/layout_right.hpp +++ b/include/experimental/__p0009_bits/layout_right.hpp @@ -190,7 +190,7 @@ class layout_right::mapping { } // In C++ 20 the not equal exists if equal is found -#if MDSPAN_HAS_CXX_20 +#if !(MDSPAN_HAS_CXX_20) template MDSPAN_INLINE_FUNCTION friend constexpr bool operator!=(mapping const& lhs, mapping const& rhs) noexcept { diff --git a/tests/test_layout_ctors.cpp b/tests/test_layout_ctors.cpp index e4e3475f..5a83a585 100644 --- a/tests/test_layout_ctors.cpp +++ b/tests/test_layout_ctors.cpp @@ -68,6 +68,7 @@ TYPED_TEST(TestLayoutCtors, default_ctor) { auto m2 = typename TestFixture::mapping_type{}; ASSERT_EQ(m2.extents(), typename TestFixture::extents_type{}); ASSERT_EQ(m, m2); + ASSERT_FALSE(m != m2); } template struct TestLayoutCompatCtors;