Use empty tuple as unit type, for all side-effects.
[hope.git] / src / hope_option.erl
CommitLineData
e492ea13
SK
1-module(hope_option).
2
b69220d7 3-behavior(hope_gen_monad).
2a40de4f 4
3b156801
SK
5-export_type(
6 [ t/1
7 ]).
e492ea13 8
3b156801 9-export(
1c003d17
SK
10 % Generic monad interface
11 [ return/1
3b156801 12 , map/2
4af0774b 13 , pipe/2
1c003d17
SK
14
15 % Specific to hope_option:t()
16 , return/2
17 , put/2
18 , get/2
19 , iter/2
2497062c 20 , of_result/1
f2e1fffc 21 , of_undefined/1
352ddeb4 22 , validate/2
3b156801 23 ]).
e492ea13
SK
24
25
3b156801
SK
26-type t(A) ::
27 none
28 | {some, A}
29 .
e492ea13
SK
30
31
ed9905af
SK
32-spec put(A, fun((A) -> boolean())) ->
33 t(A).
e492ea13 34put(X, F) ->
9a5e47fa 35 return(X, F).
e492ea13 36
ed9905af
SK
37-spec get(t(A), Default :: A) ->
38 A.
e492ea13
SK
39get({some, X}, _) -> X;
40get(none , Y) -> Y.
41
4af0774b
SK
42-spec return(A) ->
43 {some, A}.
44return(X) ->
45 {some, X}.
46
9a5e47fa
SK
47-spec return(A, fun((A) -> boolean())) ->
48 t(A).
49return(X, Condition) ->
50 case Condition(X)
51 of true -> {some, X}
52 ; false -> none
53 end.
54
ed9905af
SK
55-spec map(t(A), fun((A) -> (B))) ->
56 t(B).
e492ea13
SK
57map({some, X}, F) -> {some, F(X)};
58map(none , _) -> none.
27a4f25f 59
0ed4baeb 60-spec iter(t(A), fun((A) -> (any()))) ->
4744fed9 61 {}.
0ed4baeb
SK
62iter({some, X}, F) ->
63 _ = F(X),
4744fed9 64 {};
0ed4baeb 65iter(none, _) ->
4744fed9 66 {}.
2497062c 67
4af0774b
SK
68-spec pipe([fun((A) -> t(B))], A) ->
69 t(B).
70pipe([], X) ->
71 return(X);
72pipe([F|Fs], X) ->
73 case F(X)
74 of none -> none
75 ; {some, Y} -> pipe(Fs, Y)
76 end.
77
2497062c
SK
78-spec of_result(hope_result:t(A, _B)) ->
79 t(A).
80of_result({ok, X}) -> {some, X};
81of_result({error, _}) -> none.
f2e1fffc
SK
82
83-spec of_undefined(undefined | A) ->
84 t(A).
85of_undefined(undefined) -> none;
86of_undefined(X) -> {some, X}.
352ddeb4
SK
87
88-spec validate(t(A), fun((A) -> boolean())) ->
89 t(A).
90validate(none, _) ->
91 none;
92validate({some, X}=T, F) ->
93 case F(X)
94 of false -> none
95 ; true -> T
96 end.
This page took 0.029721 seconds and 4 git commands to generate.