12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061(**************************************************************************)(* This file is part of BINSEC. *)(* *)(* Copyright (C) 2016-2022 *)(* 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). *)(* *)(**************************************************************************)typet=stringexternalto_string:t->string="%identity"letpp=Format.pp_print_stringletzero="!0"letincr=letsett'ic=Bytes.sett'ic;Bytes.unsafe_to_stringt'in(* to keep it compact, transition rules are impacted by the ASCII encoding:
0-9a-zA-Z!$%&*+./<>?@^_~ *)letrecincrt'i=matchBytes.gett'iwith|'9'->sett'i'a'|'z'->sett'i'A'|'Z'->sett'i'!'|'!'->sett'i'$'|'&'->sett'i'*'|'+'->sett'i'.'|'/'->sett'i'<'|'<'->sett'i'>'|'@'->sett'i'^'|'_'->sett'i'~'|'~'wheni=0->(* overflow *)lett'=Bytes.(make(lengtht'+1)'0')inBytes.sett'0'!';Bytes.unsafe_to_stringt'|'~'->Bytes.sett'i'0';incrt'(i-1)(* carry *)|x->sett'iChar.(unsafe_chr(codex+1))infunt->lett'=Bytes.of_stringtinincrt'(Bytes.lengtht'-1)