-
Notifications
You must be signed in to change notification settings - Fork 31.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tracking Issue: Syncify the ESM Loader #55782
Comments
Maybe moving it in the loaders repo would be more appropriate since its a effort that is gonna require different iterations? |
This task is better handled by a large group of people, and this repo is more visible. Once the first few steps are done, it can easily be tagged as "good first issue" |
I would like to mention my issue here. |
Hi @mcollina and @marco-ippolito, Also what is the best method to test if my code is improving performance? |
This may be necessary to prevent a race condition like prettier/prettier#17139 (comment) |
@cu8code Sorry to not notice your comment earlier. If you'd like to help with this effort, you can pick any of the functions listed in the top issue and try to refactor them to be synchronous. The lowest hanging fruit are the ones that are async functions but never actually |
Can be removed since we removed http imports |
The code under
lib/internal/modules/esm
, a.k.a. the ESM loader, contains many functions that are async. We should refactor as many of these as possible, ideally all of them, to be synchronous. This should improve the performance of evaluating ESM code, bringing it roughly on par with the speed of running CommonJS code.Longer term, once the ESM loader is synchronous and we land the synchronous module customization hooks, we could deprecate monkey-patching the CommonJS loader and merge together the CommonJS and ESM loaders, eliminating duplication: #50356.
This issue will track our progress syncifying the various files and functions of the ESM loader until we can get as much of it to be as synchronous as possible.
The files to be updated, all under
lib/internal/modules
:run_main.js
:asyncRunEntryPointWithESMLoader
esm/fetch_module.js
:fetchWithRedirects
esm/fetch_module.js
:isLocalAddress
esm/hooks.js
:Hooks
class (the async methods here probably don’t need updating as they will be removed once we migrate to the synchronous customization hooks)esm/hooks.js
:nextHookFactory
esm/load.js
:getSource
esm: syncify default path ofModuleLoader.load
#57419esm/load.js
:defaultLoad
esm: syncify default path ofModuleLoader.load
#57419esm/loader.js
:ModuleLoader.eval
esm/loader.js
:ModuleLoader.getModuleJobForImport
esm/loader.js
:ModuleLoader.loadAndTranslate
esm/loader.js
:ModuleLoader.import
esm/loader.js
:ModuleLoader.load
esm/module_job.js
:ModuleJob._link
esm/module_job.js
:ModuleJob._instantiate
esm/module_job.js
:ModuleJob.run
esm/module_job.js
:ModuleJobSync.run
esm/translators.js
:wasm
handler, viatranslators.set('wasm', ...
esm/utils.js
:importModuleDynamicallyCallback
esm/utils.js
:initializeHooks
(might not need updating as we will remove this once the synchronous customization hooks landesm/worker.js
:customizedModuleWorker
(might not need updating as we will remove this once the synchronous customization hooks landesm/worker.js
:handleMessage
(might not need updating as we will remove this once the synchronous customization hooks land@nodejs/loaders @mcollina @JakobJingleheimer @joyeecheung
The text was updated successfully, but these errors were encountered: