@vercel/build-utils 8.3.4 → 8.3.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # @vercel/build-utils
2
2
 
3
+ ## 8.3.5
4
+
5
+ ### Patch Changes
6
+
7
+ - Revert "warn on mismatched corepack and detected package managers" ([#11879](https://github.com/vercel/vercel/pull/11879))
8
+
3
9
  ## 8.3.4
4
10
 
5
11
  ### Patch Changes
@@ -97,12 +97,11 @@ export declare function getEnvForPackageManager({ cliType, lockfileVersion, pack
97
97
  * Helper to get the binary paths that link to the used package manager.
98
98
  * Note: Make sure it doesn't contain any `console.log` calls.
99
99
  */
100
- export declare function getPathOverrideForPackageManager({ cliType, lockfileVersion, corepackPackageManager, corepackEnabled, }: {
100
+ export declare function getPathOverrideForPackageManager({ cliType, lockfileVersion, corepackEnabled, nodeVersion, }: {
101
101
  cliType: CliType;
102
102
  lockfileVersion: number | undefined;
103
- corepackPackageManager: string | undefined;
103
+ corepackEnabled: boolean;
104
104
  nodeVersion: NodeVersion | undefined;
105
- corepackEnabled?: boolean;
106
105
  }): {
107
106
  /**
108
107
  * Which lockfile was detected.
@@ -118,15 +117,6 @@ export declare function getPathOverrideForPackageManager({ cliType, lockfileVers
118
117
  */
119
118
  path: string | undefined;
120
119
  };
121
- export declare function detectPackageManager(cliType: CliType, lockfileVersion: number | undefined): {
122
- path: string;
123
- detectedLockfile: string;
124
- detectedPackageManager: string;
125
- } | {
126
- path: undefined;
127
- detectedLockfile: string;
128
- detectedPackageManager: string;
129
- } | undefined;
130
120
  /**
131
121
  * Helper to get the binary paths that link to the used package manager.
132
122
  * Note: Make sure it doesn't contain any `console.log` calls.
@@ -28,7 +28,6 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
29
  var run_user_scripts_exports = {};
30
30
  __export(run_user_scripts_exports, {
31
- detectPackageManager: () => detectPackageManager,
32
31
  execCommand: () => execCommand,
33
32
  getEnvForPackageManager: () => getEnvForPackageManager,
34
33
  getNodeBinPath: () => getNodeBinPath,
@@ -65,11 +64,6 @@ var import_node_version = require("./node-version");
65
64
  var import_read_config_file = require("./read-config-file");
66
65
  var import_clone_env = require("../clone-env");
67
66
  const runNpmInstallSema = new import_async_sema.default(1);
68
- const NO_OVERRIDE = {
69
- detectedLockfile: void 0,
70
- detectedPackageManager: void 0,
71
- path: void 0
72
- };
73
67
  function spawnAsync(command, args, opts = {}) {
74
68
  return new Promise((resolve, reject) => {
75
69
  const stderrLogs = [];
@@ -431,9 +425,8 @@ function getEnvForPackageManager({
431
425
  } = getPathOverrideForPackageManager({
432
426
  cliType,
433
427
  lockfileVersion,
434
- corepackPackageManager: packageJsonPackageManager,
435
- nodeVersion,
436
- corepackEnabled
428
+ corepackEnabled,
429
+ nodeVersion
437
430
  });
438
431
  if (corepackEnabled) {
439
432
  (0, import_debug.default)(
@@ -471,8 +464,10 @@ function getEnvForPackageManager({
471
464
  }
472
465
  return newEnv;
473
466
  }
474
- function detectPnpmVersion(lockfileVersion) {
467
+ function detectPnpmVersion(lockfileVersion, corepackEnabled) {
475
468
  switch (true) {
469
+ case corepackEnabled:
470
+ return "corepack_enabled";
476
471
  case lockfileVersion === void 0:
477
472
  return "not found";
478
473
  case lockfileVersion === 5.3:
@@ -487,155 +482,99 @@ function detectPnpmVersion(lockfileVersion) {
487
482
  return "not found";
488
483
  }
489
484
  }
490
- function validLockfileForPackageManager(cliType, lockfileVersion, packageManagerVersion) {
491
- const packageManagerMajorVersion = packageManagerVersion.major;
492
- switch (cliType) {
493
- case "npm":
494
- case "bun":
495
- case "yarn":
496
- return true;
497
- case "pnpm":
498
- switch (packageManagerMajorVersion) {
499
- case 9:
500
- if ("9.0.0" === packageManagerVersion.version && lockfileVersion === 6) {
501
- return false;
502
- }
503
- return [6, 7, 9].includes(lockfileVersion);
504
- case 8:
505
- return [6, 6.1].includes(lockfileVersion);
506
- case 7:
507
- return [5.3, 5.4].includes(lockfileVersion);
508
- case 6:
509
- return [5.3, 5.4].includes(lockfileVersion);
510
- default:
511
- return true;
512
- }
513
- }
485
+ function shouldUseNpm7(lockfileVersion, nodeVersion) {
486
+ if (lockfileVersion === void 0)
487
+ return false;
488
+ return lockfileVersion >= 2 && (nodeVersion?.major || 0) < 16;
514
489
  }
515
490
  function getPathOverrideForPackageManager({
516
491
  cliType,
517
492
  lockfileVersion,
518
- corepackPackageManager,
519
- corepackEnabled = true
493
+ corepackEnabled,
494
+ nodeVersion
520
495
  }) {
521
- const detectedPackageManger = detectPackageManager(cliType, lockfileVersion);
522
- if (!corepackPackageManager) {
523
- return detectedPackageManger ?? NO_OVERRIDE;
524
- }
525
- if (lockfileVersion === void 0 || !corepackEnabled) {
526
- return NO_OVERRIDE;
527
- }
528
- if (validateCorepackPackageManager(
529
- cliType,
530
- lockfileVersion,
531
- corepackPackageManager
532
- )) {
533
- return NO_OVERRIDE;
534
- }
535
- console.warn(
536
- `WARN [package-manager-warning-1] Detected lockfile "${lockfileVersion}" which is not compatible with the intended corepack package manager "${corepackPackageManager}". Update your lockfile or change to a compatible corepack version.`
537
- );
538
- return NO_OVERRIDE;
539
- }
540
- function validateCorepackPackageManager(cliType, lockfileVersion, corepackPackageManager) {
541
- const validatedCorepackPackageManager = validateVersionSpecifier(
542
- corepackPackageManager
543
- );
544
- if (!validatedCorepackPackageManager) {
545
- console.warn(
546
- `WARN [package-manager-warning-2] Intended corepack defined package manager "${corepackPackageManager}" is not a valid semver value.`
547
- );
548
- return false;
549
- }
550
- if (cliType !== validatedCorepackPackageManager.packageName) {
551
- console.warn(
552
- `WARN [package-manager-warning-3] Detected package manager "${cliType}" does not match intended corepack defined package manager "${validatedCorepackPackageManager.packageName}". Change your lockfile or "package.json#packageManager" value to match.`
553
- );
554
- return false;
555
- }
556
- const corepackPackageManagerVersion = (0, import_semver.coerce)(
557
- validatedCorepackPackageManager.packageVersionRange
558
- );
559
- if (corepackPackageManagerVersion === null) {
560
- return true;
561
- } else {
562
- return validLockfileForPackageManager(
563
- cliType,
564
- lockfileVersion,
565
- corepackPackageManagerVersion
566
- );
567
- }
568
- }
569
- function validateVersionSpecifier(version) {
570
- if (!version) {
571
- return void 0;
572
- }
573
- const [before, after, ...extra] = version.split("@");
574
- if (extra.length) {
575
- return void 0;
576
- }
577
- if (!before) {
578
- return void 0;
579
- }
580
- if (!after) {
581
- return void 0;
582
- }
583
- if (!(0, import_semver.validRange)(after)) {
584
- return void 0;
585
- }
586
- return {
587
- packageName: before,
588
- packageVersionRange: after
496
+ const no_override = {
497
+ detectedLockfile: void 0,
498
+ detectedPackageManager: void 0,
499
+ path: void 0
589
500
  };
590
- }
591
- function detectPackageManager(cliType, lockfileVersion) {
592
501
  switch (cliType) {
593
502
  case "npm":
594
- return void 0;
503
+ switch (true) {
504
+ case corepackEnabled:
505
+ return no_override;
506
+ case shouldUseNpm7(lockfileVersion, nodeVersion):
507
+ return {
508
+ path: "/node16/bin-npm7",
509
+ detectedLockfile: "package-lock.json",
510
+ detectedPackageManager: "npm 7+"
511
+ };
512
+ default:
513
+ return no_override;
514
+ }
595
515
  case "pnpm":
596
- switch (detectPnpmVersion(lockfileVersion)) {
516
+ switch (detectPnpmVersion(lockfileVersion, corepackEnabled)) {
517
+ case "corepack_enabled":
518
+ return no_override;
597
519
  case "pnpm 7":
598
520
  return {
599
521
  path: "/pnpm7/node_modules/.bin",
600
522
  detectedLockfile: "pnpm-lock.yaml",
601
- detectedPackageManager: "pnpm@7.x"
523
+ detectedPackageManager: "pnpm 7"
602
524
  };
603
525
  case "pnpm 8":
604
526
  return {
605
527
  path: "/pnpm8/node_modules/.bin",
606
528
  detectedLockfile: "pnpm-lock.yaml",
607
- detectedPackageManager: "pnpm@8.x"
529
+ detectedPackageManager: "pnpm 8"
608
530
  };
609
531
  case "pnpm 9":
610
532
  return {
611
533
  path: "/pnpm9/node_modules/.bin",
612
534
  detectedLockfile: "pnpm-lock.yaml",
613
- detectedPackageManager: "pnpm@9.x"
535
+ detectedPackageManager: "pnpm 9"
614
536
  };
615
537
  case "pnpm 6":
616
- return {
617
- // undefined because pnpm@6 is the current default in the build container
618
- path: void 0,
619
- detectedLockfile: "pnpm-lock.yaml",
620
- detectedPackageManager: "pnpm 6"
621
- };
622
538
  default:
623
- return void 0;
539
+ return no_override;
624
540
  }
625
541
  case "bun":
626
- return {
627
- path: "/bun1",
628
- detectedLockfile: "bun.lockb",
629
- detectedPackageManager: "bun@1.x"
630
- };
542
+ switch (true) {
543
+ case corepackEnabled:
544
+ return no_override;
545
+ default:
546
+ return {
547
+ path: "/bun1",
548
+ detectedLockfile: "bun.lockb",
549
+ detectedPackageManager: "Bun"
550
+ };
551
+ }
631
552
  case "yarn":
632
- return {
633
- path: void 0,
634
- detectedLockfile: "yarn.lock",
635
- detectedPackageManager: "yarn"
636
- };
553
+ return no_override;
637
554
  }
638
555
  }
556
+ function validateVersionSpecifier(version) {
557
+ if (!version) {
558
+ return void 0;
559
+ }
560
+ const [before, after, ...extra] = version.split("@");
561
+ if (extra.length) {
562
+ return void 0;
563
+ }
564
+ if (!before) {
565
+ return void 0;
566
+ }
567
+ if (!after) {
568
+ return void 0;
569
+ }
570
+ if (!(0, import_semver.validRange)(after)) {
571
+ return void 0;
572
+ }
573
+ return {
574
+ packageName: before,
575
+ packageVersionRange: after
576
+ };
577
+ }
639
578
  function getPathForPackageManager({
640
579
  cliType,
641
580
  lockfileVersion,
@@ -643,15 +582,12 @@ function getPathForPackageManager({
643
582
  env
644
583
  }) {
645
584
  const corepackEnabled = env.ENABLE_EXPERIMENTAL_COREPACK === "1";
646
- let overrides = getPathOverrideForPackageManager({
585
+ const overrides = getPathOverrideForPackageManager({
647
586
  cliType,
648
587
  lockfileVersion,
649
- corepackPackageManager: void 0,
588
+ corepackEnabled,
650
589
  nodeVersion
651
590
  });
652
- if (corepackEnabled) {
653
- overrides = NO_OVERRIDE;
654
- }
655
591
  const alreadyInPath = (newPath) => {
656
592
  const oldPath = env.PATH ?? "";
657
593
  return oldPath.split(import_path.default.delimiter).includes(newPath);
@@ -772,7 +708,6 @@ const installDependencies = (0, import_util.deprecate)(
772
708
  );
773
709
  // Annotate the CommonJS export names for ESM import in node:
774
710
  0 && (module.exports = {
775
- detectPackageManager,
776
711
  execCommand,
777
712
  getEnvForPackageManager,
778
713
  getNodeBinPath,
package/dist/index.js CHANGED
@@ -13072,7 +13072,7 @@ var require_readShebang = __commonJS({
13072
13072
  // ../../node_modules/.pnpm/semver@5.7.2/node_modules/semver/semver.js
13073
13073
  var require_semver = __commonJS({
13074
13074
  "../../node_modules/.pnpm/semver@5.7.2/node_modules/semver/semver.js"(exports2, module2) {
13075
- exports2 = module2.exports = SemVer2;
13075
+ exports2 = module2.exports = SemVer;
13076
13076
  var debug2;
13077
13077
  if (typeof process === "object" && process.env && process.env.NODE_DEBUG && /\bsemver\b/i.test(process.env.NODE_DEBUG)) {
13078
13078
  debug2 = function() {
@@ -13205,7 +13205,7 @@ var require_semver = __commonJS({
13205
13205
  includePrerelease: false
13206
13206
  };
13207
13207
  }
13208
- if (version instanceof SemVer2) {
13208
+ if (version instanceof SemVer) {
13209
13209
  return version;
13210
13210
  }
13211
13211
  if (typeof version !== "string") {
@@ -13219,7 +13219,7 @@ var require_semver = __commonJS({
13219
13219
  return null;
13220
13220
  }
13221
13221
  try {
13222
- return new SemVer2(version, options);
13222
+ return new SemVer(version, options);
13223
13223
  } catch (er) {
13224
13224
  return null;
13225
13225
  }
@@ -13234,15 +13234,15 @@ var require_semver = __commonJS({
13234
13234
  var s = parse2(version.trim().replace(/^[=v]+/, ""), options);
13235
13235
  return s ? s.version : null;
13236
13236
  }
13237
- exports2.SemVer = SemVer2;
13238
- function SemVer2(version, options) {
13237
+ exports2.SemVer = SemVer;
13238
+ function SemVer(version, options) {
13239
13239
  if (!options || typeof options !== "object") {
13240
13240
  options = {
13241
13241
  loose: !!options,
13242
13242
  includePrerelease: false
13243
13243
  };
13244
13244
  }
13245
- if (version instanceof SemVer2) {
13245
+ if (version instanceof SemVer) {
13246
13246
  if (version.loose === options.loose) {
13247
13247
  return version;
13248
13248
  } else {
@@ -13254,8 +13254,8 @@ var require_semver = __commonJS({
13254
13254
  if (version.length > MAX_LENGTH) {
13255
13255
  throw new TypeError("version is longer than " + MAX_LENGTH + " characters");
13256
13256
  }
13257
- if (!(this instanceof SemVer2)) {
13258
- return new SemVer2(version, options);
13257
+ if (!(this instanceof SemVer)) {
13258
+ return new SemVer(version, options);
13259
13259
  }
13260
13260
  debug2("SemVer", version, options);
13261
13261
  this.options = options;
@@ -13293,32 +13293,32 @@ var require_semver = __commonJS({
13293
13293
  this.build = m[5] ? m[5].split(".") : [];
13294
13294
  this.format();
13295
13295
  }
13296
- SemVer2.prototype.format = function() {
13296
+ SemVer.prototype.format = function() {
13297
13297
  this.version = this.major + "." + this.minor + "." + this.patch;
13298
13298
  if (this.prerelease.length) {
13299
13299
  this.version += "-" + this.prerelease.join(".");
13300
13300
  }
13301
13301
  return this.version;
13302
13302
  };
13303
- SemVer2.prototype.toString = function() {
13303
+ SemVer.prototype.toString = function() {
13304
13304
  return this.version;
13305
13305
  };
13306
- SemVer2.prototype.compare = function(other) {
13306
+ SemVer.prototype.compare = function(other) {
13307
13307
  debug2("SemVer.compare", this.version, this.options, other);
13308
- if (!(other instanceof SemVer2)) {
13309
- other = new SemVer2(other, this.options);
13308
+ if (!(other instanceof SemVer)) {
13309
+ other = new SemVer(other, this.options);
13310
13310
  }
13311
13311
  return this.compareMain(other) || this.comparePre(other);
13312
13312
  };
13313
- SemVer2.prototype.compareMain = function(other) {
13314
- if (!(other instanceof SemVer2)) {
13315
- other = new SemVer2(other, this.options);
13313
+ SemVer.prototype.compareMain = function(other) {
13314
+ if (!(other instanceof SemVer)) {
13315
+ other = new SemVer(other, this.options);
13316
13316
  }
13317
13317
  return compareIdentifiers(this.major, other.major) || compareIdentifiers(this.minor, other.minor) || compareIdentifiers(this.patch, other.patch);
13318
13318
  };
13319
- SemVer2.prototype.comparePre = function(other) {
13320
- if (!(other instanceof SemVer2)) {
13321
- other = new SemVer2(other, this.options);
13319
+ SemVer.prototype.comparePre = function(other) {
13320
+ if (!(other instanceof SemVer)) {
13321
+ other = new SemVer(other, this.options);
13322
13322
  }
13323
13323
  if (this.prerelease.length && !other.prerelease.length) {
13324
13324
  return -1;
@@ -13345,7 +13345,7 @@ var require_semver = __commonJS({
13345
13345
  }
13346
13346
  } while (++i2);
13347
13347
  };
13348
- SemVer2.prototype.inc = function(release, identifier) {
13348
+ SemVer.prototype.inc = function(release, identifier) {
13349
13349
  switch (release) {
13350
13350
  case "premajor":
13351
13351
  this.prerelease.length = 0;
@@ -13431,7 +13431,7 @@ var require_semver = __commonJS({
13431
13431
  loose = void 0;
13432
13432
  }
13433
13433
  try {
13434
- return new SemVer2(version, loose).inc(release, identifier).version;
13434
+ return new SemVer(version, loose).inc(release, identifier).version;
13435
13435
  } catch (er) {
13436
13436
  return null;
13437
13437
  }
@@ -13475,19 +13475,19 @@ var require_semver = __commonJS({
13475
13475
  }
13476
13476
  exports2.major = major;
13477
13477
  function major(a, loose) {
13478
- return new SemVer2(a, loose).major;
13478
+ return new SemVer(a, loose).major;
13479
13479
  }
13480
13480
  exports2.minor = minor;
13481
13481
  function minor(a, loose) {
13482
- return new SemVer2(a, loose).minor;
13482
+ return new SemVer(a, loose).minor;
13483
13483
  }
13484
13484
  exports2.patch = patch;
13485
13485
  function patch(a, loose) {
13486
- return new SemVer2(a, loose).patch;
13486
+ return new SemVer(a, loose).patch;
13487
13487
  }
13488
13488
  exports2.compare = compare;
13489
13489
  function compare(a, b, loose) {
13490
- return new SemVer2(a, loose).compare(new SemVer2(b, loose));
13490
+ return new SemVer(a, loose).compare(new SemVer(b, loose));
13491
13491
  }
13492
13492
  exports2.compareLoose = compareLoose;
13493
13493
  function compareLoose(a, b) {
@@ -13610,7 +13610,7 @@ var require_semver = __commonJS({
13610
13610
  if (!m[2]) {
13611
13611
  this.semver = ANY;
13612
13612
  } else {
13613
- this.semver = new SemVer2(m[2], this.options.loose);
13613
+ this.semver = new SemVer(m[2], this.options.loose);
13614
13614
  }
13615
13615
  };
13616
13616
  Comparator.prototype.toString = function() {
@@ -13622,7 +13622,7 @@ var require_semver = __commonJS({
13622
13622
  return true;
13623
13623
  }
13624
13624
  if (typeof version === "string") {
13625
- version = new SemVer2(version, this.options);
13625
+ version = new SemVer(version, this.options);
13626
13626
  }
13627
13627
  return cmp(version, this.operator, this.semver, this.options);
13628
13628
  };
@@ -13919,7 +13919,7 @@ var require_semver = __commonJS({
13919
13919
  return false;
13920
13920
  }
13921
13921
  if (typeof version === "string") {
13922
- version = new SemVer2(version, this.options);
13922
+ version = new SemVer(version, this.options);
13923
13923
  }
13924
13924
  for (var i2 = 0; i2 < this.set.length; i2++) {
13925
13925
  if (testSet(this.set[i2], version, this.options)) {
@@ -13973,7 +13973,7 @@ var require_semver = __commonJS({
13973
13973
  if (rangeObj.test(v)) {
13974
13974
  if (!max || maxSV.compare(v) === -1) {
13975
13975
  max = v;
13976
- maxSV = new SemVer2(max, options);
13976
+ maxSV = new SemVer(max, options);
13977
13977
  }
13978
13978
  }
13979
13979
  });
@@ -13992,7 +13992,7 @@ var require_semver = __commonJS({
13992
13992
  if (rangeObj.test(v)) {
13993
13993
  if (!min || minSV.compare(v) === 1) {
13994
13994
  min = v;
13995
- minSV = new SemVer2(min, options);
13995
+ minSV = new SemVer(min, options);
13996
13996
  }
13997
13997
  }
13998
13998
  });
@@ -14001,11 +14001,11 @@ var require_semver = __commonJS({
14001
14001
  exports2.minVersion = minVersion;
14002
14002
  function minVersion(range, loose) {
14003
14003
  range = new Range(range, loose);
14004
- var minver = new SemVer2("0.0.0");
14004
+ var minver = new SemVer("0.0.0");
14005
14005
  if (range.test(minver)) {
14006
14006
  return minver;
14007
14007
  }
14008
- minver = new SemVer2("0.0.0-0");
14008
+ minver = new SemVer("0.0.0-0");
14009
14009
  if (range.test(minver)) {
14010
14010
  return minver;
14011
14011
  }
@@ -14013,7 +14013,7 @@ var require_semver = __commonJS({
14013
14013
  for (var i2 = 0; i2 < range.set.length; ++i2) {
14014
14014
  var comparators = range.set[i2];
14015
14015
  comparators.forEach(function(comparator) {
14016
- var compver = new SemVer2(comparator.semver.version);
14016
+ var compver = new SemVer(comparator.semver.version);
14017
14017
  switch (comparator.operator) {
14018
14018
  case ">":
14019
14019
  if (compver.prerelease.length === 0) {
@@ -14059,7 +14059,7 @@ var require_semver = __commonJS({
14059
14059
  }
14060
14060
  exports2.outside = outside;
14061
14061
  function outside(version, range, hilo, options) {
14062
- version = new SemVer2(version, options);
14062
+ version = new SemVer(version, options);
14063
14063
  range = new Range(range, options);
14064
14064
  var gtfn, ltefn, ltfn, comp, ecomp;
14065
14065
  switch (hilo) {
@@ -14123,7 +14123,7 @@ var require_semver = __commonJS({
14123
14123
  }
14124
14124
  exports2.coerce = coerce2;
14125
14125
  function coerce2(version) {
14126
- if (version instanceof SemVer2) {
14126
+ if (version instanceof SemVer) {
14127
14127
  return version;
14128
14128
  }
14129
14129
  if (typeof version !== "string") {
@@ -14304,7 +14304,7 @@ var require_cross_spawn = __commonJS({
14304
14304
  // ../../node_modules/.pnpm/semver@6.3.1/node_modules/semver/semver.js
14305
14305
  var require_semver2 = __commonJS({
14306
14306
  "../../node_modules/.pnpm/semver@6.3.1/node_modules/semver/semver.js"(exports2, module2) {
14307
- exports2 = module2.exports = SemVer2;
14307
+ exports2 = module2.exports = SemVer;
14308
14308
  var debug2;
14309
14309
  if (typeof process === "object" && process.env && process.env.NODE_DEBUG && /\bsemver\b/i.test(process.env.NODE_DEBUG)) {
14310
14310
  debug2 = function() {
@@ -14446,7 +14446,7 @@ var require_semver2 = __commonJS({
14446
14446
  includePrerelease: false
14447
14447
  };
14448
14448
  }
14449
- if (version instanceof SemVer2) {
14449
+ if (version instanceof SemVer) {
14450
14450
  return version;
14451
14451
  }
14452
14452
  if (typeof version !== "string") {
@@ -14460,7 +14460,7 @@ var require_semver2 = __commonJS({
14460
14460
  return null;
14461
14461
  }
14462
14462
  try {
14463
- return new SemVer2(version, options);
14463
+ return new SemVer(version, options);
14464
14464
  } catch (er) {
14465
14465
  return null;
14466
14466
  }
@@ -14475,15 +14475,15 @@ var require_semver2 = __commonJS({
14475
14475
  var s = parse2(version.trim().replace(/^[=v]+/, ""), options);
14476
14476
  return s ? s.version : null;
14477
14477
  }
14478
- exports2.SemVer = SemVer2;
14479
- function SemVer2(version, options) {
14478
+ exports2.SemVer = SemVer;
14479
+ function SemVer(version, options) {
14480
14480
  if (!options || typeof options !== "object") {
14481
14481
  options = {
14482
14482
  loose: !!options,
14483
14483
  includePrerelease: false
14484
14484
  };
14485
14485
  }
14486
- if (version instanceof SemVer2) {
14486
+ if (version instanceof SemVer) {
14487
14487
  if (version.loose === options.loose) {
14488
14488
  return version;
14489
14489
  } else {
@@ -14495,8 +14495,8 @@ var require_semver2 = __commonJS({
14495
14495
  if (version.length > MAX_LENGTH) {
14496
14496
  throw new TypeError("version is longer than " + MAX_LENGTH + " characters");
14497
14497
  }
14498
- if (!(this instanceof SemVer2)) {
14499
- return new SemVer2(version, options);
14498
+ if (!(this instanceof SemVer)) {
14499
+ return new SemVer(version, options);
14500
14500
  }
14501
14501
  debug2("SemVer", version, options);
14502
14502
  this.options = options;
@@ -14534,32 +14534,32 @@ var require_semver2 = __commonJS({
14534
14534
  this.build = m[5] ? m[5].split(".") : [];
14535
14535
  this.format();
14536
14536
  }
14537
- SemVer2.prototype.format = function() {
14537
+ SemVer.prototype.format = function() {
14538
14538
  this.version = this.major + "." + this.minor + "." + this.patch;
14539
14539
  if (this.prerelease.length) {
14540
14540
  this.version += "-" + this.prerelease.join(".");
14541
14541
  }
14542
14542
  return this.version;
14543
14543
  };
14544
- SemVer2.prototype.toString = function() {
14544
+ SemVer.prototype.toString = function() {
14545
14545
  return this.version;
14546
14546
  };
14547
- SemVer2.prototype.compare = function(other) {
14547
+ SemVer.prototype.compare = function(other) {
14548
14548
  debug2("SemVer.compare", this.version, this.options, other);
14549
- if (!(other instanceof SemVer2)) {
14550
- other = new SemVer2(other, this.options);
14549
+ if (!(other instanceof SemVer)) {
14550
+ other = new SemVer(other, this.options);
14551
14551
  }
14552
14552
  return this.compareMain(other) || this.comparePre(other);
14553
14553
  };
14554
- SemVer2.prototype.compareMain = function(other) {
14555
- if (!(other instanceof SemVer2)) {
14556
- other = new SemVer2(other, this.options);
14554
+ SemVer.prototype.compareMain = function(other) {
14555
+ if (!(other instanceof SemVer)) {
14556
+ other = new SemVer(other, this.options);
14557
14557
  }
14558
14558
  return compareIdentifiers(this.major, other.major) || compareIdentifiers(this.minor, other.minor) || compareIdentifiers(this.patch, other.patch);
14559
14559
  };
14560
- SemVer2.prototype.comparePre = function(other) {
14561
- if (!(other instanceof SemVer2)) {
14562
- other = new SemVer2(other, this.options);
14560
+ SemVer.prototype.comparePre = function(other) {
14561
+ if (!(other instanceof SemVer)) {
14562
+ other = new SemVer(other, this.options);
14563
14563
  }
14564
14564
  if (this.prerelease.length && !other.prerelease.length) {
14565
14565
  return -1;
@@ -14586,9 +14586,9 @@ var require_semver2 = __commonJS({
14586
14586
  }
14587
14587
  } while (++i2);
14588
14588
  };
14589
- SemVer2.prototype.compareBuild = function(other) {
14590
- if (!(other instanceof SemVer2)) {
14591
- other = new SemVer2(other, this.options);
14589
+ SemVer.prototype.compareBuild = function(other) {
14590
+ if (!(other instanceof SemVer)) {
14591
+ other = new SemVer(other, this.options);
14592
14592
  }
14593
14593
  var i2 = 0;
14594
14594
  do {
@@ -14608,7 +14608,7 @@ var require_semver2 = __commonJS({
14608
14608
  }
14609
14609
  } while (++i2);
14610
14610
  };
14611
- SemVer2.prototype.inc = function(release, identifier) {
14611
+ SemVer.prototype.inc = function(release, identifier) {
14612
14612
  switch (release) {
14613
14613
  case "premajor":
14614
14614
  this.prerelease.length = 0;
@@ -14694,7 +14694,7 @@ var require_semver2 = __commonJS({
14694
14694
  loose = void 0;
14695
14695
  }
14696
14696
  try {
14697
- return new SemVer2(version, loose).inc(release, identifier).version;
14697
+ return new SemVer(version, loose).inc(release, identifier).version;
14698
14698
  } catch (er) {
14699
14699
  return null;
14700
14700
  }
@@ -14738,19 +14738,19 @@ var require_semver2 = __commonJS({
14738
14738
  }
14739
14739
  exports2.major = major;
14740
14740
  function major(a, loose) {
14741
- return new SemVer2(a, loose).major;
14741
+ return new SemVer(a, loose).major;
14742
14742
  }
14743
14743
  exports2.minor = minor;
14744
14744
  function minor(a, loose) {
14745
- return new SemVer2(a, loose).minor;
14745
+ return new SemVer(a, loose).minor;
14746
14746
  }
14747
14747
  exports2.patch = patch;
14748
14748
  function patch(a, loose) {
14749
- return new SemVer2(a, loose).patch;
14749
+ return new SemVer(a, loose).patch;
14750
14750
  }
14751
14751
  exports2.compare = compare;
14752
14752
  function compare(a, b, loose) {
14753
- return new SemVer2(a, loose).compare(new SemVer2(b, loose));
14753
+ return new SemVer(a, loose).compare(new SemVer(b, loose));
14754
14754
  }
14755
14755
  exports2.compareLoose = compareLoose;
14756
14756
  function compareLoose(a, b) {
@@ -14758,8 +14758,8 @@ var require_semver2 = __commonJS({
14758
14758
  }
14759
14759
  exports2.compareBuild = compareBuild;
14760
14760
  function compareBuild(a, b, loose) {
14761
- var versionA = new SemVer2(a, loose);
14762
- var versionB = new SemVer2(b, loose);
14761
+ var versionA = new SemVer(a, loose);
14762
+ var versionB = new SemVer(b, loose);
14763
14763
  return versionA.compare(versionB) || versionA.compareBuild(versionB);
14764
14764
  }
14765
14765
  exports2.rcompare = rcompare;
@@ -14879,7 +14879,7 @@ var require_semver2 = __commonJS({
14879
14879
  if (!m[2]) {
14880
14880
  this.semver = ANY;
14881
14881
  } else {
14882
- this.semver = new SemVer2(m[2], this.options.loose);
14882
+ this.semver = new SemVer(m[2], this.options.loose);
14883
14883
  }
14884
14884
  };
14885
14885
  Comparator.prototype.toString = function() {
@@ -14892,7 +14892,7 @@ var require_semver2 = __commonJS({
14892
14892
  }
14893
14893
  if (typeof version === "string") {
14894
14894
  try {
14895
- version = new SemVer2(version, this.options);
14895
+ version = new SemVer(version, this.options);
14896
14896
  } catch (er) {
14897
14897
  return false;
14898
14898
  }
@@ -15213,7 +15213,7 @@ var require_semver2 = __commonJS({
15213
15213
  }
15214
15214
  if (typeof version === "string") {
15215
15215
  try {
15216
- version = new SemVer2(version, this.options);
15216
+ version = new SemVer(version, this.options);
15217
15217
  } catch (er) {
15218
15218
  return false;
15219
15219
  }
@@ -15270,7 +15270,7 @@ var require_semver2 = __commonJS({
15270
15270
  if (rangeObj.test(v)) {
15271
15271
  if (!max || maxSV.compare(v) === -1) {
15272
15272
  max = v;
15273
- maxSV = new SemVer2(max, options);
15273
+ maxSV = new SemVer(max, options);
15274
15274
  }
15275
15275
  }
15276
15276
  });
@@ -15289,7 +15289,7 @@ var require_semver2 = __commonJS({
15289
15289
  if (rangeObj.test(v)) {
15290
15290
  if (!min || minSV.compare(v) === 1) {
15291
15291
  min = v;
15292
- minSV = new SemVer2(min, options);
15292
+ minSV = new SemVer(min, options);
15293
15293
  }
15294
15294
  }
15295
15295
  });
@@ -15298,11 +15298,11 @@ var require_semver2 = __commonJS({
15298
15298
  exports2.minVersion = minVersion;
15299
15299
  function minVersion(range, loose) {
15300
15300
  range = new Range(range, loose);
15301
- var minver = new SemVer2("0.0.0");
15301
+ var minver = new SemVer("0.0.0");
15302
15302
  if (range.test(minver)) {
15303
15303
  return minver;
15304
15304
  }
15305
- minver = new SemVer2("0.0.0-0");
15305
+ minver = new SemVer("0.0.0-0");
15306
15306
  if (range.test(minver)) {
15307
15307
  return minver;
15308
15308
  }
@@ -15310,7 +15310,7 @@ var require_semver2 = __commonJS({
15310
15310
  for (var i2 = 0; i2 < range.set.length; ++i2) {
15311
15311
  var comparators = range.set[i2];
15312
15312
  comparators.forEach(function(comparator) {
15313
- var compver = new SemVer2(comparator.semver.version);
15313
+ var compver = new SemVer(comparator.semver.version);
15314
15314
  switch (comparator.operator) {
15315
15315
  case ">":
15316
15316
  if (compver.prerelease.length === 0) {
@@ -15356,7 +15356,7 @@ var require_semver2 = __commonJS({
15356
15356
  }
15357
15357
  exports2.outside = outside;
15358
15358
  function outside(version, range, hilo, options) {
15359
- version = new SemVer2(version, options);
15359
+ version = new SemVer(version, options);
15360
15360
  range = new Range(range, options);
15361
15361
  var gtfn, ltefn, ltfn, comp, ecomp;
15362
15362
  switch (hilo) {
@@ -15420,7 +15420,7 @@ var require_semver2 = __commonJS({
15420
15420
  }
15421
15421
  exports2.coerce = coerce2;
15422
15422
  function coerce2(version, options) {
15423
- if (version instanceof SemVer2) {
15423
+ if (version instanceof SemVer) {
15424
15424
  return version;
15425
15425
  }
15426
15426
  if (typeof version === "number") {
@@ -21786,11 +21786,6 @@ function cloneEnv(...envs) {
21786
21786
 
21787
21787
  // src/fs/run-user-scripts.ts
21788
21788
  var runNpmInstallSema = new import_async_sema4.default(1);
21789
- var NO_OVERRIDE = {
21790
- detectedLockfile: void 0,
21791
- detectedPackageManager: void 0,
21792
- path: void 0
21793
- };
21794
21789
  function spawnAsync(command, args, opts = {}) {
21795
21790
  return new Promise((resolve, reject) => {
21796
21791
  const stderrLogs = [];
@@ -22152,9 +22147,8 @@ function getEnvForPackageManager({
22152
22147
  } = getPathOverrideForPackageManager({
22153
22148
  cliType,
22154
22149
  lockfileVersion,
22155
- corepackPackageManager: packageJsonPackageManager,
22156
- nodeVersion,
22157
- corepackEnabled
22150
+ corepackEnabled,
22151
+ nodeVersion
22158
22152
  });
22159
22153
  if (corepackEnabled) {
22160
22154
  debug(
@@ -22192,8 +22186,10 @@ function getEnvForPackageManager({
22192
22186
  }
22193
22187
  return newEnv;
22194
22188
  }
22195
- function detectPnpmVersion(lockfileVersion) {
22189
+ function detectPnpmVersion(lockfileVersion, corepackEnabled) {
22196
22190
  switch (true) {
22191
+ case corepackEnabled:
22192
+ return "corepack_enabled";
22197
22193
  case lockfileVersion === void 0:
22198
22194
  return "not found";
22199
22195
  case lockfileVersion === 5.3:
@@ -22208,155 +22204,99 @@ function detectPnpmVersion(lockfileVersion) {
22208
22204
  return "not found";
22209
22205
  }
22210
22206
  }
22211
- function validLockfileForPackageManager(cliType, lockfileVersion, packageManagerVersion) {
22212
- const packageManagerMajorVersion = packageManagerVersion.major;
22213
- switch (cliType) {
22214
- case "npm":
22215
- case "bun":
22216
- case "yarn":
22217
- return true;
22218
- case "pnpm":
22219
- switch (packageManagerMajorVersion) {
22220
- case 9:
22221
- if ("9.0.0" === packageManagerVersion.version && lockfileVersion === 6) {
22222
- return false;
22223
- }
22224
- return [6, 7, 9].includes(lockfileVersion);
22225
- case 8:
22226
- return [6, 6.1].includes(lockfileVersion);
22227
- case 7:
22228
- return [5.3, 5.4].includes(lockfileVersion);
22229
- case 6:
22230
- return [5.3, 5.4].includes(lockfileVersion);
22231
- default:
22232
- return true;
22233
- }
22234
- }
22207
+ function shouldUseNpm7(lockfileVersion, nodeVersion) {
22208
+ if (lockfileVersion === void 0)
22209
+ return false;
22210
+ return lockfileVersion >= 2 && (nodeVersion?.major || 0) < 16;
22235
22211
  }
22236
22212
  function getPathOverrideForPackageManager({
22237
22213
  cliType,
22238
22214
  lockfileVersion,
22239
- corepackPackageManager,
22240
- corepackEnabled = true
22215
+ corepackEnabled,
22216
+ nodeVersion
22241
22217
  }) {
22242
- const detectedPackageManger = detectPackageManager(cliType, lockfileVersion);
22243
- if (!corepackPackageManager) {
22244
- return detectedPackageManger ?? NO_OVERRIDE;
22245
- }
22246
- if (lockfileVersion === void 0 || !corepackEnabled) {
22247
- return NO_OVERRIDE;
22248
- }
22249
- if (validateCorepackPackageManager(
22250
- cliType,
22251
- lockfileVersion,
22252
- corepackPackageManager
22253
- )) {
22254
- return NO_OVERRIDE;
22255
- }
22256
- console.warn(
22257
- `WARN [package-manager-warning-1] Detected lockfile "${lockfileVersion}" which is not compatible with the intended corepack package manager "${corepackPackageManager}". Update your lockfile or change to a compatible corepack version.`
22258
- );
22259
- return NO_OVERRIDE;
22260
- }
22261
- function validateCorepackPackageManager(cliType, lockfileVersion, corepackPackageManager) {
22262
- const validatedCorepackPackageManager = validateVersionSpecifier(
22263
- corepackPackageManager
22264
- );
22265
- if (!validatedCorepackPackageManager) {
22266
- console.warn(
22267
- `WARN [package-manager-warning-2] Intended corepack defined package manager "${corepackPackageManager}" is not a valid semver value.`
22268
- );
22269
- return false;
22270
- }
22271
- if (cliType !== validatedCorepackPackageManager.packageName) {
22272
- console.warn(
22273
- `WARN [package-manager-warning-3] Detected package manager "${cliType}" does not match intended corepack defined package manager "${validatedCorepackPackageManager.packageName}". Change your lockfile or "package.json#packageManager" value to match.`
22274
- );
22275
- return false;
22276
- }
22277
- const corepackPackageManagerVersion = (0, import_semver2.coerce)(
22278
- validatedCorepackPackageManager.packageVersionRange
22279
- );
22280
- if (corepackPackageManagerVersion === null) {
22281
- return true;
22282
- } else {
22283
- return validLockfileForPackageManager(
22284
- cliType,
22285
- lockfileVersion,
22286
- corepackPackageManagerVersion
22287
- );
22288
- }
22289
- }
22290
- function validateVersionSpecifier(version) {
22291
- if (!version) {
22292
- return void 0;
22293
- }
22294
- const [before, after, ...extra] = version.split("@");
22295
- if (extra.length) {
22296
- return void 0;
22297
- }
22298
- if (!before) {
22299
- return void 0;
22300
- }
22301
- if (!after) {
22302
- return void 0;
22303
- }
22304
- if (!(0, import_semver2.validRange)(after)) {
22305
- return void 0;
22306
- }
22307
- return {
22308
- packageName: before,
22309
- packageVersionRange: after
22218
+ const no_override = {
22219
+ detectedLockfile: void 0,
22220
+ detectedPackageManager: void 0,
22221
+ path: void 0
22310
22222
  };
22311
- }
22312
- function detectPackageManager(cliType, lockfileVersion) {
22313
22223
  switch (cliType) {
22314
22224
  case "npm":
22315
- return void 0;
22225
+ switch (true) {
22226
+ case corepackEnabled:
22227
+ return no_override;
22228
+ case shouldUseNpm7(lockfileVersion, nodeVersion):
22229
+ return {
22230
+ path: "/node16/bin-npm7",
22231
+ detectedLockfile: "package-lock.json",
22232
+ detectedPackageManager: "npm 7+"
22233
+ };
22234
+ default:
22235
+ return no_override;
22236
+ }
22316
22237
  case "pnpm":
22317
- switch (detectPnpmVersion(lockfileVersion)) {
22238
+ switch (detectPnpmVersion(lockfileVersion, corepackEnabled)) {
22239
+ case "corepack_enabled":
22240
+ return no_override;
22318
22241
  case "pnpm 7":
22319
22242
  return {
22320
22243
  path: "/pnpm7/node_modules/.bin",
22321
22244
  detectedLockfile: "pnpm-lock.yaml",
22322
- detectedPackageManager: "pnpm@7.x"
22245
+ detectedPackageManager: "pnpm 7"
22323
22246
  };
22324
22247
  case "pnpm 8":
22325
22248
  return {
22326
22249
  path: "/pnpm8/node_modules/.bin",
22327
22250
  detectedLockfile: "pnpm-lock.yaml",
22328
- detectedPackageManager: "pnpm@8.x"
22251
+ detectedPackageManager: "pnpm 8"
22329
22252
  };
22330
22253
  case "pnpm 9":
22331
22254
  return {
22332
22255
  path: "/pnpm9/node_modules/.bin",
22333
22256
  detectedLockfile: "pnpm-lock.yaml",
22334
- detectedPackageManager: "pnpm@9.x"
22257
+ detectedPackageManager: "pnpm 9"
22335
22258
  };
22336
22259
  case "pnpm 6":
22337
- return {
22338
- // undefined because pnpm@6 is the current default in the build container
22339
- path: void 0,
22340
- detectedLockfile: "pnpm-lock.yaml",
22341
- detectedPackageManager: "pnpm 6"
22342
- };
22343
22260
  default:
22344
- return void 0;
22261
+ return no_override;
22345
22262
  }
22346
22263
  case "bun":
22347
- return {
22348
- path: "/bun1",
22349
- detectedLockfile: "bun.lockb",
22350
- detectedPackageManager: "bun@1.x"
22351
- };
22264
+ switch (true) {
22265
+ case corepackEnabled:
22266
+ return no_override;
22267
+ default:
22268
+ return {
22269
+ path: "/bun1",
22270
+ detectedLockfile: "bun.lockb",
22271
+ detectedPackageManager: "Bun"
22272
+ };
22273
+ }
22352
22274
  case "yarn":
22353
- return {
22354
- path: void 0,
22355
- detectedLockfile: "yarn.lock",
22356
- detectedPackageManager: "yarn"
22357
- };
22275
+ return no_override;
22358
22276
  }
22359
22277
  }
22278
+ function validateVersionSpecifier(version) {
22279
+ if (!version) {
22280
+ return void 0;
22281
+ }
22282
+ const [before, after, ...extra] = version.split("@");
22283
+ if (extra.length) {
22284
+ return void 0;
22285
+ }
22286
+ if (!before) {
22287
+ return void 0;
22288
+ }
22289
+ if (!after) {
22290
+ return void 0;
22291
+ }
22292
+ if (!(0, import_semver2.validRange)(after)) {
22293
+ return void 0;
22294
+ }
22295
+ return {
22296
+ packageName: before,
22297
+ packageVersionRange: after
22298
+ };
22299
+ }
22360
22300
  function getPathForPackageManager({
22361
22301
  cliType,
22362
22302
  lockfileVersion,
@@ -22364,15 +22304,12 @@ function getPathForPackageManager({
22364
22304
  env
22365
22305
  }) {
22366
22306
  const corepackEnabled = env.ENABLE_EXPERIMENTAL_COREPACK === "1";
22367
- let overrides = getPathOverrideForPackageManager({
22307
+ const overrides = getPathOverrideForPackageManager({
22368
22308
  cliType,
22369
22309
  lockfileVersion,
22370
- corepackPackageManager: void 0,
22310
+ corepackEnabled,
22371
22311
  nodeVersion
22372
22312
  });
22373
- if (corepackEnabled) {
22374
- overrides = NO_OVERRIDE;
22375
- }
22376
22313
  const alreadyInPath = (newPath) => {
22377
22314
  const oldPath = env.PATH ?? "";
22378
22315
  return oldPath.split(import_path5.default.delimiter).includes(newPath);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vercel/build-utils",
3
- "version": "8.3.4",
3
+ "version": "8.3.5",
4
4
  "license": "Apache-2.0",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.js",