package batteries
A community-maintained standard library extension
Install
Dune Dependency
Authors
Maintainers
Sources
v3.9.0.tar.gz
md5=ea26b5c72e6731e59d856626049cca4d
sha512=55975b62c26f6db77433a3ac31f97af609fc6789bb62ac38b267249c78fd44ff37fe81901f1cf560857b9493a6046dd37b0d1c0234c66bd59e52843aac3ce6cb
doc/src/batteries.unthreaded/batMultiPMap.ml.html
Source file batMultiPMap.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
(* * MultiPMap - Polymorphic maps with multiple associations * Copyright (C) 1996-2003 Xavier Leroy, Nicolas Cannasse, Markus Mottl * Copyright (C) 2008 David Teller, LIFO, Universite d'Orleans * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version, * with the special exception on linking described in file LICENSE. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *) module S = BatSet.PSet module M = BatMap.PMap type ('a, 'b) t = { content : ('a, 'b S.t) M.t; keys : 'a -> 'a -> int; data : 'b -> 'b -> int } let empty = {content = M.empty; keys = compare; data = compare} let is_empty t = M.is_empty t.content let create keys data = { content = M.create keys; data = data; keys = keys } let find k t = try M.find k t.content with Not_found -> S.create t.data let add k d t = {(t) with content = M.add k (S.add d (find k t)) t.content} let remove_all k t = {(t) with content = M.remove k t.content} let remove k d t = try let set = S.remove d (M.find k t.content) in {(t) with content = if S.is_empty set then M.remove k t.content else M.add k set t.content; } with Not_found -> t let mem k d = M.mem k d.content (* let exists = mem *) let iter f d = M.iter f d.content let map (f:('b S.t -> 'c S.t)) (cmp:('b -> 'b -> int) -> ('c -> 'c -> int)) (t:('a, 'b) t) = { content = M.map f t.content; keys = t.keys; data = cmp t.data} let mapi (f:('a -> 'b S.t -> 'c S.t)) (cmp:('b -> 'b -> int) -> ('c -> 'c -> int)) (t:('a, 'b) t) = { content = M.mapi f t.content; keys = t.keys; data = cmp t.data} let fold f d i = M.fold f d.content i let foldi f d i = M.foldi f d.content i let modify k f t = {t with content = M.modify k f t.content} let modify_def dft k f t = {t with content = M.modify_def dft k f t.content} let modify_opt k f t = {t with content = M.modify_opt k f t.content} let enum t = BatEnum.concat (BatEnum.map (fun (k,e) -> BatEnum.map (fun x -> (k,x)) (S.enum e)) (M.enum t.content)) let of_enum ?(keys=compare) ?(data=compare) e = let base = create keys data in BatEnum.fold (fun acc (k,d) -> add k d acc) base e let print ?(first="{\n") ?(last="\n}") ?(sep=",\n") ?(kvsep=": ") print_k print_v out t = BatEnum.print ~first ~last ~sep (fun out (k, v) -> BatPrintf.fprintf out "%a%s%a" print_k k kvsep print_v v) out (enum t) module Infix = struct let (-->) map key = find key map let (<--) map (key, value) = add key value map end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>