From cdb631efe7ce43b3c89821db070fceec13874db9 Mon Sep 17 00:00:00 2001 From: Chengzhong Wu Date: Fri, 20 Dec 2024 11:59:08 +0000 Subject: [PATCH] esm: add experimental support for addon modules PR-URL: https://github.com/nodejs/node/pull/55844 Fixes: https://github.com/nodejs/node/issues/40541 Fixes: https://github.com/nodejs/node/issues/55821 Reviewed-By: Guy Bedford Reviewed-By: Geoffrey Booth Reviewed-By: Joyee Cheung Reviewed-By: Jacob Smith Reviewed-By: Antoine du Hamel --- doc/api/cli.md | 19 +++- doc/api/esm.md | 19 ++-- doc/api/module.md | 1 + doc/node.1 | 3 + lib/internal/modules/esm/formats.js | 5 + lib/internal/modules/esm/load.js | 3 + lib/internal/modules/esm/translators.js | 104 +++++++++++++++--- src/node_options.cc | 4 + src/node_options.h | 1 + test/addons/.gitignore | 1 + test/addons/esm/binding-export-default.cc | 17 +++ test/addons/esm/binding-export-primitive.cc | 17 +++ test/addons/esm/binding.cc | 17 +++ test/addons/esm/binding.gyp | 40 +++++++ .../esm/node_modules/esm-package/package.json | 8 ++ test/addons/esm/test-esm.mjs | 58 ++++++++++ test/addons/esm/test-import-package.js | 15 +++ test/addons/esm/test-import.js | 7 ++ test/addons/esm/test-require-package.js | 12 ++ test/addons/esm/test-require.js | 6 + 20 files changed, 331 insertions(+), 26 deletions(-) create mode 100644 test/addons/esm/binding-export-default.cc create mode 100644 test/addons/esm/binding-export-primitive.cc create mode 100644 test/addons/esm/binding.cc create mode 100644 test/addons/esm/binding.gyp create mode 100644 test/addons/esm/node_modules/esm-package/package.json create mode 100644 test/addons/esm/test-esm.mjs create mode 100644 test/addons/esm/test-import-package.js create mode 100644 test/addons/esm/test-import.js create mode 100644 test/addons/esm/test-require-package.js create mode 100644 test/addons/esm/test-require.js diff --git a/doc/api/cli.md b/doc/api/cli.md index d54b56aff9c891..6a6d2e80c4fe55 100644 --- a/doc/api/cli.md +++ b/doc/api/cli.md @@ -45,8 +45,11 @@ Otherwise, the file is loaded using the CommonJS module loader. See When loading, the [ES module loader][Modules loaders] loads the program entry point, the `node` command will accept as input only files with `.js`, -`.mjs`, or `.cjs` extensions; and with `.wasm` extensions when -[`--experimental-wasm-modules`][] is enabled. +`.mjs`, or `.cjs` extensions. With the following flags, additional file +extensions are enabled: + +* [`--experimental-wasm-modules`][] for files with `.wasm` extension. +* [`--experimental-addon-modules`][] for files with `.node` extension. ## Options @@ -879,6 +882,16 @@ and `"` are usable. It is possible to run code containing inline types by passing [`--experimental-strip-types`][]. +### `--experimental-addon-modules` + + + +> Stability: 1.0 - Early development + +Enable experimental import support for `.node` addons. + ### `--experimental-async-context-frame`