123456789101112131415161718192021222324252627282930313233343536373839404142434445(**************************************************************************)(* This file is part of the Codex semantics library. *)(* *)(* Copyright (C) 2013-2025 *)(* CEA (Commissariat à l'énergie atomique et aux énergies *)(* alternatives) *)(* *)(* 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, version 2.1. *)(* *)(* It 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. *)(* *)(* See the GNU Lesser General Public License version 2.1 *)(* for more details (enclosed in the file LICENSE). *)(* *)(**************************************************************************)moduleMake(D:Sig.Minimal)=structletimperative_assumectxbool=letctx'=D.assumectxboolinmatchctx'with|None->assertfalse|Somectx'->D.Context.assignctxctx'endmoduleMakeForAADT(D:sigmoduleScalar:Sig.BASEincludeMemory_sig.WITH_BOOLEAN_REDEFINITIONwithmoduleContext:=Scalar.Contextend)=structletimperative_assumectxbool=letctx'=D.assumectxboolinmatchctx'with|None->assertfalse|Somectx'->D.Scalar.Context.assignctxctx'end