12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364(****************************************************************************)(* *)(* This file is part of MOPSA, a Modular Open Platform for Static Analysis. *)(* *)(* Copyright (C) 2017-2019 The MOPSA Project. *)(* *)(* This program 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 3 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 Lesser General Public License for more details. *)(* *)(* You should have received a copy of the GNU Lesser General Public License *)(* along with this program. If not, see <http://www.gnu.org/licenses/>. *)(* *)(****************************************************************************)(** Map with printing builder *)(** Builder *)moduleMake(K:ValueSig.S)(E:ValueSig.S):sigtype+'amapincludeMapExtSig.Swithtypekey:=K.tandtype'at:='amaptypet=E.tmapvalprint:Format.formatter->t->unitvalcompare:t->t->intend=structmoduleM=MapExt.Make(K)type'amap='aM.tmoduletypeS=MapExtSig.Swithtypekey:=K.tandtype'at:='amapinclude(M:S)typet=E.tmapletprintfmt(m:t)=Format.fprintffmt"@[{%a}@]"(Format.pp_print_list~pp_sep:(funfmt()->Format.fprintffmt",")(funfmt(z,t)->Format.fprintffmt"%a ~> %a"K.printzE.printt))(bindingsm)letcompare(m:t)(m':t)=tryletr=fold(funkvacc->ifmemkacc&&E.compare(findkacc)v=0thenremovekaccelseraiseExit)mm'inifcardinalr=0then0else-1with|Exit->1end