package tezos-protocol-alpha
Tezos protocol alpha package
Install
Dune Dependency
Authors
Maintainers
Sources
octez-19.0.tar.gz
sha256=c6df840ebbf115e454db949028c595bec558a59a66cade73b52a6d099d6fa4d4
sha512=d8aee903b9fe130d73176bc8ec38b78c9ff65317da3cb4f3415f09af0c625b4384e7498201fdb61aa39086a7d5d409d0ab3423f9bc3ab989a680cf444a79bc13
doc/src/tezos_raw_protocol_alpha/sc_rollups.ml.html
Source file sc_rollups.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
(*****************************************************************************) (* *) (* Open Source License *) (* Copyright (c) 2021 Nomadic Labs <contact@nomadic-labs.com> *) (* Copyright (c) 2022 Trili Tech, <contact@trili.tech> *) (* *) (* 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. *) (* *) (*****************************************************************************) module PVM = struct type boot_sector = string module type S = sig val parse_boot_sector : string -> boot_sector option val pp_boot_sector : Format.formatter -> boot_sector -> unit include Sc_rollup_PVM_sig.S end type ('state, 'proof, 'output) implementation = (module S with type state = 'state and type proof = 'proof and type output_proof = 'output) type t = Packed : ('state, 'proof, 'output) implementation -> t [@@unboxed] end module Kind = struct (* Each time we add a data constructor to [t], we also need: - to extend [Sc_rollups.all] with this new constructor ; - to update [Sc_rollups.of_string] and [encoding] ; - to update [Sc_rollups.wrapped_proof] and [wrapped_proof_encoding]. *) type t = Example_arith | Wasm_2_0_0 | Riscv let all = [Example_arith; Wasm_2_0_0; Riscv] let to_string = function | Example_arith -> "arith" | Wasm_2_0_0 -> "wasm_2_0_0" | Riscv -> "riscv" let of_string = function | "arith" -> Some Example_arith | "wasm_2_0_0" -> Some Wasm_2_0_0 | "riscv" -> Some Riscv | _ -> None let encoding = Data_encoding.string_enum @@ List.map (fun k -> (to_string k, k)) all let pp fmt = function | Example_arith -> Format.pp_print_string fmt "arith" | Wasm_2_0_0 -> Format.pp_print_string fmt "wasm_2_0_0" | Riscv -> Format.pp_print_string fmt "riscv" let equal x y = match (x, y) with | Example_arith, Example_arith -> true | Wasm_2_0_0, Wasm_2_0_0 -> true | Riscv, Riscv -> true | _ -> false let example_arith_pvm = PVM.Packed (module Sc_rollup_arith.Protocol_implementation) let wasm_2_0_0_pvm = PVM.Packed (module Sc_rollup_wasm.V2_0_0.Protocol_implementation) let riscv_pvm = PVM.Packed (module Sc_rollup_riscv.Protocol_implementation) let reference_initial_state_hash_of = function | Example_arith -> Sc_rollup_arith.reference_initial_state_hash | Wasm_2_0_0 -> Sc_rollup_wasm.V2_0_0.reference_initial_state_hash | Riscv -> Sc_rollup_riscv.reference_initial_state_hash let pvm_of = function | Example_arith -> example_arith_pvm | Wasm_2_0_0 -> wasm_2_0_0_pvm | Riscv -> riscv_pvm let no_proof_machine_of : t -> (module Sc_rollup_machine_no_proofs.S) = function | Example_arith -> (module Sc_rollup_machine_no_proofs.Arith) | Wasm_2_0_0 -> (module Sc_rollup_machine_no_proofs.Wasm) | Riscv -> (module Sc_rollup_machine_no_proofs.Riscv) end let genesis_state_hash_of ~boot_sector kind = let open Lwt_syntax in let (module Machine) = Kind.no_proof_machine_of kind in let empty = Sc_rollup_machine_no_proofs.empty_tree () in let* tree = Machine.initial_state ~empty in let* initial_hash = Machine.state_hash tree in assert ( Sc_rollup_repr.State_hash.( initial_hash = Kind.reference_initial_state_hash_of kind)) ; let* tree = Machine.install_boot_sector tree boot_sector in Machine.state_hash tree
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>