//===----------------------------------------------------------------------===// // // 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++98, c++03, c++11, c++14 // UNSUPPORTED: libcpp-no-deduction-guides // 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>; #include // std::equal #include #include // INT_MAX #include #include #include #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); } return 0; }