12345678910111213141516171819202122232425262728293031323334353637383940414243(**************************************************************************)(* This file is part of BINSEC. *)(* *)(* Copyright (C) 2016-2026 *)(* 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). *)(* *)(**************************************************************************)letrecuntilipti=ifi=Array.lengthtthenraiseNot_foundelseifpt.(i)thenielseuntilipt@@(i+1)letfindipt=untilipt0letfindpt=t.(findipt)letfind_optpt=trySome(findpt)withNot_found->Noneletfold_leftifat=leta=refainfori=0toArray.lengtht-1doa:=fi!at.(i)done;!aletfold_rightifat=leta=refainfori=Array.lengtht-1downto0doa:=fi!at.(i)done;!a