Skip to content

Commit

Permalink
Archive Current Efforts as roadmap/wishlist
Browse files Browse the repository at this point in the history
  • Loading branch information
DerekNonGeneric committed Feb 21, 2020
1 parent e48e282 commit ef75417
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 42 deletions.
44 changes: 2 additions & 42 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,54 +13,14 @@ Work includes:
* Node.js and browser interoperability
* VM modules implementation

## Current Efforts

### To Do / In Progress

* [Loader hooks](https://nodejs.org/api/esm.html#esm_hooks) (work in progress). The goal is to create hooks that provide enough functionality to enable users to build loaders that can achieve many of the remaining [features](./doc/features.md) we hope to support.
- Overview: https://github.com/nodejs/modules/issues/351.
- A [design](https://github.com/nodejs/node/pull/30986) that enables [transpilation](https://github.com/nodejs/modules/issues/96) and [arbitrary sources](https://github.com/nodejs/modules/issues/97) and [specifier customization](https://github.com/nodejs/modules/issues/110) shipped in Node 13.7.0.
- **Status**: Work remains to be done to support further use cases including [code coverage/instrumentation](https://github.com/nodejs/modules/issues/95) and [mocks/stubs](https://github.com/nodejs/modules/issues/98).

* [WASM modules](https://nodejs.org/api/esm.html#esm_experimental_wasm_modules) (work in progress).

### Wish List (Blocked)

* Named exports for CommonJS modules, e.g. `import { shuffle } from 'cjs-pkg'` in addition to the currently supported `import _ from 'cjs-pkg'`.
- Overview: https://github.com/nodejs/modules/issues/264.
- Discussion: https://github.com/nodejs/modules/issues/448.
- Proposal: https://github.com/nodejs/modules/issues/252.
- **Status**: As far as we can tell, currently there is no spec-compliant way to achieve this.

CommonJS is not statically analyzable (that’s one of the primary benefits of `import`/`export` syntax) and therefore the exported names cannot be known to Node.js simply by parsing JavaScript source code: the code needs to actually be evaluated in order for Node.js to discover what identifiers get attached to `module.exports` for each file. But evaluating the CommonJS code in what the ECMAScript Modules spec calls the “linking” phase (when the module graph is determined) is not permitted; this would mean that CommonJS code is evaluated early, before any ES module code, whereas the spec defines the order of modules’ evaluation based on the depth of imports. This early evaluation presents other issues in that if a dependency gets converted from CommonJS to ESM, its order of evaluation would change in the user’s application; and early evaluation might trigger side effects if reading the values from `module.exports` were getters or proxies.

A [“dynamic modules” proposal](https://github.com/nodejs/modules/issues/252) was created and presented to TC39, the standards body responsible for the ECMAScript Modules spec. This was a proposal to allow new export names to be discovered during the execution phase, which happens after linking. This made named exports from CommonJS work, but had the caveat that `export *` would not be supported for CommonJS sources. Without a solution for this edge case, TC39 deemed the proposal inadequate. There are currently no other proposals in development to try to surmount these obstacles.

The approach taken by the [`standard-things/esm`](https://github.com/standard-things/esm) package is to transpile ES module sources into CommonJS on the fly, and have Node.js evaluate the CommonJS sources. This is not considered a viable option for Node.js because it means that the actual source code being executed by the V8 JavaScript engine is not the code that the user wrote.

* `require` of ES modules: Support using `require` (in addition to `import()`) to load ES modules into a CommonJS context.
- Discussion: https://github.com/nodejs/modules/issues/299.
- PR: https://github.com/nodejs/node/pull/30891.
- **Status**: Blocked due to various issues discussed in https://github.com/nodejs/modules/issues/454.

### Not Planned

* Limited module type detection.
- PR: https://github.com/nodejs/ecmascript-modules/pull/69.
- Upstream PR: https://github.com/nodejs/node/pull/27808.
- **Status**: The group’s current thinking is to encourage explicit source type definition via file extension or the `"type"` field. Source type detection via parsing source code is not 100% accurate and should therefore be left to userland where users can choose to accept its risks.

* Provide a way to make ESM the default instead of CommonJS.
- Discussion: https://github.com/nodejs/modules/issues/318.
- Proposal: https://github.com/nodejs/modules/issues/335.
- **Status**: Currently one can add `--input-type=module` to `NODE_OPTIONS` to flip the default for `--input-type`; at the moment the group is deciding not to pursue providing an ability to flip the default for the `package.json` `type` field. We instead want to encourage all packages, both ESM and CommonJS, to include an explicit `type` field; leaving it out and relying on a default is something we want to discourage.

## Archives

- **[Features](./doc/archive/features.md)**: As part of creating the ECMAScript Modules implementation for Node.js 12.0.0, [use cases](./doc/use-cases.md) were brainstormed, which led to a list of features. This feature list, which previously existed as a section in this repo's root README, informed what became the [plan for the implementation](./doc/archive/plan-for-new-modules-implementation.md).

- **[Plan for New Modules Implementation](./doc/archive/plan-for-new-modules-implementation.md)**: This document summarized the work that went into the new ECMAScript Modules implementation that shipped in Node.js 12.0.0.

- **[Roadmap](./doc/archive/roadmap.md)**: These sections have been archived, which previously existed compositely as a section named "Current Efforts" in this repo's root README.

## Members

<!-- ncu-team-sync.team(nodejs/modules-active-members) -->
Expand Down
59 changes: 59 additions & 0 deletions doc/archive/roadmap.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
> _These sections have been archived, which previously existed compositely as
> a section named "Current Efforts" in this repo's root
> [README](../../README.md)._
<br />
---

> _This section has been archived._
>
> _The goals below represent items planned for completion. For additional items that had been recognized as desirable, see the [wishlist](#wishlist)._
# Roadmap

* [Loader hooks](https://nodejs.org/api/esm.html#esm_hooks) (work in progress). The goal is to create hooks that provide enough functionality to enable users to build loaders that can achieve many of the remaining [features](./doc/features.md) we hope to support.
- Overview: https://github.com/nodejs/modules/issues/351.
- A [design](https://github.com/nodejs/node/pull/30986) that enables [transpilation](https://github.com/nodejs/modules/issues/96) and [arbitrary sources](https://github.com/nodejs/modules/issues/97) and [specifier customization](https://github.com/nodejs/modules/issues/110) shipped in Node 13.7.0.
- **Status**: Work remains to be done to support further use cases including [code coverage/instrumentation](https://github.com/nodejs/modules/issues/95) and [mocks/stubs](https://github.com/nodejs/modules/issues/98).

* [WASM modules](https://nodejs.org/api/esm.html#esm_experimental_wasm_modules) (work in progress).

<br />
---

> _This section has been archived._
>
> _The items below represent functionality that had been recognized as desirable, but cannot be implemented due to either being currently blocked or unplanned. For items that had been planned, see the [roadmap](#roadmap)._
# Wishlist

## Blocked

* Named exports for CommonJS modules, e.g. `import { shuffle } from 'cjs-pkg'` in addition to the currently supported `import _ from 'cjs-pkg'`.
- Overview: https://github.com/nodejs/modules/issues/264.
- Discussion: https://github.com/nodejs/modules/issues/448.
- Proposal: https://github.com/nodejs/modules/issues/252.
- **Status**: As far as we can tell, currently there is no spec-compliant way to achieve this.

CommonJS is not statically analyzable (that’s one of the primary benefits of `import`/`export` syntax) and therefore the exported names cannot be known to Node.js simply by parsing JavaScript source code: the code needs to actually be evaluated in order for Node.js to discover what identifiers get attached to `module.exports` for each file. But evaluating the CommonJS code in what the ECMAScript Modules spec calls the “linking” phase (when the module graph is determined) is not permitted; this would mean that CommonJS code is evaluated early, before any ES module code, whereas the spec defines the order of modules’ evaluation based on the depth of imports. This early evaluation presents other issues in that if a dependency gets converted from CommonJS to ESM, its order of evaluation would change in the user’s application; and early evaluation might trigger side effects if reading the values from `module.exports` were getters or proxies.

A [“dynamic modules” proposal](https://github.com/nodejs/modules/issues/252) was created and presented to TC39, the standards body responsible for the ECMAScript Modules spec. This was a proposal to allow new export names to be discovered during the execution phase, which happens after linking. This made named exports from CommonJS work, but had the caveat that `export *` would not be supported for CommonJS sources. Without a solution for this edge case, TC39 deemed the proposal inadequate. There are currently no other proposals in development to try to surmount these obstacles.

The approach taken by the [`standard-things/esm`](https://github.com/standard-things/esm) package is to transpile ES module sources into CommonJS on the fly, and have Node.js evaluate the CommonJS sources. This is not considered a viable option for Node.js because it means that the actual source code being executed by the V8 JavaScript engine is not the code that the user wrote.

* `require` of ES modules: Support using `require` (in addition to `import()`) to load ES modules into a CommonJS context.
- Discussion: https://github.com/nodejs/modules/issues/299.
- PR: https://github.com/nodejs/node/pull/30891.
- **Status**: Blocked due to various issues discussed in https://github.com/nodejs/modules/issues/454.

## Not Planned

* Limited module type detection.
- PR: https://github.com/nodejs/ecmascript-modules/pull/69.
- Upstream PR: https://github.com/nodejs/node/pull/27808.
- **Status**: The group’s current thinking is to encourage explicit source type definition via file extension or the `"type"` field. Source type detection via parsing source code is not 100% accurate and should therefore be left to userland where users can choose to accept its risks.

* Provide a way to make ESM the default instead of CommonJS.
- Discussion: https://github.com/nodejs/modules/issues/318.
- Proposal: https://github.com/nodejs/modules/issues/335.
- **Status**: Currently one can add `--input-type=module` to `NODE_OPTIONS` to flip the default for `--input-type`; at the moment the group is deciding not to pursue providing an ability to flip the default for the `package.json` `type` field. We instead want to encourage all packages, both ESM and CommonJS, to include an explicit `type` field; leaving it out and relying on a default is something we want to discourage.

0 comments on commit ef75417

Please sign in to comment.