(**************************************************************************) (* *) (* Copyright (c) 2014 - 2018. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) type t = MBytes.t list include Compare.Make(struct type nonrec t = t (* 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 end) 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 def "fitness" ~title: "Block fitness" ~description: "The fitness, or score, of a block, that allow the Tezos to \ decide which chain is the best. A fitness value is a list of \ byte sequences. They are compared as follows: shortest lists \ are smaller; lists of the same length are compared according to \ the lexicographical order." @@ splitted ~json: (list bytes) ~binary: (list (def "fitness.elem" bytes)) let to_bytes v = Data_encoding.Binary.to_bytes_exn encoding v let of_bytes b = Data_encoding.Binary.of_bytes encoding b