1234567891011121314151617181920212223242526272829303132333435363738394041424344(**************************************************************************)(* This file is part of BINSEC. *)(* *)(* Copyright (C) 2016-2024 *)(* 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 licenses/LGPLv2.1). *)(* *)(**************************************************************************)moduleInterrupt:sigvaldefault:float->intvaltimeout:float->intend=structletchecktimestamp=Float.compare(Unix.gettimeofday())timestampletinterruptfx=matchUnix.sigpending()with|[]|(exceptionInvalid_argument_)->fx|lwhenList.memSys.sigintl->1|_->fxletzero=Fun.const0letdefault=interruptzerolettimeout=interruptcheckendletwatchdog~timeout(f:?interrupt:('a->int)*'a->'b)=letinterrupt=iftimeout=0then(Interrupt.default,0.)else(Interrupt.timeout,Unix.gettimeofday()+.float_of_inttimeout)inf~interrupt