module T = (val Containers_testlib.make ~__FILE__ ()) include T;; open CCMap;; module M = CCMap.Make(String);; let eq' = eq ~printer:CCFormat.(to_string @@ Dump.(list (pair string int)));; eq' ["a", 1; "b", 20] (M.of_list ["b", 2; "c", 3] |> M.update "a" (function _ -> Some 1) |> M.update "c" (fun _ -> None) |> M.update "b" (CCOption.map (fun x -> x * 10)) |> M.to_list |> List.sort CCOrd.poly);; module M2 = Make(CCInt);; q Q.(list (pair small_int small_int)) M2.(fun l -> to_list (of_list l) = to_list (of_list_with ~f:(fun _ v _ ->v) l));; q Q.(list (pair small_int small_int)) M2.(fun l -> to_list (of_iter @@ Iter.of_list l) = to_list (of_iter_with ~f:(fun _ v _ ->v) @@ Iter.of_list l));; q Q.(list (pair small_int small_int)) M2.(fun l -> to_list (of_seq @@ CCSeq.of_list l) = to_list (of_seq_with ~f:(fun _ v _ ->v) @@ CCSeq.of_list l));;