diff --git a/guest.js b/guest.js index 51f11ca..bd25ede 100644 --- a/guest.js +++ b/guest.js @@ -1,11 +1,10 @@ 'use strict' -const duplexify = require('duplexify') const { AbstractLevel, AbstractIterator } = require('abstract-level') -const eos = require('end-of-stream') const lpstream = require('length-prefixed-stream') const ModuleError = require('module-error') const { input, output } = require('./tags') +const { Duplex, pipeline, finished } = require('stream') const kExplicitClose = Symbol('explicitClose') const kAbortRequests = Symbol('abortRequests') @@ -108,10 +107,8 @@ class ManyLevelGuest extends AbstractLevel { self[kFlushed]() }) - const proxy = duplexify() - proxy.setWritable(decode) - proxy.setReadable(encode) - eos(proxy, cleanup) + const proxy = Duplex.from({ writable: decode, readable: encode }) + finished(proxy, cleanup) this[kRpcStream] = proxy return proxy @@ -312,7 +309,7 @@ class ManyLevelGuest extends AbstractLevel { this[kAbortRequests]('Aborted on database close()', 'LEVEL_DATABASE_NOT_OPEN') if (this[kRpcStream]) { - eos(this[kRpcStream], () => { + finished(this[kRpcStream], () => { this[kRpcStream] = null this._close(cb) }) @@ -330,7 +327,12 @@ class ManyLevelGuest extends AbstractLevel { // For tests only so does not need error handling this[kExplicitClose] = false const remote = this[kRemote]() - remote.pipe(this.connect()).pipe(remote) + pipeline( + remote, + this.connect(), + remote, + () => {} + ) } else if (this[kExplicitClose]) { throw new ModuleError('Cannot reopen many-level database after close()', { code: 'LEVEL_NOT_SUPPORTED' diff --git a/host.js b/host.js index 513c6dc..2e0ec36 100644 --- a/host.js +++ b/host.js @@ -2,8 +2,7 @@ const lpstream = require('length-prefixed-stream') const ModuleError = require('module-error') -const eos = require('end-of-stream') -const duplexify = require('duplexify') +const { Duplex, finished } = require('stream') const { input, output } = require('./tags') const rangeOptions = new Set(['gt', 'gte', 'lt', 'lte']) @@ -60,7 +59,7 @@ function createRpcStream (db, options, streamOptions) { const readonly = options.readonly const decode = lpstream.decode() const encode = lpstream.encode() - const stream = duplexify(decode, encode) + const stream = Duplex.from({ writable: decode, readable: encode }) const preput = options.preput const predel = options.predel @@ -85,7 +84,7 @@ function createRpcStream (db, options, streamOptions) { const iterators = new Map() - eos(stream, function () { + finished(stream, function () { for (const iterator of iterators.values()) { iterator.close() } diff --git a/package.json b/package.json index 4a7b538..efae535 100644 --- a/package.json +++ b/package.json @@ -26,8 +26,6 @@ ], "dependencies": { "abstract-level": "^1.0.3", - "duplexify": "^4.1.1", - "end-of-stream": "^1.1.0", "length-prefixed-stream": "^2.0.0", "module-error": "^1.0.2", "protocol-buffers-encodings": "^1.1.0"