NodeRuntime.ts
NodeRuntime.ts overview
Section titled “NodeRuntime.ts overview”Node.js process runner for Effect programs.
This module exports runMain, which runs one Effect as the main process
fiber in Node.js. It reuses the shared Node runtime runner, including its
error reporting, SIGINT / SIGTERM interruption, and optional teardown
behavior.
Since v4.0.0
Exports Grouped by Category
Section titled “Exports Grouped by Category”running
Section titled “running”runMain
Section titled “runMain”Helps you run a main effect with built-in error handling, logging, and signal management.
When to use
Use to run a Node.js application’s main Effect with structured error handling, log management, interrupt support, or advanced teardown capabilities.
Details
This function launches an Effect as the main entry point, setting exit codes based on success or failure, handling interrupts (e.g., Ctrl+C), and optionally logging errors. By default, it logs errors and uses a “pretty” format, but both behaviors can be turned off. You can also provide custom teardown logic to finalize resources or produce different exit codes.
The optional configuration object can include:
disableErrorReporting: Turn off automatic error logging.teardown: Provide custom finalization logic.
Signature
declare const runMain: { (options?: { readonly disableErrorReporting?: boolean | undefined readonly teardown?: Runtime.Teardown | undefined }): <E, A>(effect: Effect<A, E>) => void <E, A>( effect: Effect<A, E>, options?: { readonly disableErrorReporting?: boolean | undefined; readonly teardown?: Runtime.Teardown | undefined } ): void}Since v4.0.0