From 3797a8467dc7665fb5c12e5858b2a9216cbced96 Mon Sep 17 00:00:00 2001 From: James M Snell Date: Wed, 14 Jul 2021 08:50:18 -0700 Subject: [PATCH] fixup! streams: add CompressionStream and DecompressionStream --- lib/internal/webstreams/compression.js | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/lib/internal/webstreams/compression.js b/lib/internal/webstreams/compression.js index 6dfddbce248b7a..692f64af005af9 100644 --- a/lib/internal/webstreams/compression.js +++ b/lib/internal/webstreams/compression.js @@ -25,12 +25,11 @@ const { customInspectSymbol: kInspect, } = require('internal/util'); -const { - createDeflate, - createInflate, - createGzip, - createGunzip, -} = require('zlib'); +let zlib; +function lazyZlib() { + zlib ??= require('zlib'); + return zlib; +} const kHandle = Symbol('kHandle'); const kTransform = Symbol('kTransform'); @@ -59,10 +58,10 @@ class CompressionStream { this[kType] = 'CompressionStream'; switch (format) { case 'deflate': - this[kHandle] = createDeflate(); + this[kHandle] = lazyZlib().createDeflate(); break; case 'gzip': - this[kHandle] = createGzip(); + this[kHandle] = lazyZlib().createGzip(); break; default: throw new ERR_INVALID_ARG_VALUE('format', format); @@ -108,10 +107,10 @@ class DecompressionStream { this[kType] = 'DecompressionStream'; switch (format) { case 'deflate': - this[kHandle] = createInflate(); + this[kHandle] = lazyZlib().createInflate(); break; case 'gzip': - this[kHandle] = createGunzip(); + this[kHandle] = lazyZlib().createGunzip(); break; default: throw new ERR_INVALID_ARG_VALUE('format', format);