package core
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/doubly_linked_intf.ml.html
Source file doubly_linked_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 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191(** Doubly-linked lists. Compared to other doubly-linked lists, in this one: 1. Calls to modification functions ([insert*], [move*], ...) detect if the list is being iterated over ([iter], [fold], ...), and if so raise an exception. For example, a use like the following would raise: {[ iter t ~f:(fun _ -> ... remove t e ...) ]} 2. There is a designated "front" and "back" of each list, rather than viewing each element as an equal in a ring. 3. Elements know which list they're in. Each operation that takes an [Elt.t] also takes a [t], first checks that the [Elt] belongs to the [t], and if not, raises. 4. Related to (3), lists cannot be split, though a sort of splicing is available as [transfer]. In other words, no operation will cause one list to become two. This makes this module unsuitable for maintaining the faces of a planar graph under edge insertion and deletion, for example. 5. Another property permitted by (3) and (4) is that [length] is O(1). *) open! Import module type S = sig module Elt : sig type 'a t val value : 'a t -> 'a (** pointer equality *) val equal : 'a t -> 'a t -> bool val set : 'a t -> 'a -> unit val sexp_of_t : ('a -> Base.Sexp.t) -> 'a t -> Base.Sexp.t end type 'a t [@@deriving compare, sexp, sexp_grammar] include Container.S1 with type 'a t := 'a t include Invariant.S1 with type 'a t := 'a t (** {2 Creating doubly-linked lists} *) val create : unit -> 'a t (** [of_list l] returns a doubly-linked list [t] with the same elements as [l] and in the same order (i.e., the first element of [l] is the first element of [t]). It is always the case that [l = to_list (of_list l)]. *) val of_list : 'a list -> 'a t val of_array : 'a array -> 'a t (** {2 Predicates} *) (** pointer equality *) val equal : 'a t -> 'a t -> bool val is_first : 'a t -> 'a Elt.t -> bool val is_last : 'a t -> 'a Elt.t -> bool val mem_elt : 'a t -> 'a Elt.t -> bool (** {2 Constant-time extraction of first and last elements} *) val first_elt : 'a t -> 'a Elt.t option val last_elt : 'a t -> 'a Elt.t option val first : 'a t -> 'a option val last : 'a t -> 'a option val first_exn : 'a t -> 'a val last_exn : 'a t -> 'a (** {2 Constant-time retrieval of next or previous element} *) val next : 'a t -> 'a Elt.t -> 'a Elt.t option val prev : 'a t -> 'a Elt.t -> 'a Elt.t option (** {2 Constant-time insertion of a new element} *) val insert_before : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t val insert_after : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t val insert_first : 'a t -> 'a -> 'a Elt.t val insert_last : 'a t -> 'a -> 'a Elt.t (** {2 Constant-time move of an element from and to positions in the same list} An exception is raised if [elt] is equal to [anchor]. *) val move_to_front : 'a t -> 'a Elt.t -> unit val move_to_back : 'a t -> 'a Elt.t -> unit val move_after : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit val move_before : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit (** {2 Constant-time removal of an element} *) val remove : 'a t -> 'a Elt.t -> unit val remove_first : 'a t -> 'a option val remove_last : 'a t -> 'a option val iteri : 'a t -> f:(int -> 'a -> unit) -> unit val foldi : 'a t -> init:'acc -> f:(int -> 'acc -> 'a -> 'acc) -> 'acc (** [fold_elt t ~init ~f] is the same as fold, except [f] is called with the ['a Elt.t]'s from the list instead of the contained ['a] values. Note that like other iteration functions, it is an error to mutate [t] inside the fold. If you'd like to call [remove] on any of the ['a Elt.t]'s, use [filter_inplace]. *) val fold_elt : 'a t -> init:'acc -> f:('acc -> 'a Elt.t -> 'acc) -> 'acc val foldi_elt : 'a t -> init:'acc -> f:(int -> 'acc -> 'a Elt.t -> 'acc) -> 'acc val iter_elt : 'a t -> f:('a Elt.t -> unit) -> unit val iteri_elt : 'a t -> f:(int -> 'a Elt.t -> unit) -> unit val fold_right : 'a t -> init:'acc -> f:('a -> 'acc -> 'acc) -> 'acc val fold_right_elt : 'a t -> init:'acc -> f:('a Elt.t -> 'acc -> 'acc) -> 'acc (** [find_elt t ~f] finds the first element in [t] that satisfies [f], by testing each of element of [t] in turn until [f] succeeds. *) val find_elt : 'a t -> f:('a -> bool) -> 'a Elt.t option val findi_elt : 'a t -> f:(int -> 'a -> bool) -> (int * 'a Elt.t) option (** [clear t] removes all elements from the list in constant time. *) val clear : 'a t -> unit val copy : 'a t -> 'a t (** [transfer ~src ~dst] has the same behavior as [iter src ~f:(insert_last dst); clear src] except that it runs in constant time. If [s = to_list src] and [d = to_list dst], then after [transfer ~src ~dst]: [to_list src = []] [to_list dst = d @ s] *) val transfer : src:'a t -> dst:'a t -> unit (** {2 Linear-time mapping of lists (creates a new list)} *) val map : 'a t -> f:('a -> 'b) -> 'b t val mapi : 'a t -> f:(int -> 'a -> 'b) -> 'b t val filter : 'a t -> f:('a -> bool) -> 'a t val filteri : 'a t -> f:(int -> 'a -> bool) -> 'a t val filter_map : 'a t -> f:('a -> 'b option) -> 'b t val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t (** {2 Linear-time partition of lists (creates two new lists)} *) val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t val partition_map : 'a t -> f:('a -> ('b, 'c) Either.t) -> 'b t * 'c t val partition_mapi : 'a t -> f:(int -> 'a -> ('b, 'c) Either.t) -> 'b t * 'c t (** {2 Linear-time in-place mapping of lists} *) (** [map_inplace t ~f] replaces all values [v] with [f v] *) val map_inplace : 'a t -> f:('a -> 'a) -> unit val mapi_inplace : 'a t -> f:(int -> 'a -> 'a) -> unit (** [filter_inplace t ~f] removes all elements of [t] that don't satisfy [f]. *) val filter_inplace : 'a t -> f:('a -> bool) -> unit val filteri_inplace : 'a t -> f:(int -> 'a -> bool) -> unit (** If [f] returns [None], the element is removed, else the value is replaced with the contents of the [Some] *) val filter_map_inplace : 'a t -> f:('a -> 'a option) -> unit val filter_mapi_inplace : 'a t -> f:(int -> 'a -> 'a option) -> unit (** [unchecked_iter t ~f] behaves like [iter t ~f] except that [f] is allowed to modify [t]. Adding or removing elements before the element currently being visited has no effect on the traversal. Elements added after the element currently being visited will be traversed. Elements deleted after the element currently being visited will not be traversed. Deleting the element currently being visited is an error that is not detected (presumably leading to an infinite loop). *) val unchecked_iter : 'a t -> f:('a -> unit) -> unit (** A sequence of values from the doubly-linked list. It makes an intermediate copy of the list so that the returned sequence is immune to any subsequent mutation of the original list. *) val to_sequence : 'a t -> 'a Sequence.t end module type Doubly_linked = sig module type S = S include S end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>