package irmin
Irmin, a distributed database that follows the same design principles as Git
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-2.9.1.tbz
sha256=16003a8a873737b0a8ae2a940399b14754c5c2ba506e4511b96df4473e912783
sha512=64682e67c1e9f6b6f6a5f017da7c0d7e5316e2dd139ad8ad7ad43b73003d827fb9f3141c10469986dee47849687c841a297b91d08186f72268c41e026810a647
doc/src/irmin/slice.ml.html
Source file slice.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
(* * Copyright (c) 2013-2017 Thomas Gazagnaire <thomas@gazagnaire.org> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. *) include Slice_intf module Make (Contents : Contents.STORE) (Node : Node.STORE) (Commit : Commit.STORE) = struct type contents = Contents.Key.t * Contents.Val.t [@@deriving irmin] type node = Node.Key.t * Node.Val.t [@@deriving irmin] type commit = Commit.Key.t * Commit.Val.t [@@deriving irmin] type value = [ `Contents of contents | `Node of node | `Commit of commit ] [@@deriving irmin] type t = { mutable contents : contents list; mutable nodes : node list; mutable commits : commit list; } [@@deriving irmin] let empty () = Lwt.return { contents = []; nodes = []; commits = [] } let add t = function | `Contents c -> t.contents <- c :: t.contents; Lwt.return_unit | `Node n -> t.nodes <- n :: t.nodes; Lwt.return_unit | `Commit c -> t.commits <- c :: t.commits; Lwt.return_unit let iter t f = Lwt.join [ Lwt_list.iter_p (fun c -> f (`Contents c)) t.contents; Lwt_list.iter_p (fun n -> f (`Node n)) t.nodes; Lwt_list.iter_p (fun c -> f (`Commit c)) t.commits; ] end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>