2016-09-08 21:13:10 +04:00
|
|
|
(**************************************************************************)
|
|
|
|
(* *)
|
2017-11-14 03:36:14 +04:00
|
|
|
(* Copyright (c) 2014 - 2017. *)
|
2016-09-08 21:13:10 +04:00
|
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
|
|
(* *)
|
|
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
|
|
(* *)
|
|
|
|
(**************************************************************************)
|
|
|
|
|
|
|
|
type t = int32
|
|
|
|
type roll = t
|
|
|
|
|
|
|
|
let encoding = Data_encoding.int32
|
|
|
|
|
|
|
|
let first = 0l
|
|
|
|
let succ i = Int32.succ i
|
|
|
|
|
|
|
|
let random sequence ~bound =
|
|
|
|
Seed_repr.take_int32 sequence bound
|
|
|
|
|
|
|
|
let to_int32 v = v
|
|
|
|
|
|
|
|
let (=) = Compare.Int32.(=)
|
2017-11-16 19:45:22 +04:00
|
|
|
|
|
|
|
module Index = struct
|
|
|
|
type t = roll
|
|
|
|
let path_length = 3
|
|
|
|
let to_path roll l =
|
2017-11-20 00:30:48 +04:00
|
|
|
(Int32.to_string @@ Int32.logand roll (Int32.of_int 0xff)) ::
|
|
|
|
(Int32.to_string @@ Int32.logand (Int32.shift_right_logical roll 8) (Int32.of_int 0xff)) ::
|
|
|
|
Int32.to_string roll :: l
|
2017-11-16 19:45:22 +04:00
|
|
|
let of_path = function
|
|
|
|
| _ :: _ :: s :: _ -> begin
|
|
|
|
try Some (Int32.of_string s)
|
|
|
|
with _ -> None
|
|
|
|
end
|
|
|
|
| _ -> None
|
|
|
|
end
|
2017-11-20 00:32:24 +04:00
|
|
|
|
|
|
|
let rec too_many_roll next =
|
|
|
|
if Compare.Int32.(next < 100_000l) then
|
|
|
|
0
|
|
|
|
else
|
|
|
|
1 + too_many_roll (Int32.div next 2l)
|