Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add limited support for devEngines #643

Merged
merged 21 commits into from
Feb 28, 2025
Merged

Conversation

aduh95
Copy link
Contributor

@aduh95 aduh95 commented Feb 8, 2025

This implementation of devEngines support in this PR is limited to packageManager only, only one packageManager can be specified, the onFail field is ignored EDIT: I've added support for the onFail field, supporting the same values as npm.

Fixes: #567

Co-authored-by: Geoffrey Booth <[email protected]>
@styfle
Copy link
Member

styfle commented Feb 9, 2025

the onFail field is ignored

What value of onFail is used by default if its not accepting user input? download?

Copy link
Member

@styfle styfle left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How about updating the readme?

In particular, mentioning the onFail behavior and also which takes precedence when both packageManager and devEngines is defined?

@aduh95 aduh95 requested a review from styfle February 15, 2025 19:04
- if set to `warn` or some other value, Corepack will print a warning in case
of mismatch.

If the top-level `packageManager` field is missing, Corepack will use the
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should be the first sentence of this section.

Because it sounds like this devEngines.packageManager is ignored when there is a top level packageManager, right?

Copy link
Contributor Author

@aduh95 aduh95 Feb 25, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No it's never ignored. As said in the first paragraph of this section, if it is defined to something Corepack recognises, it will throw/warn/do nothing (depending of the value of onFail) if the user is trying to use an incompatible package manager (i.e. if the one defined in package.json#packageManager does not match the one defined in package.json#devEngines.packageManager for when the user is using a Corepack shim)

@@ -246,6 +275,7 @@ it.

Unlike `corepack use` this command doesn't take a package manager name nor a
version range, as it will always select the latest available version from the
range specified in `devEngines.packageManager.version`, or fallback to the
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What about top-level packageManager?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's what or fallback to the same major line is for

@aduh95

This comment was marked as resolved.

@aduh95 aduh95 merged commit b456268 into nodejs:main Feb 28, 2025
13 checks passed
@aduh95 aduh95 deleted the dev-engines-part1 branch February 28, 2025 19:06
haoqunjiang added a commit to haoqunjiang/schemastore that referenced this pull request Mar 13, 2025
madskristensen pushed a commit to SchemaStore/schemastore that referenced this pull request Mar 13, 2025
* Support `devEngines` field in `package.json`

It's a [standardization effort by the OpenJS Foundation](https://github.com/openjs-foundation/package-metadata-interoperability-collab-space/blob/43e31689ae1fff8c46b617548655a3f60e0c9387/devengines-field-proposal.md)
and has been implemented in [NPM 10.9.0](npm/cli#7766)
and [Corepack 0.32.0](nodejs/corepack#643).

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

---------

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implement devEngines proposal from Package Metadata Interoperability Collab Space
5 participants