From 2e2a40b3312ed5ba5452836999d78df4d64d5e66 Mon Sep 17 00:00:00 2001 From: Vincent Botbol Date: Tue, 6 Nov 2018 16:47:45 +0100 Subject: [PATCH] Alpha/Client: also prevent the client from parsing n times the nonces --- src/proto_alpha/lib_delegate/client_baking_lib.ml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/proto_alpha/lib_delegate/client_baking_lib.ml b/src/proto_alpha/lib_delegate/client_baking_lib.ml index 2af1433de..d76796c40 100644 --- a/src/proto_alpha/lib_delegate/client_baking_lib.ml +++ b/src/proto_alpha/lib_delegate/client_baking_lib.ml @@ -110,6 +110,9 @@ let do_reveal cctxt block blocks = return_unit let reveal_block_nonces (cctxt : #Proto_alpha.full) block_hashes = + cctxt#with_lock begin fun () -> + Client_baking_nonces.load cctxt + end >>=? fun nonces -> Lwt_list.filter_map_p (fun hash -> Lwt.catch @@ -125,7 +128,7 @@ let reveal_block_nonces (cctxt : #Proto_alpha.full) block_hashes = Lwt.return_none)) block_hashes >>= fun block_infos -> filter_map_s (fun (bi : Client_baking_blocks.block_info) -> - Client_baking_nonces.find cctxt bi.hash >>=? function + match List.assoc_opt bi.hash nonces with | None -> cctxt#warning "Cannot find nonces for block %a (ignoring)@." Block_hash.pp_short bi.hash >>= fun () ->