From 71249a6c00f44f9758a6b4ea6e02560a9c17c43b Mon Sep 17 00:00:00 2001 From: Santiago Gimeno Date: Wed, 8 Feb 2023 17:51:49 +0100 Subject: [PATCH] lib: predeclare Event.isTrusted prop descriptor It improves Event creation performance. PR-URL: https://github.com/nodejs/node/pull/46527 Reviewed-By: Luigi Pinca Reviewed-By: Yagiz Nizipli Reviewed-By: Ruben Bridgewater Reviewed-By: Antoine du Hamel Reviewed-By: James M Snell Reviewed-By: Colin Ihrig Reviewed-By: Rafael Gonzaga --- lib/internal/event_target.js | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/lib/internal/event_target.js b/lib/internal/event_target.js index b3b38635cb3db3..f00d75e150166f 100644 --- a/lib/internal/event_target.js +++ b/lib/internal/event_target.js @@ -78,6 +78,13 @@ const isTrusted = ObjectGetOwnPropertyDescriptor({ } }, 'isTrusted').get; +const isTrustedDescriptor = { + __proto__: null, + configurable: false, + enumerable: true, + get: isTrusted, +}; + function isEvent(value) { return typeof value?.[kType] === 'string'; } @@ -113,12 +120,7 @@ class Event { } // isTrusted is special (LegacyUnforgeable) - ObjectDefineProperty(this, 'isTrusted', { - __proto__: null, - get: isTrusted, - enumerable: true, - configurable: false - }); + ObjectDefineProperty(this, 'isTrusted', isTrustedDescriptor); this[kTarget] = null; this[kIsBeingDispatched] = false; }