From a30a39984ac1b241ae3c105b9a45f5dd5ed068d5 Mon Sep 17 00:00:00 2001 From: Anna Henningsen Date: Sun, 30 Sep 2018 21:08:12 -0400 Subject: [PATCH] zlib: use common owner symbol to access JS wrapper Use the same symbol that other `AsyncWrap` instances also use for accessing the JS wrapper. --- lib/zlib.js | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/lib/zlib.js b/lib/zlib.js index 87e8641767669f..626676da6df4aa 100644 --- a/lib/zlib.js +++ b/lib/zlib.js @@ -42,6 +42,7 @@ const { Buffer, kMaxLength } = require('buffer'); +const { owner_symbol } = require('internal/async_hooks').symbols; const constants = process.binding('constants').zlib; const { @@ -143,7 +144,7 @@ function zlibBufferSync(engine, buffer) { } function zlibOnError(message, errno) { - var self = this.jsref; + var self = this[owner_symbol]; // there is no way to cleanly recover. // continuing only obscures problems. _close(self); @@ -300,7 +301,8 @@ function Zlib(opts, mode) { Transform.call(this, opts); this.bytesWritten = 0; this._handle = new binding.Zlib(mode); - this._handle.jsref = this; // Used by processCallback() and zlibOnError() + // Used by processCallback() and zlibOnError() + this._handle[owner_symbol] = this; this._handle.onerror = zlibOnError; this._hadError = false; this._writeState = new Uint32Array(2); @@ -713,6 +715,13 @@ function createProperty(ctor) { }; } +// Legacy alias on the C++ wrapper object. This is not public API, so we may +// want to runtime-deprecate it at some point. There's no hurry, though. +Object.defineProperty(binding.Zlib.prototype, 'jsref', { + get() { return this[owner_symbol]; }, + set(v) { return this[owner_symbol] = v; } +}); + module.exports = { Deflate, Inflate,