From a235a152c50e23c0fe41a234fb338a227091a5cd Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Sun, 10 Mar 2024 07:52:12 +0800 Subject: [PATCH] fixup! module: support require()ing synchronous ESM graphs --- doc/api/cli.md | 30 +++++++++++++---------- doc/api/errors.md | 4 +-- src/module_wrap.cc | 9 ++++--- src/node_errors.h | 2 +- src/node_options.cc | 4 +-- src/node_options.h | 2 +- test/es-module/test-require-module-tla.js | 2 +- 7 files changed, 29 insertions(+), 24 deletions(-) diff --git a/doc/api/cli.md b/doc/api/cli.md index cbc40a906505d5..9e61ba395c7457 100644 --- a/doc/api/cli.md +++ b/doc/api/cli.md @@ -879,17 +879,21 @@ added: REPLACEME > Stability: 1.1 - Active Developement -Supports loading a synchronous ES module graph in `require()`. If the module -graph is not synchronous (contains top-level await), Node.js throws an error -without executing the module. If `--print-pending-tla` is passed, Node.js -will evaluate the module, try to locate the top-level awaits, and print -their location to help users fix them. - -With this option alone, the module being `require()`'d should be explicitly -marked as an ES module either using the `"type": "module"` field in -`package.json` or the `.mjs` extension. To load implicit ES modules with -automatic syntax-based module type detection, use -`--experimental-require-module-with-detection`. +Supports loading a synchronous ES module graph in `require()`. + +When `--experimental-require-module` is enabled, and `require()` +resolves to an ES module, if the module is fully synchronous +(contains no top-level await), the `require()` call returns the +module name space object. Otherwise, Node.js throws an error +without executing the module. If `--experimental-print-required-tla` +is passed, Node.js will evaluate the module, try to locate the +top-level awaits, and print their location to help users fix them. + +With this option alone, the module being `require()`'d should be +explicitly marked as an ES module either using the `"type": "module"` +field in `package.json` or the `.mjs` extension. To load implicit ES +modules ending with `.js` using automatic syntax-based module type +detection, use `--experimental-require-module-with-detection`. ### `--experimental-require-module-with-detection` @@ -1611,7 +1615,7 @@ changes: Identical to `-e` but prints the result. -### `--print-pending-tla` +### `--experimental-print-required-tla`