Skip to content

Commit

Permalink
Add process/progress documents
Browse files Browse the repository at this point in the history
  • Loading branch information
DerekNonGeneric committed Feb 19, 2020
1 parent e48e282 commit f1fd682
Show file tree
Hide file tree
Showing 5 changed files with 116 additions and 47 deletions.
58 changes: 11 additions & 47 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,53 +13,17 @@ 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.
## Links

- [Archives](./doc/archive/README.md)
- [Code of Conduct](./CODE_OF_CONDUCT.md)
- [Governance](./GOVERNANCE.md)
- [License](./LICENSE.md)
- [Resources](./RESOURCES.md)
- [Roadmap](./doc/roadmap-2020.md)
- [Terminology](./doc/terminology.md)
- [Vitae](./doc/vitae.md)
- [Wishlist](./doc/wishlist.md)

## Members

Expand Down
6 changes: 6 additions & 0 deletions doc/archive/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Document Archive

## Contents

- **[Features](./features.md)**: As part of creating the ECMAScript Modules implementation for Node.js 12.0.0, [use cases](../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](./plan-for-new-modules-implementation.md).
- **[Plan for New Modules Implementation](./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.
21 changes: 21 additions & 0 deletions doc/roadmap-2020.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
<table>
<thead><tr><td colspan=3 align=center>This is a living document. It describes the policy and priorities as they exist today, but can evolve over time.</td></tr></thead>
<tfoot><tr><td align=center><a href="./wishlist.md"><strong>❮&nbsp;Wishlist</strong></a></td><td><img width=1000/></td><td align=center><a href="./vitae.md"><strong>Vitae&nbsp;❯</strong></a></td></tr></tfoot>
</table><br />

# Node.js Modules Group 2020 Roadmap

_The goals below represent items currently planned for completion in 2020. For
additional items that have been recognized as desirable, see the
[wishlist](./wishlist.md)._

---

* [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).

---
36 changes: 36 additions & 0 deletions doc/vitae.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@

<table>
<thead><tr><td colspan=3 align=center>This is a living document. It describes the policy and priorities as they exist today, but can evolve over time.</td></tr></thead>
<tfoot><tr><td align=center><a href="./roadmap.md"><strong>❮&nbsp;Roadmap</strong></a></td><td><img width=1000/></td><td align=center><a href="./wishlist.md"><strong>Wishlist&nbsp;❯</strong></a></td></tr></tfoot>
</table><br />

# Node.js Modules Group Vitae

*The items below represent non-trivial contributions, relevant to ES module support, made by the Node.js Modules Group. For items that are likely to be displayed here soon, see the [2020 roadmap](./roadmap-2020.md).*

---

<!-- FIXME -->

- **Add Lorem Feature**

*Added new functionality to lorem an ES module.*

PR: nodejs/node#123456

Conbtributors:
- @Alice
- @Bob

- **Fix Ipsum Ability**

*Fixed missing ability to ipsum an ES module.*

PR: nodejs/node#123456

Conbtributors:
- @Alice
- @Chuck
- @Dan
- @Eve
---
42 changes: 42 additions & 0 deletions doc/wishlist.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
<table>
<thead><tr><td colspan=3 align=center>This is a living document. It describes the policy and priorities as they exist today, but can evolve over time.</td></tr></thead>
<tfoot><tr><td align=center><a href="./vitae.md"><strong>❮&nbsp;Vitae</strong></a></td><td><img width=1000/></td><td align=center><a href="./roadmap-2020.md"><strong>Roadmap&nbsp;❯</strong></a></td></tr></tfoot>
</table><br />

# Node.js Modules Group Wishlist

*The items below represent functionality that has been recognized as desirable, but cannot be implemented due to either being currently blocked or unplanned. For items that are currently planned, see the [2020 roadmap](./roadmap-2020.md).*

## 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 f1fd682

Please sign in to comment.