package irmin
Irmin, a distributed database that follows the same design principles as Git
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-3.5.2.tbz
sha256=2a1e6a7577e498fbfeb678d666da210dc48d1344637e8ecb653e1dd88c640b5f
sha512=3fb6f49a1af2f8bab1df5b6f5affaaa09f09fe892a08eb2d9de58138e56646d4a6797f3c087b22875e36e3411218ab2435fe5437ac78f323dd661932af021fad
doc/src/irmin/watch_intf.ml.html
Source file watch_intf.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
(* * Copyright (c) 2013-2022 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. *) module type S = sig (** {1 Watch Helpers} *) type key (** The type for store keys. *) type value (** The type for store values. *) type watch (** The type for watch handlers. *) type t (** The type for watch state. *) val stats : t -> int * int (** [stats t] is a tuple [(k,a)] represeting watch stats. [k] is the number of single key watchers for the store [t] and [a] the number of global watchers for [t]. *) val notify : t -> key -> value option -> unit Lwt.t (** Notify all listeners in the given watch state that a key has changed, with the new value associated to this key. [None] means the key has been removed. *) val v : unit -> t (** Create a watch state. *) val clear : t -> unit Lwt.t (** Clear all register listeners in the given watch state. *) val watch_key : t -> key -> ?init:value -> (value Diff.t -> unit Lwt.t) -> watch Lwt.t (** Watch a given key for changes. More efficient than {!watch}. *) val watch : t -> ?init:(key * value) list -> (key -> value Diff.t -> unit Lwt.t) -> watch Lwt.t (** Add a watch handler. To watch a specific key, use {!watch_key} which is more efficient. *) val unwatch : t -> watch -> unit Lwt.t (** Remove a watch handler. *) val listen_dir : t -> string -> key:(string -> key option) -> value:(key -> value option Lwt.t) -> (unit -> unit Lwt.t) Lwt.t (** Register a thread looking for changes in the given directory and return a function to stop watching and free up resources. *) end module type Sigs = sig module type S = S (** The signature for watch helpers. *) val workers : unit -> int (** [workers ()] is the number of background worker threads managing event notification currently active. *) type hook = int -> string -> (string -> unit Lwt.t) -> (unit -> unit Lwt.t) Lwt.t (** The type for watch hooks. *) val none : hook (** [none] is the hooks which asserts false. *) val set_listen_dir_hook : hook -> unit (** Register a function which looks for file changes in a directory and return a function to stop watching. It is probably best to use {!Irmin_watcher.hook} there. By default, it uses {!none}. *) (** [Make] builds an implementation of watch helpers. *) module Make (K : Type.S) (V : Type.S) : S with type key = K.t and type value = V.t end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>