(**************************************************************************) (* *) (* Copyright (c) 2014 - 2017. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) type t = MBytes.t list (* Fitness comparison: - shortest lists are smaller ; - lexicographical order for lists of the same length. *) let compare_bytes b1 b2 = let len1 = MBytes.length b1 in let len2 = MBytes.length b2 in let c = compare len1 len2 in if c <> 0 then c else let rec compare_byte b1 b2 pos len = if pos = len then 0 else let c = compare (MBytes.get_char b1 pos) (MBytes.get_char b2 pos) in if c <> 0 then c else compare_byte b1 b2 (pos+1) len in compare_byte b1 b2 0 len1 let compare f1 f2 = let rec compare_rec f1 f2 = match f1, f2 with | [], [] -> 0 | i1 :: f1, i2 :: f2 -> let i = compare_bytes i1 i2 in if i = 0 then compare_rec f1 f2 else i | _, _ -> assert false in let len = compare (List.length f1) (List.length f2) in if len = 0 then compare_rec f1 f2 else len let equal f1 f2 = compare f1 f2 = 0 let (=) = equal let (<>) x y = compare x y <> 0 let (<) x y = compare x y < 0 let (<=) x y = compare x y <= 0 let (>=) x y = compare x y >= 0 let (>) x y = compare x y > 0 let min x y = if x <= y then x else y let max x y = if x <= y then y else x let rec pp fmt = function | [] -> () | [f] -> Format.fprintf fmt "%a" Hex.pp (MBytes.to_hex f) | f1 :: f -> Format.fprintf fmt "%a::%a" Hex.pp (MBytes.to_hex f1) pp f let encoding = let open Data_encoding in describe ~title: "Tezos block fitness" (list bytes) let to_bytes v = Data_encoding.Binary.to_bytes encoding v let of_bytes b = Data_encoding.Binary.of_bytes encoding b