From 4520648cf1111c3013978743753ae34dadc20993 Mon Sep 17 00:00:00 2001 From: lectem Date: Fri, 23 Aug 2024 13:28:07 +0200 Subject: [PATCH 1/2] Do not auto pin by default COREPACK_ENABLE_AUTO_PIN=0 is now the default --- README.md | 4 ++-- sources/Engine.ts | 8 +++++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index d94614aff..46e8e8349 100644 --- a/README.md +++ b/README.md @@ -237,8 +237,8 @@ same major line. Should you need to upgrade to a new major, use an explicit package manager, and to not update the Last Known Good version when it downloads a new version of the same major line. -- `COREPACK_ENABLE_AUTO_PIN` can be set to `0` to prevent Corepack from - updating the `packageManager` field when it detects that the local package +- `COREPACK_ENABLE_AUTO_PIN` can be set to `1` to allow Corepack to + update the `packageManager` field when it detects that the local package doesn't list it. In general we recommend to always list a `packageManager` field (which you can easily set through `corepack use [name]@[version]`), as it ensures that your project installs are always deterministic. diff --git a/sources/Engine.ts b/sources/Engine.ts index b9a12dea7..22249cd22 100644 --- a/sources/Engine.ts +++ b/sources/Engine.ts @@ -263,7 +263,7 @@ export class Engine { return fallbackDescriptor; case `NoSpec`: { - if (process.env.COREPACK_ENABLE_AUTO_PIN !== `0`) { + if (process.env.COREPACK_ENABLE_AUTO_PIN === `1`) { const resolved = await this.resolveDescriptor(fallbackDescriptor, {allowTags: true}); if (resolved === null) throw new UsageError(`Failed to successfully resolve '${fallbackDescriptor.range}' to a valid ${fallbackDescriptor.name} release`); @@ -275,9 +275,11 @@ export class Engine { console.error(); await specUtils.setLocalPackageManager(path.dirname(result.target), installSpec); + } else { + debugUtils.log(`Falling back to ${fallbackDescriptor.name}@${fallbackDescriptor.range} in the absence of "packageManage" field in ${result.target}.`); + debugUtils.log(`It could be added for you automatically by setting the environment variable COREPACK_ENABLE_AUTO_PIN=1`); + debugUtils.log(`For more details about this field, consult the documentation at https://nodejs.org/api/packages.html#packagemanager`); } - - debugUtils.log(`Falling back to ${fallbackDescriptor.name}@${fallbackDescriptor.range} in the absence of "packageManage" field in ${result.target}`); return fallbackDescriptor; } From 7ffd1bd32fe5c5c79e52f88a045eda19810ae968 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Gr=C3=A9goire?= Date: Sat, 24 Aug 2024 18:59:38 +0200 Subject: [PATCH 2/2] Fix typo packageManage => packageManager Co-authored-by: Steven --- sources/Engine.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sources/Engine.ts b/sources/Engine.ts index 22249cd22..62e842ad3 100644 --- a/sources/Engine.ts +++ b/sources/Engine.ts @@ -276,7 +276,7 @@ export class Engine { await specUtils.setLocalPackageManager(path.dirname(result.target), installSpec); } else { - debugUtils.log(`Falling back to ${fallbackDescriptor.name}@${fallbackDescriptor.range} in the absence of "packageManage" field in ${result.target}.`); + debugUtils.log(`Falling back to ${fallbackDescriptor.name}@${fallbackDescriptor.range} in the absence of "packageManager" field in ${result.target}.`); debugUtils.log(`It could be added for you automatically by setting the environment variable COREPACK_ENABLE_AUTO_PIN=1`); debugUtils.log(`For more details about this field, consult the documentation at https://nodejs.org/api/packages.html#packagemanager`); }