blob: 977886551747e8d4b27448848dc8aa70fff2d155 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
(.module:
lux
(lux (control [monoid #+ Monoid])))
(def: #export (compose f g)
{#.doc "Function composition."}
(All [a b c]
(-> (-> b c) (-> a b) (-> a c)))
(|>> g f))
(def: #export (const c)
{#.doc "Create constant functions."}
(All [a b] (-> a (-> b a)))
(function [_] c))
(def: #export (flip f)
{#.doc "Flips the order of the arguments of a function."}
(All [a b c]
(-> (-> a b c) (-> b a c)))
(function [x y] (f y x)))
(struct: #export Monoid<Function> (All [a] (Monoid (-> a a)))
(def: identity id)
(def: compose ..compose))
|