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 Result type.
import { AsyncResult } from 'funkcia';
declare function findUserById(id: string): AsyncResult;
declare function calculateUserScore(user: User): AsyncResult;
declare function rankUserLevel(user: User, score: UserScore): AsyncResult;
// ββββ AsyncResult
// βΌ
const userLevel = AsyncResult.Do
.bind('user', () => findUserById('user_123'))
.bind('score', (ctx) => calculateUserScore(ctx.user))
.map((ctx) => rankUserLevel(ctx.user, ctx.score));
// β²
// ββββ { user: User; score: UserScore }bindTo
Initiates a do notation with the current AsyncResult, binding it to a context object with the provided key.
bind
Binds an AsyncResult to the context object in a do notation.
If the Result is Ok, the value is assigned to the key in the context object. If the Result is Error, the parent Result running the Do simulation becomes an Error.
let
Ensure you know what you're doing when binding a promise using let, otherwise a thrown exception will not be caught and break your app
Binds non-rejecting promise to the context object in a do notation.
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?