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 <[email protected]> Reviewed-By: Antoine du Hamel <[email protected]> Reviewed-By: Daijiro Wachi <[email protected]> Reviewed-By: Rich Trott <[email protected]>
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‎

Lines changed: 14 additions & 7 deletions
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+
consteventHandlerValueMap=newSafeWeakMap();
582+
579583
functiondefineEventHandler(emitter,name){
580584
// 8.1.5.1 Event handlers - basically `on[eventName]` attributes
581-
leteventHandlerValue;
582-
Object.defineProperty(emitter,`on${name}`,{
585+
ObjectDefineProperty(emitter,`on${name}`,{
583586
get(){
584-
returneventHandlerValue;
587+
returneventHandlerValueMap.get(this)?.get(name);
585588
},
586589
set(value){
587-
if(eventHandlerValue){
588-
emitter.removeEventListener(name,eventHandlerValue);
590+
constoldValue=eventHandlerValueMap.get(this)?.get(name);
591+
if(oldValue){
592+
this.removeEventListener(name,oldValue);
589593
}
590594
if(typeofvalue==='function'){
591-
emitter.addEventListener(name,value);
595+
this.addEventListener(name,value);
596+
}
597+
if(!eventHandlerValueMap.has(this)){
598+
eventHandlerValueMap.set(this,newMap());
592599
}
593-
eventHandlerValue=value;
600+
eventHandlerValueMap.get(this).set(name,value);
594601
},
595602
configurable: true,
596603
enumerable: true

‎lib/internal/worker/io.js‎

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -99,13 +99,14 @@ ObjectDefineProperty(
9999
// This is called from inside the `MessagePort` constructor.
100100
functiononinit(){
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‎

Lines changed: 2 additions & 4 deletions
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)