90 lines
2.8 KiB
JavaScript
90 lines
2.8 KiB
JavaScript
|
import { ap as ap_ } from './Apply';
|
||
|
import { constant, flow, pipe } from './function';
|
||
|
import { map as map_ } from './Functor';
|
||
|
import * as O from './Option';
|
||
|
export function some(F) {
|
||
|
return flow(O.some, F.of);
|
||
|
}
|
||
|
export function zero(F) {
|
||
|
return constant(F.of(O.none));
|
||
|
}
|
||
|
export function fromF(F) {
|
||
|
return function (ma) { return F.map(ma, O.some); };
|
||
|
}
|
||
|
export function fromNullable(F) {
|
||
|
return flow(O.fromNullable, F.of);
|
||
|
}
|
||
|
export function fromNullableK(F) {
|
||
|
var fromNullableF = fromNullable(F);
|
||
|
return function (f) { return flow(f, fromNullableF); };
|
||
|
}
|
||
|
export function chainNullableK(M) {
|
||
|
var chainM = chain(M);
|
||
|
var fromNullableKM = fromNullableK(M);
|
||
|
return function (f) { return chainM(fromNullableKM(f)); };
|
||
|
}
|
||
|
export function fromOptionK(F) {
|
||
|
return function (f) { return flow(f, F.of); };
|
||
|
}
|
||
|
export function chainOptionK(M) {
|
||
|
var chainM = chain(M);
|
||
|
var fromOptionKM = fromOptionK(M);
|
||
|
return function (f) { return chainM(fromOptionKM(f)); };
|
||
|
}
|
||
|
export function fromPredicate(F) {
|
||
|
return function (predicate) {
|
||
|
return function (a) {
|
||
|
return F.of(O.fromPredicate(predicate)(a));
|
||
|
};
|
||
|
};
|
||
|
}
|
||
|
export function fromEither(F) {
|
||
|
return flow(O.fromEither, F.of);
|
||
|
}
|
||
|
export function match(F) {
|
||
|
return function (onNone, onSome) { return function (ma) { return F.map(ma, O.match(onNone, onSome)); }; };
|
||
|
}
|
||
|
export function matchE(M) {
|
||
|
return function (onNone, onSome) { return function (ma) { return M.chain(ma, O.match(onNone, onSome)); }; };
|
||
|
}
|
||
|
export function getOrElse(M) {
|
||
|
return function (onNone) { return function (fa) { return M.chain(fa, O.match(onNone, M.of)); }; };
|
||
|
}
|
||
|
export function map(F) {
|
||
|
return map_(F, O.Functor);
|
||
|
}
|
||
|
export function ap(F) {
|
||
|
return ap_(F, O.Apply);
|
||
|
}
|
||
|
export function chain(M) {
|
||
|
var zeroM = zero(M);
|
||
|
return function (f) { return function (ma) {
|
||
|
return M.chain(ma, O.match(function () { return zeroM(); }, f));
|
||
|
}; };
|
||
|
}
|
||
|
export function alt(M) {
|
||
|
var _some = some(M);
|
||
|
return function (second) { return function (first) { return M.chain(first, O.match(second, _some)); }; };
|
||
|
}
|
||
|
/** @deprecated */
|
||
|
export function getOptionM(M) {
|
||
|
var apM = ap(M);
|
||
|
var mapM = map(M);
|
||
|
var chainM = chain(M);
|
||
|
var altM = alt(M);
|
||
|
var foldM = matchE(M);
|
||
|
var getOrElseM = getOrElse(M);
|
||
|
var zeroM = zero(M);
|
||
|
return {
|
||
|
map: function (fa, f) { return pipe(fa, mapM(f)); },
|
||
|
ap: function (fab, fa) { return pipe(fab, apM(fa)); },
|
||
|
of: some(M),
|
||
|
chain: function (ma, f) { return pipe(ma, chainM(f)); },
|
||
|
alt: function (fa, that) { return pipe(fa, altM(that)); },
|
||
|
fold: function (fa, onNone, onSome) { return pipe(fa, foldM(onNone, onSome)); },
|
||
|
getOrElse: function (fa, onNone) { return pipe(fa, getOrElseM(onNone)); },
|
||
|
fromM: fromF(M),
|
||
|
none: function () { return zeroM(); }
|
||
|
};
|
||
|
}
|