package travesty

  1. Overview
  2. Docs
Traversable containers, monad extensions, and more

Install

Dune Dependency

Authors

Maintainers

Sources

travesty-0.7.2.tbz
sha256=49d43ea0e9cef32d493fcc1561fc7480c55d9a2490700e487f4d5c3aff562d61
sha512=1cd77071adfb4583d0fcd27469b97bc64b7278761949aaaf415768aec14f6a1243e14575155c75033a5141a0320b4f56687381dc2bc56432a5ea63ea8613d968

doc/travesty.base_exts/Travesty_base_exts/Fn/index.html

Module Travesty_base_exts.FnSource

Miscellaneous function combinators.

Fn contains various higher-order functions in the style of Base's Fn module.

Constant predicates

These are convenience shorthands for Base.Fn.const.

Sourceval always : 'a -> bool

always x is true.

Sourceval never : 'a -> bool

never x is false.

Pointwise liftings of operators

These complement Base.Fn.non.

Sourceval conj : ('a -> bool) -> ('a -> bool) -> 'a -> bool

conj f g lifts && over predicates f and g. It is short-circuiting: g is never called if f returns false.

Examples:

  let is_zero = Int.(conj is_non_negative is_non_positive)
  (* Short-circuiting: *)
  conj always (fun () -> failwith "oops") () ;
  (* --> exception *)
  conj never (fun () -> failwith "oops") ()

  (* --> false *)
Sourceval disj : ('a -> bool) -> ('a -> bool) -> 'a -> bool

disj f g lifts || over predicates f and g. It is short-circuiting: g is never called if f returns true.

Examples:

  let is_not_zero = Int.(disj is_negative is_positive)
  (* Short-circuiting: *)
  disj never (fun () -> failwith "oops") () ;
  (* --> exception *)
  disj always (fun () -> failwith "oops") ()

  (* --> false *)
Sourceval (&&&) : ('a -> bool) -> ('a -> bool) -> 'a -> bool

f &&& g is conj f g.

Sourceval (|||) : ('a -> bool) -> ('a -> bool) -> 'a -> bool

f ||| g is disj f g.

Miscellaneous combinators

Sourceval on : ('a -> 'b) -> 'a -> 'a -> f:('b -> 'b -> 'r) -> 'r

on lift x y ~f lifts a binary function f using the lifter lift. It does the same thing as the `on` function from Haskell, but with arguments flipped to make sense without infixing.

Effectively, it's Base.Comparable.lift, but with a slightly different signature.

Example:

  let ints = on fst ~f:Int.equal (42, "banana") (42, "apple") in
  let strs = on snd ~f:String.equal (42, "banana") (42, "apple") in
  (ints, strs)

  (* --> true, false *)

F# style function composition operator

This is in a separate module to reduce the ambiguity caused by its use.

Sourcemodule Compose_syntax : sig ... end
OCaml

Innovation. Community. Security.