package core
- Overview
- No Docs
You can search for identifiers within the package.
in-package search v0.2.0
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Industrial strength alternative to OCaml's standard library
Install
dune-project
Dependency
Authors
Maintainers
Sources
v0.17.1.tar.gz
md5=743a141234e04210e295980f7a78a6d9
sha512=61b415f4fb12c78d30649fff1aabe3a475eea926ce6edb7774031f4dc7f37ea51f5d9337ead6ec73cd93da5fd1ed0f2738c210c71ebc8fe9d7f6135a06bd176f
doc/src/core/set_once.ml.html
Source file set_once.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 105module Stable = struct open Stable_internal module T = struct type 'a t = { mutable value : 'a Option.t ; mutable set_at : Source_code_position.Stable.V1.t [@compare.ignore] [@equal.ignore] } [@@deriving compare, equal] end module V1 = struct module Format = struct type 'a t = 'a option ref [@@deriving bin_io, sexp] end include T let of_format (v1 : 'a Format.t) : 'a t = { value = !v1; set_at = [%here] } let to_format (t : 'a t) : 'a Format.t = ref t.value include Binable.Of_binable1_without_uuid [@alert "-legacy"] (Format) (struct include T let of_binable = of_format let to_binable = to_format end) include Sexpable.Of_sexpable1 (Format) (struct include T let of_sexpable = of_format let to_sexpable = to_format end) end end open! Import module Unstable = Stable.V1 open Stable.T type 'a t = 'a Stable.T.t [@@deriving compare, equal] let sexp_of_t sexp_of_a { value; set_at } = match value with | None -> [%message "unset"] | Some value -> [%message "" (value : a) ~set_at:(set_at |> Source_code_position.to_string)] ;; let invariant invariant_a t = match t.value with | None -> () | Some a -> invariant_a a ;; let create () = { value = None; set_at = [%here] } let set_internal t here value = t.value <- Some value; t.set_at <- here ;; let set_if_none t here value = if Option.is_none t.value then set_internal t here value let set t here value = if Option.is_none t.value then ( set_internal t here value; Ok ()) else Or_error.error_s [%message "[Set_once.set_exn] already set" ~setting_at:(here : Source_code_position.t) ~previously_set_at:(t.set_at : Source_code_position.t)] ;; let set_exn t here value = Or_error.ok_exn (set t here value) let get t = t.value let get_exn (t : _ t) here = match t.value with | Some a -> a | None -> raise_s [%message "[Set_once.get_exn] unset" ~at:(here : Source_code_position.t)] ;; let is_none t = Option.is_none t.value let is_some t = Option.is_some t.value let iter t ~f = Option.iter t.value ~f module Optional_syntax = struct module Optional_syntax = struct let is_none = is_none let unsafe_value t = get_exn t [%here] end end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>