(**************************************************************************) (* *) (* Copyright (c) 2014 - 2017. *) (* Dynamic Ledger Solutions, Inc. *) (* *) (* All rights reserved. No warranty, explicit or implicit, provided. *) (* *) (**************************************************************************) let run (cctxt : Client_commands.full_context) ?max_priority ~delay ?min_date delegates ~endorsement ~denunciation ~baking = (* TODO really detach... *) let endorsement = if endorsement then Client_baking_blocks.monitor cctxt ?min_date ~min_heads:1 () >>=? fun block_stream -> Client_baking_endorsement.create cctxt ~delay delegates block_stream >>= fun () -> return () else return () in let denunciation = if denunciation then Client_baking_operations.monitor_endorsement cctxt >>=? fun endorsement_stream -> Client_baking_denunciation.create cctxt endorsement_stream >>= fun () -> return () else return () in let forge = if baking then begin Client_baking_blocks.monitor cctxt ?min_date ~min_heads:1 () >>=? fun block_stream -> Client_baking_operations.monitor_endorsement cctxt >>=? fun endorsement_stream -> Client_baking_forge.create cctxt ?max_priority delegates block_stream endorsement_stream >>=? fun () -> return () end else return () in denunciation >>=? fun () -> endorsement >>=? fun () -> forge