Skip to content
This repository has been archived by the owner on Sep 2, 2023. It is now read-only.

doc: first pass at minimal-kernel #180

Merged
merged 6 commits into from
Oct 3, 2018

Conversation

MylesBorins
Copy link
Contributor

Decided to submit this as a PR to comment and land as documentation.

Thoughts?

michael-ciniawsky

This comment was marked as off-topic.

@MylesBorins
Copy link
Contributor Author

updated based on feedback.

Biggest changes

ljharb

This comment was marked as off-topic.

guybedford

This comment was marked as off-topic.

mcollina

This comment was marked as off-topic.

* Rewrite: emphasize that minimal kernel is just the first phase of a multistage process, add more features and more links to features, use complete sentences.
@MylesBorins
Copy link
Contributor Author

Updated significantly based on feedback I received from @GeoffreyBooth

As such I'm dismissing all current reviews. PTAL

@MylesBorins MylesBorins dismissed stale reviews from mcollina and guybedford September 20, 2018 19:47

Significant changes since review

guybedford

This comment was marked as off-topic.

@SMotaal
Copy link

SMotaal commented Sep 21, 2018

Amazing!

targos

This comment was marked as off-topic.

mcollina

This comment was marked as off-topic.

jkrems

This comment was marked as off-topic.

@MylesBorins MylesBorins added the modules-agenda To be discussed in a meeting label Sep 25, 2018
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Oct 2, 2018
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 14, 2019
Refs: nodejs/modules#180

PR-URL: #6
PR-URL: #12
Co-authored-by: Myles Borins <[email protected]>
Co-authored-by: John-David Dalton <[email protected]>
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 15, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 18, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 18, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 18, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 19, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 20, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 21, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 21, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 21, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 22, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 23, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 24, 2019
MylesBorins added a commit to nodejs/ecmascript-modules that referenced this pull request Mar 26, 2019
nodejs-ci pushed a commit to nodejs/ecmascript-modules that referenced this pull request Mar 27, 2019
MylesBorins pushed a commit to MylesBorins/node that referenced this pull request Mar 27, 2019
This PR updates the current `--experimental-modules` implementation
based on the work of the modules team  and reflects Phase 2 of our
new modules plan.

The largest differences from the current implementation include

* `packge.type` which can be either `module` or `commonjs`
  - `type: "commonjs"`:
    - `.js` is parsed as commonjs
    - default for entry point without an extension is commonjs
  - `type: "module"`:
    - `.js` is parsed as esm
    - does not support loading JSON or Native Module by default
    - default for entry point without an extension is esm
* `--entry-type=[mode]`
  - allows you set the type on entry point.
* A new file extension `.cjs`.
  - this is specifically to support importing commonjs in the
    `module` mode.
  - this is only in the esm loader, the commonjs loader remains
    untouched, but the extension will work in the old loader if you use
    the full file path.
* `--es-module-specifier-resolution=[type]`
  - options are `explicit` (default) and `node`
  - by default our loader will not allow for optional extensions in
    the import, the path for a module must include the extension if
    there is one
  - by default our loader will not allow for importing directories that
    have an index file
  - developers can use `--es-module-specifier-resolution=node` to
    enable the commonjs specifier resolution algorithm
  - This is not a “feature” but rather an implementation for
    experimentation. It is expected to change before the flag is
    removed
* `--experimental-json-loader`
  - the only way to import json when `"type": "module"`
  - when enable all `import 'thing.json'` will go through the
    experimental loader independent of mode
  - based on whatwg/html#4315
* You can use `package.main` to set an entry point for a module
  - the file extensions used in main will be resolved based on the
    `type` of the module

Refs: https://github.com/nodejs/modules/blob/master/doc/plan-for-new-modules-implementation.md
Refs: https://github.com/GeoffreyBooth/node-import-file-specifier-resolution-proposal
Refs: nodejs/modules#180
Refs: nodejs/ecmascript-modules#6
Refs: nodejs/ecmascript-modules#12
Refs: nodejs/ecmascript-modules#28
Refs: nodejs/modules#255
Refs: whatwg/html#4315
Refs: WICG/webcomponents#770
Co-authored-by: Myles Borins <[email protected]>
Co-authored-by: John-David Dalton <[email protected]>
Co-authored-by: Evan Plaice <[email protected]>
Co-authored-by: Geoffrey Booth <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]>

PR-URL: nodejs#26745
Reviewed-By: Gus Caplan <[email protected]>
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: Ben Coe <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Joyee Cheung <[email protected]>
Reviewed-By: Ruben Bridgewater <[email protected]>
Reviewed-By: Сковорода Никита Андреевич <[email protected]>
BethGriggs pushed a commit to nodejs/node that referenced this pull request Apr 5, 2019
This PR updates the current `--experimental-modules` implementation
based on the work of the modules team  and reflects Phase 2 of our
new modules plan.

The largest differences from the current implementation include

* `packge.type` which can be either `module` or `commonjs`
  - `type: "commonjs"`:
    - `.js` is parsed as commonjs
    - default for entry point without an extension is commonjs
  - `type: "module"`:
    - `.js` is parsed as esm
    - does not support loading JSON or Native Module by default
    - default for entry point without an extension is esm
* `--entry-type=[mode]`
  - allows you set the type on entry point.
* A new file extension `.cjs`.
  - this is specifically to support importing commonjs in the
    `module` mode.
  - this is only in the esm loader, the commonjs loader remains
    untouched, but the extension will work in the old loader if you use
    the full file path.
* `--es-module-specifier-resolution=[type]`
  - options are `explicit` (default) and `node`
  - by default our loader will not allow for optional extensions in
    the import, the path for a module must include the extension if
    there is one
  - by default our loader will not allow for importing directories that
    have an index file
  - developers can use `--es-module-specifier-resolution=node` to
    enable the commonjs specifier resolution algorithm
  - This is not a “feature” but rather an implementation for
    experimentation. It is expected to change before the flag is
    removed
* `--experimental-json-loader`
  - the only way to import json when `"type": "module"`
  - when enable all `import 'thing.json'` will go through the
    experimental loader independent of mode
  - based on whatwg/html#4315
* You can use `package.main` to set an entry point for a module
  - the file extensions used in main will be resolved based on the
    `type` of the module

Refs: https://github.com/nodejs/modules/blob/master/doc/plan-for-new-modules-implementation.md
Refs: https://github.com/GeoffreyBooth/node-import-file-specifier-resolution-proposal
Refs: nodejs/modules#180
Refs: nodejs/ecmascript-modules#6
Refs: nodejs/ecmascript-modules#12
Refs: nodejs/ecmascript-modules#28
Refs: nodejs/modules#255
Refs: whatwg/html#4315
Refs: WICG/webcomponents#770
Co-authored-by: Myles Borins <[email protected]>
Co-authored-by: John-David Dalton <[email protected]>
Co-authored-by: Evan Plaice <[email protected]>
Co-authored-by: Geoffrey Booth <[email protected]>
Co-authored-by: Michaël Zasso <[email protected]>

PR-URL: #26745
Reviewed-By: Gus Caplan <[email protected]>
Reviewed-By: Guy Bedford <[email protected]>
Reviewed-By: Ben Coe <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Joyee Cheung <[email protected]>
Reviewed-By: Ruben Bridgewater <[email protected]>
Reviewed-By: Сковорода Никита Андреевич <[email protected]>
@GeoffreyBooth GeoffreyBooth removed modules-agenda To be discussed in a meeting labels May 9, 2019
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.