X-Git-Url: https://git.xandkar.net/?a=blobdiff_plain;f=src%2Fhope_option.erl;h=2bd9e7b05180a436993afd3d54ff5e2d563565c2;hb=HEAD;hp=572162881ec9d85c7d6728ceff7b04c56666758a;hpb=b69220d7a75faba9743d5b89b6fa40443cd39eec;p=hope.git diff --git a/src/hope_option.erl b/src/hope_option.erl index 5721628..2bd9e7b 100644 --- a/src/hope_option.erl +++ b/src/hope_option.erl @@ -7,14 +7,20 @@ ]). -export( - [ put/2 - , get/2 - , return/1 + % Generic monad interface + [ return/1 , map/2 - , iter/2 , pipe/2 + + % Specific to hope_option:t() + , return/2 + , put/2 + , get/2 + , iter/2 , of_result/1 , of_undefined/1 + , to_undefined/1 + , validate/2 ]). @@ -27,10 +33,7 @@ -spec put(A, fun((A) -> boolean())) -> t(A). put(X, F) -> - case F(X) - of true -> {some, X} - ; false -> none - end. + return(X, F). -spec get(t(A), Default :: A) -> A. @@ -42,15 +45,26 @@ get(none , Y) -> Y. return(X) -> {some, X}. +-spec return(A, fun((A) -> boolean())) -> + t(A). +return(X, Condition) -> + case Condition(X) + of true -> {some, X} + ; false -> none + end. + -spec map(t(A), fun((A) -> (B))) -> t(B). map({some, X}, F) -> {some, F(X)}; map(none , _) -> none. --spec iter(t(A), fun((A) -> (ok))) -> - ok. -iter({some, X}, F) -> ok = F(X); -iter(none , _) -> ok. +-spec iter(t(A), fun((A) -> (any()))) -> + {}. +iter({some, X}, F) -> + _ = F(X), + {}; +iter(none, _) -> + {}. -spec pipe([fun((A) -> t(B))], A) -> t(B). @@ -71,3 +85,18 @@ of_result({error, _}) -> none. t(A). of_undefined(undefined) -> none; of_undefined(X) -> {some, X}. + +-spec to_undefined(t(A)) -> + undefined | A. +to_undefined(none) -> undefined; +to_undefined({some, X}) -> X. + +-spec validate(t(A), fun((A) -> boolean())) -> + t(A). +validate(none, _) -> + none; +validate({some, X}=T, F) -> + case F(X) + of false -> none + ; true -> T + end.