116 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # duplexer3 [](https://travis-ci.org/floatdrop/duplexer3) [](https://coveralls.io/github/floatdrop/duplexer3?branch=master)
 | |
| 
 | |
| Like [duplexer2](https://github.com/deoxxa/duplexer2) but using Streams3 without readable-stream dependency
 | |
| 
 | |
| ```javascript
 | |
| var stream = require("stream");
 | |
| 
 | |
| var duplexer3 = require("duplexer3");
 | |
| 
 | |
| var writable = new stream.Writable({objectMode: true}),
 | |
|     readable = new stream.Readable({objectMode: true});
 | |
| 
 | |
| writable._write = function _write(input, encoding, done) {
 | |
|   if (readable.push(input)) {
 | |
|     return done();
 | |
|   } else {
 | |
|     readable.once("drain", done);
 | |
|   }
 | |
| };
 | |
| 
 | |
| readable._read = function _read(n) {
 | |
|   // no-op
 | |
| };
 | |
| 
 | |
| // simulate the readable thing closing after a bit
 | |
| writable.once("finish", function() {
 | |
|   setTimeout(function() {
 | |
|     readable.push(null);
 | |
|   }, 500);
 | |
| });
 | |
| 
 | |
| var duplex = duplexer3(writable, readable);
 | |
| 
 | |
| duplex.on("data", function(e) {
 | |
|   console.log("got data", JSON.stringify(e));
 | |
| });
 | |
| 
 | |
| duplex.on("finish", function() {
 | |
|   console.log("got finish event");
 | |
| });
 | |
| 
 | |
| duplex.on("end", function() {
 | |
|   console.log("got end event");
 | |
| });
 | |
| 
 | |
| duplex.write("oh, hi there", function() {
 | |
|   console.log("finished writing");
 | |
| });
 | |
| 
 | |
| duplex.end(function() {
 | |
|   console.log("finished ending");
 | |
| });
 | |
| ```
 | |
| 
 | |
| ```
 | |
| got data "oh, hi there"
 | |
| finished writing
 | |
| got finish event
 | |
| finished ending
 | |
| got end event
 | |
| ```
 | |
| 
 | |
| ## Overview
 | |
| 
 | |
| This is a reimplementation of [duplexer](https://www.npmjs.com/package/duplexer) using the
 | |
| Streams3 API which is standard in Node as of v4. Everything largely
 | |
| works the same.
 | |
| 
 | |
| 
 | |
| 
 | |
| ## Installation
 | |
| 
 | |
| [Available via `npm`](https://docs.npmjs.com/cli/install):
 | |
| 
 | |
| ```
 | |
| $ npm i duplexer3
 | |
| ```
 | |
| 
 | |
| ## API
 | |
| 
 | |
| ### duplexer3
 | |
| 
 | |
| Creates a new `DuplexWrapper` object, which is the actual class that implements
 | |
| most of the fun stuff. All that fun stuff is hidden. DON'T LOOK.
 | |
| 
 | |
| ```javascript
 | |
| duplexer3([options], writable, readable)
 | |
| ```
 | |
| 
 | |
| ```javascript
 | |
| const duplex = duplexer3(new stream.Writable(), new stream.Readable());
 | |
| ```
 | |
| 
 | |
| Arguments
 | |
| 
 | |
| * __options__ - an object specifying the regular `stream.Duplex` options, as
 | |
|   well as the properties described below.
 | |
| * __writable__ - a writable stream
 | |
| * __readable__ - a readable stream
 | |
| 
 | |
| Options
 | |
| 
 | |
| * __bubbleErrors__ - a boolean value that specifies whether to bubble errors
 | |
|   from the underlying readable/writable streams. Default is `true`.
 | |
| 
 | |
| 
 | |
| ## License
 | |
| 
 | |
| 3-clause BSD. [A copy](./LICENSE) is included with the source.
 | |
| 
 | |
| ## Contact
 | |
| 
 | |
| * GitHub ([deoxxa](http://github.com/deoxxa))
 | |
| * Twitter ([@deoxxa](http://twitter.com/deoxxa))
 | |
| * Email ([deoxxa@fknsrs.biz](mailto:deoxxa@fknsrs.biz))
 |