Skip to content

Commit

Permalink
basic result type and functions
Browse files Browse the repository at this point in the history
  • Loading branch information
tsloughter committed Jan 15, 2018
1 parent 72fd966 commit 3a02c90
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 1 deletion.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
_build
_checkouts
.rebar3
rebar3.crashdump
rebar.lock
54 changes: 54 additions & 0 deletions src/result.alp
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
{- Basic result type.
-}
module result

import_type option.option

export isOk/1, map/1, fromOption/2, andThen/2, withDefault/2

export_type result

type result 'a 'b = Ok 'a | Err 'b

let isOk r =
match r with
Ok _ -> true
| Err _ -> false

test "Applying `is_ok` to Ok x should return true" =
assert.equal (true) (is_ok (Ok 1))

let map f (Ok x) = Ok (f x)

let map _ (Err x) = Err x

test "mapping the identity function to Ok x should return Ok x" =
let f x = x in
assert.equal (Ok 1) (map f (Ok 1))

let fromOption opt e =
match opt with
Some x -> Ok x
| None -> Err e

let andThen callback (Ok value) = callback value
let andThen _ (Err msg) = Err msg

test "andThen test with Ok x" =
let f x = (Ok x) in
assert.equal (Ok 1) (andThen f (Ok 1))

test "andThen with Err x and identity function is Err x" =
let f x = (Ok x) in
assert.equal (Err "msg") (andThen f (Err "msg"))

let withDefault _ (Ok x) = x
let withDefault default (Err _) = default

test "withdefault test with Ok result" =
let f x = (Ok x) in
assert.equal (1) (withDefault 0 (f 1))

test "withdefault test with Err returning default" =
let f _ = (Err "error") in
assert.equal (0) (withDefault 0 (f 1))

0 comments on commit 3a02c90

Please sign in to comment.