blob: a6df64891d6ea15808a2b653f89a45684ffecbfe (
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> (Monoid (All [a] (-> a a)))
(def: identity id)
(def: compose ;;compose))
|