package travesty
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=be89ec1c96fedcc47362568b359aa6b8d3fefb8b86f70133dd1a75ca72476807
sha512=19616b0a5fddd5725fdf7ab160e9f89d243f0dbaaaf53ba455bfbac2790cb07811862ecc5ada81be35a06869a987dcc149f24a7e84f461222216d45fe0036ca2
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.
always x is true.
never x is false.
Pointwise liftings of operators
These complement Base.Fn.non.
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 *)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 *)f &&& g is conj f g.
f ||| g is disj f g.
Miscellaneous combinators
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.