forked from nodejs/node
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
streams: refactor LazyTransform to internal/
This commit refactors LazyTransform from the crypto implementation (lib/crypto.js) into an internal module (not publicy accessible) in internal/streams/lazy_transform.js. This promotes a more modular core design and removes code bloat in crypto, as LazyTransform didn't specifically have anything to do with cryptography, but rather a fast way to support two APIs on a stream. PR-URL: nodejs#2566 Reviewed-By: Fedor Indutny <[email protected]>
- Loading branch information
1 parent
7ec0491
commit c70c778
Showing
3 changed files
with
41 additions
and
31 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
// LazyTransform is a special type of Transform stream that is lazily loaded. | ||
// This is used for performance with bi-API-ship: when two APIs are available | ||
// for the stream, one conventional and one non-conventional. | ||
'use strict'; | ||
|
||
const stream = require('stream'); | ||
const util = require('util'); | ||
|
||
module.exports = LazyTransform; | ||
|
||
function LazyTransform(options) { | ||
this._options = options; | ||
} | ||
util.inherits(LazyTransform, stream.Transform); | ||
|
||
[ | ||
'_readableState', | ||
'_writableState', | ||
'_transformState' | ||
].forEach(function(prop, i, props) { | ||
Object.defineProperty(LazyTransform.prototype, prop, { | ||
get: function() { | ||
stream.Transform.call(this, this._options); | ||
this._writableState.decodeStrings = false; | ||
this._writableState.defaultEncoding = 'binary'; | ||
return this[prop]; | ||
}, | ||
set: function(val) { | ||
Object.defineProperty(this, prop, { | ||
value: val, | ||
enumerable: true, | ||
configurable: true, | ||
writable: true | ||
}); | ||
}, | ||
configurable: true, | ||
enumerable: true | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters