You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
3.0 KiB
105 lines
3.0 KiB
2 months ago
|
# exit-on-epipe
|
||
|
|
||
|
Cleanly exit on pipe errors in NodeJS scripts.
|
||
|
|
||
|
NOTE: The underlying problem was addressed in 8.x NodeJS versions but the fix
|
||
|
was not backported to 6.x and other versions of NodeJS.
|
||
|
|
||
|
These errors are common in pipelines that involve NodeJS scripts. For example,
|
||
|
take a simple script that prints out 10 lines:
|
||
|
|
||
|
```js
|
||
|
for(var i = 0; i < 10; ++i) console.log(i)
|
||
|
```
|
||
|
|
||
|
NodeJS will print an error message if the output is truncated:
|
||
|
|
||
|
```bash
|
||
|
$ cat t.js
|
||
|
for(var i = 0; i < 10; ++i) console.log(i)
|
||
|
$ node --version
|
||
|
v6.11.1
|
||
|
$ node t.js | head -n 1
|
||
|
0
|
||
|
events.js:160
|
||
|
throw er; // Unhandled 'error' event
|
||
|
^
|
||
|
|
||
|
Error: write EPIPE
|
||
|
at exports._errnoException (util.js:1018:11)
|
||
|
at WriteWrap.afterWrite (net.js:800:14)
|
||
|
```
|
||
|
|
||
|
The process will cleanly exit if you require the module:
|
||
|
|
||
|
```bash
|
||
|
$ cat t.js
|
||
|
require("exit-on-epipe");
|
||
|
for(var i = 0; i < 10; ++i) console.log(i)
|
||
|
$ node t.js | head -n 1
|
||
|
0
|
||
|
```
|
||
|
|
||
|
## Installation
|
||
|
|
||
|
With [npm](https://www.npmjs.org/package/exit-on-epipe):
|
||
|
|
||
|
```bash
|
||
|
$ npm install exit-on-epipe
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
For basic scripts, requiring at the top of the source file suffices:
|
||
|
|
||
|
```js
|
||
|
require('exit-on-epipe');
|
||
|
// ... rest of source
|
||
|
```
|
||
|
|
||
|
For more advanced situations (e.g. handing other streams), call the module:
|
||
|
|
||
|
```js
|
||
|
var eoepipe = require('exit-on-epipe');
|
||
|
eoepipe(stream); // will exit process on an EPIPE error on stream
|
||
|
eoepipe(stream, handler); // will call handler() instead of process.exit
|
||
|
```
|
||
|
|
||
|
## Interface
|
||
|
|
||
|
The module exports a single function (exposed as the variable `eoepipe`).
|
||
|
|
||
|
`eoepipe(stream, bail)` will attach an error handler to `stream` which will:
|
||
|
|
||
|
- call the `bail` function if the error `.code` is `"EPIPE"` or `.errno` is `32`
|
||
|
- defer to the default behavior if there are no other error handlers
|
||
|
- noop if the error is not `EPIPE` and if there are other error handlers
|
||
|
|
||
|
If the `bail` function is not specified, `process.exit` is used.
|
||
|
|
||
|
If the `stream` parameter is not specified, no action will be taken
|
||
|
|
||
|
## Notes
|
||
|
|
||
|
The script will not perform any action if `process` or `process.stdout` are not
|
||
|
available. It is safe to use in a web page.
|
||
|
|
||
|
## License
|
||
|
|
||
|
Please consult the attached LICENSE file for details. All rights not explicitly
|
||
|
granted by the Apache 2.0 license are reserved by the Original Author.
|
||
|
|
||
|
## Badges
|
||
|
|
||
|
[![Build Status](https://travis-ci.org/SheetJS/node-exit-on-epipe.svg?branch=master)](https://travis-ci.org/SheetJS/node-exit-on-epipe)
|
||
|
|
||
|
[![npm license](https://img.shields.io/npm/l/exit-on-epipe.svg)](https://npmjs.org/package/exit-on-epipe)
|
||
|
|
||
|
[![NPM Downloads](https://img.shields.io/npm/dt/exit-on-epipe.svg)](https://npmjs.org/package/exit-on-epipe)
|
||
|
|
||
|
[![Dependencies Status](https://david-dm.org/sheetjs/node-exit-on-epipe/status.svg)](https://david-dm.org/sheetjs/node-exit-on-epipe)
|
||
|
|
||
|
[![ghit.me](https://ghit.me/badge.svg?repo=sheetjs/node-exit-on-epipe)](https://ghit.me/repo/sheetjs/node-exit-on-epipe)
|
||
|
|
||
|
[![Analytics](https://ga-beacon.appspot.com/UA-36810333-1/SheetJS/node-exit-on-epipe?pixel)](https://github.com/SheetJS/node-exit-on-epipe)
|