48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /// <reference types="node" />
 | |
| import { signals } from './signals.js';
 | |
| export { signals };
 | |
| /**
 | |
|  * A function that takes an exit code and signal as arguments
 | |
|  *
 | |
|  * In the case of signal exits *only*, a return value of true
 | |
|  * will indicate that the signal is being handled, and we should
 | |
|  * not synthetically exit with the signal we received. Regardless
 | |
|  * of the handler return value, the handler is unloaded when an
 | |
|  * otherwise fatal signal is received, so you get exactly 1 shot
 | |
|  * at it, unless you add another onExit handler at that point.
 | |
|  *
 | |
|  * In the case of numeric code exits, we may already have committed
 | |
|  * to exiting the process, for example via a fatal exception or
 | |
|  * unhandled promise rejection, so it is impossible to stop safely.
 | |
|  */
 | |
| export type Handler = (code: number | null | undefined, signal: NodeJS.Signals | null) => true | void;
 | |
| export declare const 
 | |
| /**
 | |
|  * Called when the process is exiting, whether via signal, explicit
 | |
|  * exit, or running out of stuff to do.
 | |
|  *
 | |
|  * If the global process object is not suitable for instrumentation,
 | |
|  * then this will be a no-op.
 | |
|  *
 | |
|  * Returns a function that may be used to unload signal-exit.
 | |
|  */
 | |
| onExit: (cb: Handler, opts?: {
 | |
|     alwaysLast?: boolean | undefined;
 | |
| } | undefined) => () => void, 
 | |
| /**
 | |
|  * Load the listeners.  Likely you never need to call this, unless
 | |
|  * doing a rather deep integration with signal-exit functionality.
 | |
|  * Mostly exposed for the benefit of testing.
 | |
|  *
 | |
|  * @internal
 | |
|  */
 | |
| load: () => void, 
 | |
| /**
 | |
|  * Unload the listeners.  Likely you never need to call this, unless
 | |
|  * doing a rather deep integration with signal-exit functionality.
 | |
|  * Mostly exposed for the benefit of testing.
 | |
|  *
 | |
|  * @internal
 | |
|  */
 | |
| unload: () => void;
 | |
| //# sourceMappingURL=index.d.ts.map
 |