Rand Stats

Monad-Result

zef:rawleyfowler

Monad-Result

SparrowCI

An implementation of the result monad from OCaml. This allows the developer to completely avoid exceptions. Note the result type is not generic, and cannot be statically typed. I think this makes it more flexible overall, compared to OCaml's result monad. (Gradual typing ftw)!

How to use (default)

use Monad::Result;

sub my-error-causing-function($value --> Result) {
  return Monad::Result.error('Bad value!') if $value eq 'bad'
  ok('Value was good!');
}

# Bind operator: >>=:
my-error-causing-function('bad') >>=: -> $value {
  say $value; # Is not called because this is not bindable (it is an error!)
  return Monad::Result.ok($value);
};

my-error-causing-function('abc') >>=: -> $value {
  say $value; # Is said because this is bindable, it is OK!
  return Monad::Result.ok($value);
};

# Map operator: >>=?
# Since this call results in OK, we can map it!
my $result = (my-error-causing-function('abc') >>=? -> $value {
  $value ~ ' HELLO WORLD';
}); # Results Ok('abc HELLO WORLD');

say $result.is-ok; # True
# NOTE UNWRAP IS DANGEROUS (In this case we know it's okay though!)
say $result.unwrap; # 'abc HELLO WORLD';

How to use (subs)

Subs exist as a separate import, because they interfere with a lot of common packages.

use Monad::Result :subs;

sub my-error-causing-function($value --> Result) {
  return error('Bad value!') if $value eq 'bad'
  ok('Value was good!');
}

# Bind operator: >>=:
my-error-causing-function('bad') >>=: -> $value {
  say $value; # Is not called because this is not bindable (it is an error!)
  return ok($value);
};

my-error-causing-function('abc') >>=: -> $value {
  say $value; # Is said because this is bindable, it is OK!
  return ok($value);
};

# Map operator: >>=?
# Since this call results in OK, we can map it!
my $result = (my-error-causing-function('abc') >>=? -> $value {
  $value ~ ' HELLO WORLD';
}); # Results Ok('abc HELLO WORLD');

say $result.is-ok; # True
# NOTE UNWRAP IS DANGEROUS!
say $result.unwrap; # 'abc HELLO WORLD';

How to install

zef install Monad-Result

LICENSE

Monad::Result is provided under the Artistic-2.0 license.