12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697(*****************************************************************************)(* *)(* Open Source License *)(* Copyright (c) 2018 Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)(* Copyright (c) 2020 Metastate AG <hello@metastate.dev> *)(* Copyright (c) 2018-2022 Nomadic Labs, <contact@nomadic-labs.com> *)(* *)(* Permission is hereby granted, free of charge, to any person obtaining a *)(* copy of this software and associated documentation files (the "Software"),*)(* to deal in the Software without restriction, including without limitation *)(* the rights to use, copy, modify, merge, publish, distribute, sublicense, *)(* and/or sell copies of the Software, and to permit persons to whom the *)(* Software is furnished to do so, subject to the following conditions: *)(* *)(* The above copyright notice and this permission notice shall be included *)(* in all copies or substantial portions of the Software. *)(* *)(* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR*)(* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *)(* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL *)(* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER*)(* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *)(* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *)(* DEALINGS IN THE SOFTWARE. *)(* *)(*****************************************************************************)type'protocol_operationoperation={hash:Operation_hash.t;raw:Operation.t;protocol:'protocol_operation;count_successful_prechecks:int;}letincrement_successful_precheckop=(* We avoid {op with ...} to get feedback from the compiler if the record
type is extended/modified in the future. *){hash=op.hash;raw=op.raw;protocol=op.protocol;count_successful_prechecks=op.count_successful_prechecks+1;}(** Doesn't depend on heavy [Registered_protocol.T] for testability. *)letsafe_binary_of_bytes(encoding:'aData_encoding.t)(bytes:bytes):'atzresult=letopenResult_syntaxinmatchData_encoding.Binary.of_bytes_optencodingbyteswith|None->tzfailValidation_errors.Parse_error|Someprotocol_data->returnprotocol_datamoduletypePARSER=sigtypeprotocol_operationvalparse:Operation_hash.t->Operation.t->protocol_operationoperationtzresultendmoduleMakeParser(Proto:Tezos_protocol_environment.PROTOCOL):PARSERwithtypeprotocol_operation=Proto.operation=structtypeprotocol_operation=Proto.operationletparse_unsafe(proto:bytes):Proto.operation_datatzresult=safe_binary_of_bytesProto.operation_data_encodingprotoletparsehash(raw:Operation.t)=letopenResult_syntaxinletsize=Data_encoding.Binary.lengthOperation.encodingrawinifsize>Proto.max_operation_data_lengththentzfail(Validation_errors.Oversized_operation{size;max=Proto.max_operation_data_length})elselet+protocol_data=parse_unsaferaw.protoin{hash;raw;protocol={Proto.shell=raw.Operation.shell;protocol_data};(* When an operation is parsed, we assume that it has never been
successfully prechecked. *)count_successful_prechecks=0;}endmoduleInternal_for_tests=structletto_raw{raw;_}=rawlethash_of{hash;_}=hashletmake_operationopophdata=(* When we build an operation, we assume that it has never been
successfully prechecked. *){hash=oph;raw=op;protocol=data;count_successful_prechecks=0}letsafe_binary_of_bytes=safe_binary_of_bytesend