//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++98, c++03, c++11, c++14, c++17 // // template // void erase_if(map& 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[v] = v + 10; return ret; } template void test0(Init vals, Pred p, Init expected) { M s = make (vals); ASSERT_SAME_TYPE(void, decltype(std::erase_if(s, p))); 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, {}); test0({1}, is1, {}); test0({1}, is2, {1}); test0({1,2}, is1, {2}); test0({1,2}, is2, {1}); test0({1,2}, is3, {1,2}); test0({1,2,3}, is1, {2,3}); test0({1,2,3}, is2, {1,3}); test0({1,2,3}, is3, {1,2}); test0({1,2,3}, is4, {1,2,3}); test0({1,2,3}, True, {}); test0({1,2,3}, False, {1,2,3}); } int main() { test>(); test, min_allocator>>> (); test, test_allocator>>> (); test>(); test>(); }