https://github.com/EasyCrypt/easycrypt
Tip revision: f7b8664dcf5237042389e655a2e37b09177167f5 authored by Alley Stoughton on 30 June 2021, 15:32:30 UTC
Added Above Threshold and Report Noisy Max examples, which check
Added Above Threshold and Report Noisy Max examples, which check
Tip revision: f7b8664
ecFortune.ml
(* --------------------------------------------------------------------
* Copyright (c) - 2012--2016 - IMDEA Software Institute
* Copyright (c) - 2012--2018 - Inria
* Copyright (c) - 2012--2018 - Ecole Polytechnique
*
* Distributed under the terms of the CeCILL-C-V1 license
* -------------------------------------------------------------------- *)
(* --------------------------------------------------------------------- *)
open EcUtils
(* --------------------------------------------------------------------- *)
let thepick = ref (fun () -> failwith "fortune-uninit")
(* -------------------------------------------------------------------- *)
let pickfor values : unit -> string option =
fun () ->
match Array.length values with
| n when n <= 0 -> None
| n -> Some (values.(Random.int n))
(* --------------------------------------------------------------------- *)
let fortune_from_stream : in_channel -> string list =
let rec aux acc stream =
try
let line = input_line stream in
let line = String.strip line in
if String.length line = 0
then aux acc stream
else aux (line :: acc) stream
with End_of_file -> acc
in fun stream -> aux [] stream
(* --------------------------------------------------------------------- *)
let init () =
let conffiles =
XDG.Data.file
~exists:true ~appname:EcVersion.app ~mode:`All
"fortune.conf"
in
let values =
let for1 filename =
try
let stream = open_in filename in
EcUtils.try_finally
(fun () -> fortune_from_stream stream)
(fun () -> close_in stream)
with Sys_error _ ->
[]
in List.flatten (List.map for1 conffiles)
in thepick := pickfor (Array.of_list values)
(* --------------------------------------------------------------------- *)
let pick () : string option =
!thepick ()