2018-06-29 16:08:08 +04:00
|
|
|
(*****************************************************************************)
|
|
|
|
(* *)
|
|
|
|
(* Open Source License *)
|
|
|
|
(* Copyright (c) 2018 Dynamic Ledger Solutions, Inc. <contact@tezos.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. *)
|
|
|
|
(* *)
|
|
|
|
(*****************************************************************************)
|
2018-02-17 17:39:45 +04:00
|
|
|
|
|
|
|
module Context = struct
|
|
|
|
|
|
|
|
module StringMap = Map.Make(String)
|
|
|
|
|
|
|
|
type key = string list
|
|
|
|
type value = MBytes.t
|
|
|
|
|
|
|
|
type t =
|
|
|
|
| Dir of t StringMap.t
|
|
|
|
| Key of value
|
|
|
|
|
|
|
|
let empty = Dir StringMap.empty
|
|
|
|
|
|
|
|
let rec raw_get m k =
|
|
|
|
match k, m with
|
|
|
|
| [], m -> Some m
|
|
|
|
| n :: k, Dir m -> begin
|
2018-06-18 19:49:38 +04:00
|
|
|
match StringMap.find_opt n m with
|
|
|
|
| Some res -> raw_get res k
|
|
|
|
| None -> None
|
2018-02-17 17:39:45 +04:00
|
|
|
end
|
|
|
|
| _ :: _, Key _ -> None
|
|
|
|
|
|
|
|
let rec raw_set m k v =
|
|
|
|
match k, m, v with
|
|
|
|
| [], (Key _ as m), Some v ->
|
|
|
|
if m = v then None else Some v
|
|
|
|
| [], (Dir _ as m), Some v ->
|
|
|
|
if m == v then None else Some v
|
|
|
|
| [], (Key _ | Dir _), None -> Some empty
|
|
|
|
| n :: k, Dir m, _ -> begin
|
2018-06-30 14:04:06 +04:00
|
|
|
match raw_set (Option.unopt ~default:empty
|
|
|
|
(StringMap.find_opt n m)) k v with
|
2018-02-17 17:39:45 +04:00
|
|
|
| None -> None
|
2018-06-30 14:04:06 +04:00
|
|
|
| Some rm when rm = empty ->
|
|
|
|
Some (Dir (StringMap.remove n m))
|
2018-02-17 17:39:45 +04:00
|
|
|
| Some rm ->
|
2018-06-30 14:04:06 +04:00
|
|
|
Some (Dir (StringMap.add n rm m))
|
2018-02-17 17:39:45 +04:00
|
|
|
end
|
|
|
|
| _ :: _, Key _, None -> None
|
|
|
|
| _ :: _, Key _, Some _ ->
|
|
|
|
Pervasives.failwith "Mem_context.set"
|
|
|
|
|
|
|
|
let mem m k =
|
|
|
|
match raw_get m k with
|
|
|
|
| Some (Key _) -> Lwt.return_true
|
|
|
|
| Some (Dir _) | None -> Lwt.return_false
|
|
|
|
|
|
|
|
let dir_mem m k =
|
|
|
|
match raw_get m k with
|
|
|
|
| Some (Dir _) -> Lwt.return_true
|
|
|
|
| Some (Key _) | None -> Lwt.return_false
|
|
|
|
|
|
|
|
let get m k =
|
|
|
|
match raw_get m k with
|
|
|
|
| Some (Key v) -> Lwt.return_some v
|
|
|
|
| Some (Dir _) | None -> Lwt.return_none
|
|
|
|
|
|
|
|
let set m k v =
|
|
|
|
match raw_set m k (Some (Key v)) with
|
|
|
|
| None -> Lwt.return m
|
|
|
|
| Some m -> Lwt.return m
|
|
|
|
let del m k =
|
|
|
|
(* TODO assert key *)
|
|
|
|
match raw_set m k None with
|
|
|
|
| None -> Lwt.return m
|
|
|
|
| Some m -> Lwt.return m
|
|
|
|
let remove_rec m k =
|
|
|
|
match raw_set m k None with
|
|
|
|
| None -> Lwt.return m
|
|
|
|
| Some m -> Lwt.return m
|
2018-02-20 22:12:02 +04:00
|
|
|
let copy m ~from ~to_ =
|
|
|
|
match raw_get m from with
|
|
|
|
| None -> Lwt.return_none
|
|
|
|
| Some v -> Lwt.return (raw_set m to_ (Some v))
|
2018-02-17 17:39:45 +04:00
|
|
|
|
|
|
|
let fold m k ~init ~f =
|
|
|
|
match raw_get m k with
|
|
|
|
| None -> Lwt.return init
|
|
|
|
| Some (Key _) -> Lwt.return init
|
|
|
|
| Some (Dir m) ->
|
|
|
|
StringMap.fold
|
|
|
|
(fun n m acc ->
|
|
|
|
acc >>= fun acc ->
|
|
|
|
match m with
|
|
|
|
| Key _ -> f (`Key (k @ [n])) acc
|
|
|
|
| Dir _ -> f (`Dir (k @ [n])) acc)
|
|
|
|
m (Lwt.return init)
|
|
|
|
|
|
|
|
let rec pp ppf m =
|
|
|
|
match m with
|
|
|
|
| Key s -> Format.fprintf ppf "%s" (MBytes.to_string s)
|
|
|
|
| Dir m ->
|
|
|
|
StringMap.iter
|
|
|
|
(fun n m ->
|
|
|
|
match m with
|
|
|
|
| Key s ->
|
|
|
|
Format.fprintf ppf "- %s: %s@ " n (MBytes.to_string s)
|
|
|
|
| Dir m ->
|
|
|
|
Format.fprintf ppf "- %s:@[<v 2>@ %a@]@ " n pp (Dir m))
|
|
|
|
m
|
|
|
|
|
|
|
|
let dump m = Format.eprintf "@[<v>%a@]" pp m
|
|
|
|
|
|
|
|
let set_protocol _ _ = assert false
|
|
|
|
|
|
|
|
let fork_test_chain _ ~protocol:_ ~expiration:_ = assert false
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
include Tezos_protocol_environment.Make(Context)
|