//===----------------------------------------------------------------------===// // // 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 // // template // typename multimap::size_type // erase_if(multimap& c, Predicate pred); #include #include "test_macros.h" #include "test_allocator.h" #include "min_allocator.h" using Init = std::initializer_list; template M make (Init vals) { M ret; for (int v : vals) ret.emplace(static_cast(v), static_cast(v + 10)); return ret; } template void test0(Init vals, Pred p, Init expected, std::size_t expected_erased_count) { M s = make(vals); ASSERT_SAME_TYPE(typename M::size_type, decltype(std::erase_if(s, p))); assert(expected_erased_count == std::erase_if(s, p)); assert(s == make(expected)); } template void test() { auto is1 = [](auto v) { return v.first == 1;}; auto is2 = [](auto v) { return v.first == 2;}; auto is3 = [](auto v) { return v.first == 3;}; auto is4 = [](auto v) { return v.first == 4;}; auto True = [](auto) { return true; }; auto False = [](auto) { return false; }; test0({}, is1, {}, 0); test0({1}, is1, {}, 1); test0({1}, is2, {1}, 0); test0({1, 2}, is1, {2}, 1); test0({1, 2}, is2, {1}, 1); test0({1, 2}, is3, {1, 2}, 0); test0({1, 1}, is1, {}, 2); test0({1, 1}, is3, {1, 1}, 0); test0({1, 2, 3}, is1, {2, 3}, 1); test0({1, 2, 3}, is2, {1, 3}, 1); test0({1, 2, 3}, is3, {1, 2}, 1); test0({1, 2, 3}, is4, {1, 2, 3}, 0); test0({1, 1, 1}, is1, {}, 3); test0({1, 1, 1}, is2, {1, 1, 1}, 0); test0({1, 1, 2}, is1, {2}, 2); test0({1, 1, 2}, is2, {1, 1}, 1); test0({1, 1, 2}, is3, {1, 1, 2}, 0); test0({1, 2, 2}, is1, {2, 2}, 1); test0({1, 2, 2}, is2, {1}, 2); test0({1, 2, 2}, is3, {1, 2, 2}, 0); test0({1, 2, 3}, True, {}, 3); test0({1, 2, 3}, False, {1, 2, 3}, 0); } int main(int, char**) { test>(); test, min_allocator>>> (); test, test_allocator>>> (); test>(); test>(); return 0; }