(**************************************************************************) (* *) (* Copyright (c) 2014 - 2017. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) type 'error t = { applied: (Operation_hash.t * Operation.t) list; refused: (Operation.t * 'error list) Operation_hash.Map.t; branch_refused: (Operation.t * 'error list) Operation_hash.Map.t; branch_delayed: (Operation.t * 'error list) Operation_hash.Map.t; } let empty = { applied = [] ; refused = Operation_hash.Map.empty ; branch_refused = Operation_hash.Map.empty ; branch_delayed = Operation_hash.Map.empty ; } let map f r = { applied = r.applied; refused = Operation_hash.Map.map f r.refused ; branch_refused = Operation_hash.Map.map f r.branch_refused ; branch_delayed = Operation_hash.Map.map f r.branch_delayed ; } let encoding error_encoding = let open Data_encoding in let operation_encoding = merge_objs (obj1 (req "hash" Operation_hash.encoding)) (dynamic_size Operation.encoding) in let refused_encoding = merge_objs (obj1 (req "hash" Operation_hash.encoding)) (merge_objs (dynamic_size Operation.encoding) (obj1 (req "error" error_encoding))) in let build_list map = Operation_hash.Map.bindings map in let build_map list = List.fold_right (fun (k, e) m -> Operation_hash.Map.add k e m) list Operation_hash.Map.empty in conv (fun { applied ; refused ; branch_refused ; branch_delayed } -> (applied, build_list refused, build_list branch_refused, build_list branch_delayed)) (fun (applied, refused, branch_refused, branch_delayed) -> let refused = build_map refused in let branch_refused = build_map branch_refused in let branch_delayed = build_map branch_delayed in { applied ; refused ; branch_refused ; branch_delayed }) (obj4 (req "applied" (list operation_encoding)) (req "refused" (list refused_encoding)) (req "branch_refused" (list refused_encoding)) (req "branch_delayed" (list refused_encoding))) let operations t = let ops = List.fold_left (fun acc (h, op) -> Operation_hash.Map.add h op acc) Operation_hash.Map.empty t.applied in let ops = Operation_hash.Map.fold (fun h (op, _err) acc -> Operation_hash.Map.add h op acc) t.branch_delayed ops in let ops = Operation_hash.Map.fold (fun h (op, _err) acc -> Operation_hash.Map.add h op acc) t.branch_refused ops in ops