////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2025-2026. Distributed under the Boost // Software License, Version 1.0. (See accompanying file // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // // See http://www.boost.org/libs/container for documentation. // ////////////////////////////////////////////////////////////////////////////// #include #include #include "segmented_test_helper.hpp" #include using namespace boost::container; void test_reverse_segmented() { test_detail::seg_vector sv; int a1[] = {1, 2, 3}; int a2[] = {4, 5}; int a3[] = {6, 7, 8, 9}; sv.add_segment_range(a1, a1 + 3); sv.add_segment_range(a2, a2 + 2); sv.add_segment_range(a3, a3 + 4); segmented_reverse(sv.begin(), sv.end()); int expected[] = {9, 8, 7, 6, 5, 4, 3, 2, 1}; test_detail::seg_vector::iterator it = sv.begin(); for(int i = 0; i < 9; ++i, ++it) BOOST_TEST_EQ(*it, expected[i]); } void test_reverse_single_element() { test_detail::seg_vector sv; int a[] = {42}; sv.add_segment_range(a, a + 1); segmented_reverse(sv.begin(), sv.end()); BOOST_TEST_EQ(*sv.begin(), 42); } void test_reverse_empty() { test_detail::seg_vector sv; segmented_reverse(sv.begin(), sv.end()); BOOST_TEST_EQ(sv.total_size(), 0u); } void test_reverse_even_count() { test_detail::seg_vector sv; int a1[] = {1, 2}; int a2[] = {3, 4}; sv.add_segment_range(a1, a1 + 2); sv.add_segment_range(a2, a2 + 2); segmented_reverse(sv.begin(), sv.end()); int expected[] = {4, 3, 2, 1}; test_detail::seg_vector::iterator it = sv.begin(); for(int i = 0; i < 4; ++i, ++it) BOOST_TEST_EQ(*it, expected[i]); } void test_reverse_non_segmented() { std::vector v; v.push_back(1); v.push_back(2); v.push_back(3); v.push_back(4); v.push_back(5); segmented_reverse(v.begin(), v.end()); BOOST_TEST_EQ(v[0], 5); BOOST_TEST_EQ(v[1], 4); BOOST_TEST_EQ(v[2], 3); BOOST_TEST_EQ(v[3], 2); BOOST_TEST_EQ(v[4], 1); } void test_reverse_seg2() { test_detail::seg2_vector sv2; int a1[] = {1, 2, 3}; int a2[] = {4, 5}; int a3[] = {6, 7, 8, 9}; sv2.add_flat_segment_range(a1, a1 + 3); sv2.add_flat_segment_range(a2, a2 + 2); sv2.add_flat_segment_range(a3, a3 + 4); segmented_reverse(sv2.begin(), sv2.end()); int expected[] = {9, 8, 7, 6, 5, 4, 3, 2, 1}; test_detail::seg2_vector::iterator it = sv2.begin(); for(int i = 0; i < 9; ++i, ++it) BOOST_TEST_EQ(*it, expected[i]); } int main() { test_reverse_segmented(); test_reverse_single_element(); test_reverse_empty(); test_reverse_even_count(); test_reverse_non_segmented(); test_reverse_seg2(); return boost::report_errors(); }