package odoc
OCaml Documentation Generator
Install
dune-project
Dependency
Authors
Maintainers
Sources
odoc-3.1.0.tbz
sha256=355b3cfff4934903cbaed8b51ce35e333e8609932d230294200a9f2d42ffa914
sha512=f78318d0a16164a9cd16ee02f611c2e00d32b772fe38e992d6db6ec94b1c00cd9c377fbfe64031b8f245e57b2f3aac9364108327e7f1693533ddcff94c476e05
doc/src/odoc.odoc_utils/odoc_list.ml.html
Source file odoc_list.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
include List let rec concat_map_sep ~sep ~f = function | [] -> [] | [ x ] -> f x | x :: xs -> let hd = f x in let tl = concat_map_sep ~sep ~f xs in hd @ (sep :: tl) (* Since 4.10 *) let concat_map f l = let rec aux f acc = function | [] -> rev acc | x :: l -> let xs = f x in aux f (rev_append xs acc) l in aux f [] l (** @raise Failure if the list is empty. *) let rec last = function | [] -> failwith "Odoc_utils.List.last" | [ x ] -> x | _ :: tl -> last tl (* Since 4.10. Copied ocaml/ocaml *) let rec find_map f = function | [] -> None | x :: l -> ( match f x with Some _ as result -> result | None -> find_map f l) (* Since 5.1 *) let is_empty = function [] -> true | _ :: _ -> false let rec skip_until ~p = function | [] -> [] | h :: t -> if p h then t else skip_until ~p t let split_at ~f lst = let rec loop acc = function | hd :: _ as rest when f hd -> (List.rev acc, rest) | [] -> (List.rev acc, []) | hd :: tl -> loop (hd :: acc) tl in loop [] lst
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>