1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980(*****************************************************************************)(* *)(* Open Source License *)(* Copyright (c) 2020 Nomadic Labs, <contact@nomadic-labs.com> *)(* *)(* Permission is hereby granted, free of charge, to any person obtaining a *)(* copy of this software and associated documentation files (the "Software"),*)(* to deal in the Software without restriction, including without limitation *)(* the rights to use, copy, modify, merge, publish, distribute, sublicense, *)(* and/or sell copies of the Software, and to permit persons to whom the *)(* Software is furnished to do so, subject to the following conditions: *)(* *)(* The above copyright notice and this permission notice shall be included *)(* in all copies or substantial portions of the Software. *)(* *)(* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR*)(* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *)(* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *)(* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER*)(* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *)(* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *)(* DEALINGS IN THE SOFTWARE. *)(* *)(*****************************************************************************)moduletypeUNBOXED_COLLECTION=Sigs.UNBOXED_COLLECTIONmoduleRing:UNBOXED_COLLECTION=RingmoduleDll:UNBOXED_COLLECTION=Functors.Unbox(Dll)typereplacement=|LRU|FIFOtypeoverflow=|Strong|Weaktypeaccounting=|Precise|SloppymoduletypeCACHE_MAP=Sigs.CACHE_MAPmoduletypeCACHE_SET=Sigs.CACHE_SETlettabler:overflow->(moduleSigs.TABLER)=function|Strong->(moduleFunctors.Strong_tabler)|Weak->(moduleFunctors.Weak_tabler)letcollection:replacement->accounting->(moduleSigs.COLLECTION)=funreplacementaccounting->matchreplacementwith|LRU->(moduleFunctors.LRU_Collection)|FIFO->matchaccountingwith|Precise->(moduleFunctors.FIFO_Precise_Collection)|Sloppy->(moduleFunctors.FIFO_Sloppy_Collection)moduletypeMAP_MAKER=functor(H:Hashtbl.HashedType)->CACHE_MAPwithtypekey=H.ttypemap_maker=(moduleMAP_MAKER)letmap_maker~replacement~overflow~accounting:map_maker=letmoduleTabler=(valtableroverflow:Sigs.TABLER)inletmoduleCollection=(valcollectionreplacementaccounting:Sigs.COLLECTION)in(moduleFunctors.Make_map(Collection)(Tabler))moduleEmptyMap=Sized.EmptyMapmoduleSingletonMap=Sized.SingletonMapmoduletypeSET_MAKER=functor(H:Hashtbl.HashedType)->CACHE_SETwithtypeelt=H.ttypeset_maker=(moduleSET_MAKER)letset_maker~replacement~overflow~accounting:set_maker=letmoduleTabler=(valtableroverflow:Sigs.TABLER)inletmoduleCollection=(valcollectionreplacementaccounting:Sigs.COLLECTION)in(moduleFunctors.Make_set(Collection)(Tabler))moduleEmptySet=Sized.EmptySetmoduleSingletonSet=Sized.SingletonSet