package ppx_repr
PPX deriver for type representations
Install
Dune Dependency
Authors
Maintainers
Sources
repr-fuzz-0.5.0.tbz
sha256=2ed0e1dab950eeb551cbecc3bbc5ddb584b3b3e4b4e039ff3abf7bd6d5b238f9
sha512=bacfef83e5bd2b12a7ccd514ba92525030cdcf85ba1121e9456db7f327c434db599a47667ca9826ab77ed95e0f946347e027bc6c18420c6a8faabf4a491a2a7a
doc/src/ppx_repr.lib/utils.ml.html
Source file utils.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
open Ppxlib let ( >> ) f g x = g (f x) let ( >|= ) x f = List.map f x module Option = struct include Option let to_bool : unit option -> bool = function Some () -> true | None -> false end module List = struct include List (* TODO(4.10): remove *) let concat_map = let rec aux f acc = function | [] -> rev acc | x :: l -> let xs = f x in aux f (List.rev_append xs acc) l in fun ~f l -> aux f [] l let reduce ~f = function | [] -> None | [ x ] -> Some x | _ :: _ :: _ as l -> let rec aux = function | [] -> assert false | [ a; b ] -> f a b | x :: xs -> f x (aux xs) in Some (aux l) let reduce_exn ~f l = match reduce ~f l with | Some x -> x | None -> failwith "Cannot reduce empty list" end module Make (A : Ast_builder.S) : sig val compose_all : ('a -> 'a) list -> 'a -> 'a (** Left-to-right composition of a list of functions. *) val lambda : string list -> expression -> expression (** [lambda \[ "x_1"; ...; "x_n" \] e] is [fun x1 ... x_n -> e] *) val arrow : core_type list -> core_type -> core_type (** [arrow \[ "t_1"; ...; "t_n" \] u] is [t_1 -> ... -> t_n -> u] *) end = struct open A let compose_all l x = List.fold_left ( |> ) x (List.rev l) let lambda = List.map (pvar >> pexp_fun Nolabel None) >> compose_all let arrow = List.map (ptyp_arrow Nolabel) >> compose_all end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>