53 lines
1.6 KiB
OCaml
53 lines
1.6 KiB
OCaml
(**************************************************************************)
|
|
(* *)
|
|
(* Copyright (c) 2014 - 2016. *)
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
(* *)
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
(* *)
|
|
(**************************************************************************)
|
|
|
|
open Tezos_hash
|
|
|
|
type t = private
|
|
| Default of Ed25519.public_key_hash
|
|
| Hash of Contract_hash.t
|
|
type contract = t
|
|
|
|
type descr = {
|
|
manager: Ed25519.public_key_hash ;
|
|
delegate: Ed25519.public_key_hash option ;
|
|
spendable: bool ;
|
|
delegatable: bool ;
|
|
script: Script_repr.t ;
|
|
}
|
|
|
|
include Compare.S with type t := contract
|
|
|
|
val default_contract : Ed25519.public_key_hash -> contract
|
|
|
|
val is_default : contract -> Ed25519.public_key_hash option
|
|
|
|
val generic_contract :
|
|
manager:Ed25519.public_key_hash ->
|
|
delegate:Ed25519.public_key_hash option ->
|
|
spendable:bool ->
|
|
delegatable:bool ->
|
|
script:Script_repr.t ->
|
|
contract
|
|
|
|
(** {2 Human readable notation} ***********************************************)
|
|
|
|
type error += Invalid_contract_notation of string
|
|
|
|
val to_b48check: contract -> string
|
|
|
|
val of_b48check: string -> contract tzresult
|
|
|
|
(** {2 Serializers} ***********************************************************)
|
|
|
|
val encoding : contract Data_encoding.t
|
|
val descr_encoding : descr Data_encoding.t
|
|
|
|
val arg : contract RPC.Arg.arg
|