1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950(*
* Copyright (c) 2013-2020 Thomas Gazagnaire <thomas@gazagnaire.org>
* Copyright (c) 2013-2020 Anil Madhavapeddy <anil@recoil.org>
* Copyright (c) 2015-2020 Gabriel Radanne <drupyog@zoho.com>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*)type'akey={name:string;put:'a->exn;get:exn->'a}letnew_key(typea)name=letmoduleM=structexceptionEofaendinletputa=M.Eainletget=function|M.Ea->a|_->raise@@Invalid_argument("duplicate key: "^name)in{name;put;get}moduleMap=Map.Make(String)typet=exnMap.tletempty=Map.emptyletaddkv(t:t):t=Map.addk.name(k.putv)tletmemk(t:t)=Map.memk.nametletfindk(t:t)=ifMap.memk.nametthenSome(k.get@@Map.findk.namet)elseNoneletdump:tFmt.t=letpp_eltppf(k,v)=Fmt.pfppf"[%s: %a]"kFmt.exnvinletmap_iterf=Map.iter(funkv->f(k,v))inFmt.box~indent:2@@Fmt.(iter~sep:(any"@ "))map_iterpp_eltletmerge~defaultm=letaux__v=SomevinMap.unionauxdefaultm