Hey HN,
Like many, I've often found standard error handling in JS/TS (heavy try-catch, ambiguous null returns) a bit cumbersome for representing expected failures explicitly. Inspired by Rust's Result enum (Ok(T) | Err(E)), we built ts-result.
It's a lightweight, focused TypeScript library bringing that pattern over:
Explicit Result return types for functions.
Type safety via discriminated unions and type guards (isOk/isErr).
Functional composition methods (map, andThen, orElse, etc.) to avoid deep if nesting for success/failure checks.
Modern TS practices (strict types, ESM/CJS exports).
We were evolving an internal version that started looking like Result anyway, so we decided to build a clean, open-source implementation based on the Rust API.While there are other libraries (some older, some part of larger FP ecosystems like fp-ts/effect-ts), our goal was a minimal, easy-to-adopt implementation of just the Result pattern itself.
It doesn't magically replicate Rust's ? operator or compiler guarantees, and you still need try-catch at boundaries with exception-throwing code, but we've found it helpful for adding clarity and type-safety to our core logic where specific failure states are expected domain outcomes.
Links:
GitHub (Source/Docs): https://github.com/TrylonAI/ts-result
npm (@trylonai/ts-result): https://www.npmjs.com/package/@trylonai/ts-result
We wrote a blog post detailing the motivation, our journey from internal tools, design choices, and how it compares to exceptions or larger FP libraries:
https://trylonai.github.io/ts-result/ts-result-blog-post.htm...Would love to hear your thoughts and feedback
Comments URL: https://news.ycombinator.com/item?id=43522607
Points: 2
# Comments: 0