//===----------------------------------------------------------------------===// // // 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 // template>, // class Allocator = allocator>> // map(InputIterator, InputIterator, // Compare = Compare(), Allocator = Allocator()) // -> map, Compare, Allocator>; // template, class Allocator = allocator> // map(initializer_list, Compare = Compare(), Allocator = Allocator()) // -> map; // template // map(InputIterator, InputIterator, Allocator) // -> map, less>, Allocator>; // template // map(initializer_list, Allocator) // -> map, Allocator>; // // template, // class Allocator = allocator>> // map(from_range_t, R&&, Compare = Compare(), Allocator = Allocator()) // -> map, range-mapped-type, Compare, Allocator>; // C++23 // // template // map(from_range_t, R&&, Allocator) // -> map, range-mapped-type, less>, Allocator>; // C++23 #include // std::equal #include #include #include // INT_MAX #include #include #include #include "deduction_guides_sfinae_checks.h" #include "test_allocator.h" using P = std::pair; using PC = std::pair; int main(int, char**) { { const P arr[] = { {1,1L}, {2,2L}, {1,1L}, {INT_MAX,1L}, {3,1L} }; std::map m(std::begin(arr), std::end(arr)); ASSERT_SAME_TYPE(decltype(m), std::map); const PC expected_m[] = { {1,1L}, {2,2L}, {3,1L}, {INT_MAX,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); } { const P arr[] = { {1,1L}, {2,2L}, {1,1L}, {INT_MAX,1L}, {3,1L} }; std::map m(std::begin(arr), std::end(arr), std::greater()); ASSERT_SAME_TYPE(decltype(m), std::map>); const PC expected_m[] = { {INT_MAX,1L}, {3,1L}, {2,2L}, {1,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); } { const P arr[] = { {1,1L}, {2,2L}, {1,1L}, {INT_MAX,1L}, {3,1L} }; std::map m(std::begin(arr), std::end(arr), std::greater(), test_allocator(0, 42)); ASSERT_SAME_TYPE(decltype(m), std::map, test_allocator>); const PC expected_m[] = { {INT_MAX,1L}, {3,1L}, {2,2L}, {1,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); assert(m.get_allocator().get_id() == 42); } { std::map source; std::map m(source); ASSERT_SAME_TYPE(decltype(m), decltype(source)); assert(m.size() == 0); } { std::map source; std::map m{source}; // braces instead of parens ASSERT_SAME_TYPE(decltype(m), decltype(source)); assert(m.size() == 0); } { std::map source; std::map m(source, std::map::allocator_type()); ASSERT_SAME_TYPE(decltype(m), decltype(source)); assert(m.size() == 0); } { std::map m{ P{1,1L}, P{2,2L}, P{1,1L}, P{INT_MAX,1L}, P{3,1L} }; ASSERT_SAME_TYPE(decltype(m), std::map); const PC expected_m[] = { {1,1L}, {2,2L}, {3,1L}, {INT_MAX,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); } { std::map m({ P{1,1L}, P{2,2L}, P{1,1L}, P{INT_MAX,1L}, P{3,1L} }, std::greater()); ASSERT_SAME_TYPE(decltype(m), std::map>); const PC expected_m[] = { {INT_MAX,1L}, {3,1L}, {2,2L}, {1,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); } { std::map m({ P{1,1L}, P{2,2L}, P{1,1L}, P{INT_MAX,1L}, P{3,1L} }, std::greater(), test_allocator(0, 43)); ASSERT_SAME_TYPE(decltype(m), std::map, test_allocator>); const PC expected_m[] = { {INT_MAX,1L}, {3,1L}, {2,2L}, {1,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); assert(m.get_allocator().get_id() == 43); } { const P arr[] = { {1,1L}, {2,2L}, {1,1L}, {INT_MAX,1L}, {3,1L} }; std::map m(std::begin(arr), std::end(arr), test_allocator(0, 44)); ASSERT_SAME_TYPE(decltype(m), std::map, test_allocator>); const PC expected_m[] = { {1,1L}, {2,2L}, {3,1L}, {INT_MAX,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); assert(m.get_allocator().get_id() == 44); } { std::map m({ P{1,1L}, P{2,2L}, P{1,1L}, P{INT_MAX,1L}, P{3,1L} }, test_allocator(0, 45)); ASSERT_SAME_TYPE(decltype(m), std::map, test_allocator>); const PC expected_m[] = { {1,1L}, {2,2L}, {3,1L}, {INT_MAX,1L} }; assert(std::equal(m.begin(), m.end(), std::begin(expected_m), std::end(expected_m))); assert(m.get_allocator().get_id() == 45); } { // Examples from LWG3025 std::map m{std::pair{1, 1}, {2, 2}, {3, 3}}; ASSERT_SAME_TYPE(decltype(m), std::map); std::map m2{m.begin(), m.end()}; ASSERT_SAME_TYPE(decltype(m2), std::map); } { // Examples from LWG3531 std::map m1{{std::pair{1, 2}, {3, 4}}, std::less()}; ASSERT_SAME_TYPE(decltype(m1), std::map); using value_type = std::pair; std::map m2{{value_type{1, 2}, {3, 4}}, std::less()}; ASSERT_SAME_TYPE(decltype(m2), std::map); } #if TEST_STD_VER >= 23 { using Range = std::array; using Comp = std::greater; using DefaultComp = std::less; using Alloc = test_allocator; { // (from_range, range) std::map c(std::from_range, Range()); static_assert(std::is_same_v>); } { // (from_range, range, comp) std::map c(std::from_range, Range(), Comp()); static_assert(std::is_same_v>); } { // (from_range, range, comp, alloc) std::map c(std::from_range, Range(), Comp(), Alloc()); static_assert(std::is_same_v>); } { // (from_range, range, alloc) std::map c(std::from_range, Range(), Alloc()); static_assert(std::is_same_v>); } } #endif AssociativeContainerDeductionGuidesSfinaeAway>(); return 0; }