Skip to content

Commit bdad1bc

Browse files
benjamingrtargos
authored andcommitted
events: support event handlers on prototypes
PR-URL: #35931 Backport-PR-URL: #38386 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com> Reviewed-By: Daijiro Wachi <daijiro.wachi@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
1 parent 6e21e82 commit bdad1bc

File tree

3 files changed

+19
-13
lines changed

3 files changed

+19
-13
lines changed

lib/internal/event_target.js

+14-7
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@ const {
1313
Symbol,
1414
SymbolFor,
1515
SymbolToStringTag,
16+
SafeWeakMap,
1617
SafeWeakSet,
1718
} = primordials;
1819

@@ -576,21 +577,27 @@ function emitUnhandledRejectionOrErr(that, err, event) {
576577
process.emit('error', err, event);
577578
}
578579

580+
// A map of emitter -> map of name -> handler
581+
const eventHandlerValueMap = new SafeWeakMap();
582+
579583
function defineEventHandler(emitter, name) {
580584
// 8.1.5.1 Event handlers - basically `on[eventName]` attributes
581-
let eventHandlerValue;
582-
Object.defineProperty(emitter, `on${name}`, {
585+
ObjectDefineProperty(emitter, `on${name}`, {
583586
get() {
584-
return eventHandlerValue;
587+
return eventHandlerValueMap.get(this)?.get(name);
585588
},
586589
set(value) {
587-
if (eventHandlerValue) {
588-
emitter.removeEventListener(name, eventHandlerValue);
590+
const oldValue = eventHandlerValueMap.get(this)?.get(name);
591+
if (oldValue) {
592+
this.removeEventListener(name, oldValue);
589593
}
590594
if (typeof value === 'function') {
591-
emitter.addEventListener(name, value);
595+
this.addEventListener(name, value);
596+
}
597+
if (!eventHandlerValueMap.has(this)) {
598+
eventHandlerValueMap.set(this, new Map());
592599
}
593-
eventHandlerValue = value;
600+
eventHandlerValueMap.get(this).set(name, value);
594601
},
595602
configurable: true,
596603
enumerable: true

lib/internal/worker/io.js

+3-2
Original file line numberDiff line numberDiff line change
@@ -99,13 +99,14 @@ ObjectDefineProperty(
9999
// This is called from inside the `MessagePort` constructor.
100100
function oninit() {
101101
initNodeEventTarget(this);
102-
// TODO(addaleax): This should be on MessagePort.prototype, but
103-
// defineEventHandler() does not support that.
104102
defineEventHandler(this, 'message');
105103
defineEventHandler(this, 'messageerror');
106104
setupPortReferencing(this, this, 'message');
107105
}
108106

107+
defineEventHandler(MessagePort.prototype, 'message');
108+
defineEventHandler(MessagePort.prototype, 'messageerror');
109+
109110
ObjectDefineProperty(MessagePort.prototype, onInitSymbol, {
110111
enumerable: true,
111112
writable: false,

test/parallel/test-worker-message-port.js

+2-4
Original file line numberDiff line numberDiff line change
@@ -165,9 +165,7 @@ const { MessageChannel, MessagePort } = require('worker_threads');
165165
assert.deepStrictEqual(
166166
Object.getOwnPropertyNames(MessagePort.prototype).sort(),
167167
[
168-
// TODO(addaleax): This should include onmessage (and eventually
169-
// onmessageerror).
170-
'close', 'constructor', 'postMessage', 'ref', 'start',
171-
'unref'
168+
'close', 'constructor', 'onmessage', 'onmessageerror', 'postMessage',
169+
'ref', 'start', 'unref'
172170
]);
173171
}

0 commit comments

Comments
 (0)