Skip to content

Latest commit

 

History

History
54 lines (40 loc) · 1.89 KB

README.md

File metadata and controls

54 lines (40 loc) · 1.89 KB

Kleisli arrows for bifunctor IO

npm Build Status

Part of fp-ts ecosystem.

TypeScript port of KleisliIO – Kleisli arrows with bifunctor IO from great talk by John A. De Goes at LambdaConf'18 called "Blazing Fast, Pure Effects without Monads".

Please see examples for possible ways of programming with Kleisli arrows.

Installation & usage

  1. Install this module either via NPM or Yarn:
    npm i kleisli-ts
    # or
    yarn add kleisli-ts
  2. This module has a peer dependency – fp-ts, so you'll need to install it as well:
    npm i fp-ts@1
    yarn add fp-ts@1
  3. kleisli-ts provides curried functions as its main API, but you also have a convenience method getInstancesFor, which returns an API instance bound to the given monad:
    import { getInstancesFor } from 'kleisli-ts';
    import { ioEither } from 'fp-ts/lib/IOEither';
    
    const { liftK } = getInstancesFor(ioEither);
    
    const throwMe = liftK(() => { throw new Error('yay, it works'); });

Simple example

import { ioEither, URI as IOEitherURI } from 'fp-ts/lib/IOEither';

import { getInstancesFor, KleisliIO } from 'kleisli-ts/lib';
import { unsafeRunIE } from 'kleisli-ts/lib/unsafe';

const { impureVoid, liftK } = getInstancesFor(ioEither);

const k: KleisliIO<IOEitherURI, Error, void, string> = liftK(() => {
  if (Math.random() > 0.5) {
    throw new Error('oops');
  }
  return 'foo';
});
const log: KleisliIO<IOEitherURI, never, string, void> = impureVoid((s) => console.log(s));

unsafeRunIE(k.andThen(log).run());