diff --git a/lib/internal/modules/esm/hooks.js b/lib/internal/modules/esm/hooks.js index 8dd81ca52c53188..00c1ab75aaff87c 100644 --- a/lib/internal/modules/esm/hooks.js +++ b/lib/internal/modules/esm/hooks.js @@ -3,6 +3,7 @@ const { ArrayPrototypePush, ArrayPrototypePushApply, + FunctionPrototypeBind, Int32Array, ObjectAssign, ObjectDefineProperty, @@ -139,7 +140,7 @@ class Hooks { * to the worker. * @returns {any | Promise} User data, ignored unless it's a promise, in which case it will be awaited. */ - addCustomLoader(url, exports, data) { + async addCustomLoader(url, exports, data) { const { initialize, resolve, @@ -154,7 +155,26 @@ class Hooks { const next = this.#chains.load[this.#chains.load.length - 1]; ArrayPrototypePush(this.#chains.load, { __proto__: null, fn: load, url, next }); } - return initialize?.(data); + + const hooks = await initialize?.(data); + + if (hooks?.resolve) { + if (resolve) { + throw new Error('Invariant violation: both a module-level and returned resolve hook found'); + } + const next = this.#chains.resolve[this.#chains.resolve.length - 1]; + const boundResolve = FunctionPrototypeBind(hooks.resolve, hooks); + ArrayPrototypePush(this.#chains.resolve, { __proto__: null, fn: boundResolve, url, next }); + } + + if (hooks?.load) { + if (load) { + throw new Error('Invariant violation: both a module-level and returned load hook found'); + } + const next = this.#chains.load[this.#chains.load.length - 1]; + const boundLoad = FunctionPrototypeBind(hooks.load, hooks); + ArrayPrototypePush(this.#chains.load, { __proto__: null, fn: boundLoad, url, next }); + } } /**