methods.ml1 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(***************************************************************************** Liquidsoap, a programmable audio stream generator. Copyright 2003-2023 Savonet team This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program 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 General Public License for more details, fully stated in the COPYING file at the root of the liquidsoap distribution. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *****************************************************************************) (* Immutable fast hash *) type ('a, 'b) t = ('a * 'b) list let is_empty h = h = [] let bindings h = h let empty = [] let cardinal = List.length let fold fn h r = List.fold_left (fun r (k, v) -> fn k v r) r h let find = List.assoc let find_opt = List.assoc_opt let mem = List.mem_assoc let mapi fn = List.map (fun (k, v) -> (k, fn k v)) let map fn = List.map (fun (k, v) -> (k, fn v)) let filter fn = List.filter (fun (k, v) -> fn k v) let add k v h = (k, v) :: List.remove_assoc k h let iter fn = List.iter (fun (k, v) -> fn k v) let for_all fn = List.for_all (fun (k, v) -> fn k v) let exists fn = List.exists (fun (k, v) -> fn k v)