option-t
Version:
A toolkit of Nullable/Option/Result type implementation in ECMAScript. Their APIs are inspired by Rust's `Option<T>` and `Result<T, E>`.
24 lines (23 loc) • 1.17 kB
JavaScript
import { isNull, expectNotNull } from '../core/nullable.js';
import { ERR_MSG_TRANSFORMER_MUST_NOT_RETURN_NO_VAL_FOR_NULLABLE } from '../internal/error_message.js';
/**
* Return the result of _transformer_ with using _input_ as an argument for it if _input_ is not `null`,
* Otherwise, return `null`.
*
* * `U` must not be `Nullable<*>`.
* * If you'd like return `Nullable<*>` as `U`, use `andThen()`.
* * If the result of _transformer_ is `null`, this throw an `Error`.
*/
export async function mapAsyncForNullable(input, transformer) {
if (isNull(input)) {
return null;
}
const result = await transformer(input);
// XXX:
// If `U` is `Nullable<SomeType>`, we think naturally the returned value of this function would be
// the nested type `Nullable<Nullable<SomeType>>`. But this type means `(SomeType | null) | null`.
// So a type checker would recognize this type as `SomeType | null`. So it's flattened.
// Then the user should call `andThen` (_flatmap_) operation instead of this.
const passed = expectNotNull(result, ERR_MSG_TRANSFORMER_MUST_NOT_RETURN_NO_VAL_FOR_NULLABLE);
return passed;
}