Do Notation

A do notation syntax allows writing code in a more declarative style, similar to the do notation in other programming languages. It provides a way to define variables and perform operations on them using functions like bind and let, piping the returned values into a context object.

Do

Initiates a do notation for the Option type.

import { Option } from 'funkcia';

declare function findUserById(id: string): Option;
declare function getUserScore(user: User): Option;
declare function getUserLevel(user: User, score: UserScore): UserLevel;

//        β”Œβ”€β”€β”€ Option
//        β–Ό
const userLevel = Option.Do
  .bind('user', () => findUserById('user_123'))
  .bind('score', (ctx) => getUserScore(ctx.user))
  .map((ctx) => getUserLevel(ctx.user, ctx.score));
//       β–²
//       └─── { user: User; score: UserScore }

bindTo

Initiates a do notation with the current Option, binding it to a context object with the provided key.

bind

Binds an Option to the context object in a do notation.

If the Option is Some, the value is assigned to the key in the context object. If the Option is None, the parent Option running the Do simulation becomes a None.

let

Binds a raw value to the context object in a Do-notation.

If the value is not nullable, the value is assigned to the key in the context object. If the value is null or undefined, the parent Option running the Do simulation becomes a None.

Understanding the do notation

Do notation provides a clean way to handle sequences of operations that might fail, where each step depends on the success of all previous steps. Think of it as a chain of dominoes - if any domino falls incorrectly (returns None), the entire sequence stops.

Here's a practical example:

The equivalent code would be much more nested:

Or with intermediate variables:

Last updated

Was this helpful?