@vercel/build-utils 8.3.0 → 8.3.2

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,17 @@
1
1
  # @vercel/build-utils
2
2
 
3
+ ## 8.3.2
4
+
5
+ ### Patch Changes
6
+
7
+ - reject mismatched corepack and detected package managers ([#11603](https://github.com/vercel/vercel/pull/11603))
8
+
9
+ ## 8.3.1
10
+
11
+ ### Patch Changes
12
+
13
+ - Add build callback handling ([#11807](https://github.com/vercel/vercel/pull/11807))
14
+
3
15
  ## 8.3.0
4
16
 
5
17
  ### Minor Changes
@@ -97,11 +97,12 @@ 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, corepackEnabled, nodeVersion, }: {
100
+ export declare function getPathOverrideForPackageManager({ cliType, lockfileVersion, corepackPackageManager, corepackEnabled, }: {
101
101
  cliType: CliType;
102
102
  lockfileVersion: number | undefined;
103
- corepackEnabled: boolean;
103
+ corepackPackageManager: string | undefined;
104
104
  nodeVersion: NodeVersion | undefined;
105
+ corepackEnabled?: boolean;
105
106
  }): {
106
107
  /**
107
108
  * Which lockfile was detected.
@@ -117,6 +118,15 @@ export declare function getPathOverrideForPackageManager({ cliType, lockfileVers
117
118
  */
118
119
  path: string | undefined;
119
120
  };
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;
120
130
  /**
121
131
  * Helper to get the binary paths that link to the used package manager.
122
132
  * Note: Make sure it doesn't contain any `console.log` calls.
@@ -28,6 +28,7 @@ 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,
31
32
  execCommand: () => execCommand,
32
33
  getEnvForPackageManager: () => getEnvForPackageManager,
33
34
  getNodeBinPath: () => getNodeBinPath,
@@ -64,6 +65,11 @@ var import_node_version = require("./node-version");
64
65
  var import_read_config_file = require("./read-config-file");
65
66
  var import_clone_env = require("../clone-env");
66
67
  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
+ };
67
73
  function spawnAsync(command, args, opts = {}) {
68
74
  return new Promise((resolve, reject) => {
69
75
  const stderrLogs = [];
@@ -425,8 +431,9 @@ function getEnvForPackageManager({
425
431
  } = getPathOverrideForPackageManager({
426
432
  cliType,
427
433
  lockfileVersion,
428
- corepackEnabled,
429
- nodeVersion
434
+ corepackPackageManager: packageJsonPackageManager,
435
+ nodeVersion,
436
+ corepackEnabled
430
437
  });
431
438
  if (corepackEnabled) {
432
439
  (0, import_debug.default)(
@@ -464,10 +471,8 @@ function getEnvForPackageManager({
464
471
  }
465
472
  return newEnv;
466
473
  }
467
- function detectPnpmVersion(lockfileVersion, corepackEnabled) {
474
+ function detectPnpmVersion(lockfileVersion) {
468
475
  switch (true) {
469
- case corepackEnabled:
470
- return "corepack_enabled";
471
476
  case lockfileVersion === void 0:
472
477
  return "not found";
473
478
  case lockfileVersion === 5.3:
@@ -482,98 +487,154 @@ function detectPnpmVersion(lockfileVersion, corepackEnabled) {
482
487
  return "not found";
483
488
  }
484
489
  }
485
- function shouldUseNpm7(lockfileVersion, nodeVersion) {
486
- if (lockfileVersion === void 0)
487
- return false;
488
- return lockfileVersion >= 2 && (nodeVersion?.major || 0) < 16;
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
+ }
489
514
  }
490
515
  function getPathOverrideForPackageManager({
491
516
  cliType,
492
517
  lockfileVersion,
493
- corepackEnabled,
494
- nodeVersion
518
+ corepackPackageManager,
519
+ corepackEnabled = true
495
520
  }) {
496
- const no_override = {
497
- detectedLockfile: void 0,
498
- detectedPackageManager: void 0,
499
- path: void 0
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
500
589
  };
590
+ }
591
+ function detectPackageManager(cliType, lockfileVersion) {
501
592
  switch (cliType) {
502
593
  case "npm":
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
- }
594
+ return void 0;
515
595
  case "pnpm":
516
- switch (detectPnpmVersion(lockfileVersion, corepackEnabled)) {
517
- case "corepack_enabled":
518
- return no_override;
596
+ switch (detectPnpmVersion(lockfileVersion)) {
519
597
  case "pnpm 7":
520
598
  return {
521
599
  path: "/pnpm7/node_modules/.bin",
522
600
  detectedLockfile: "pnpm-lock.yaml",
523
- detectedPackageManager: "pnpm 7"
601
+ detectedPackageManager: "pnpm@7.x"
524
602
  };
525
603
  case "pnpm 8":
526
604
  return {
527
605
  path: "/pnpm8/node_modules/.bin",
528
606
  detectedLockfile: "pnpm-lock.yaml",
529
- detectedPackageManager: "pnpm 8"
607
+ detectedPackageManager: "pnpm@8.x"
530
608
  };
531
609
  case "pnpm 9":
532
610
  return {
533
611
  path: "/pnpm9/node_modules/.bin",
534
612
  detectedLockfile: "pnpm-lock.yaml",
535
- detectedPackageManager: "pnpm 9"
613
+ detectedPackageManager: "pnpm@9.x"
536
614
  };
537
615
  case "pnpm 6":
538
- default:
539
- return no_override;
540
- }
541
- case "bun":
542
- switch (true) {
543
- case corepackEnabled:
544
- return no_override;
545
- default:
546
616
  return {
547
- path: "/bun1",
548
- detectedLockfile: "bun.lockb",
549
- detectedPackageManager: "Bun"
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"
550
621
  };
622
+ default:
623
+ return void 0;
551
624
  }
625
+ case "bun":
626
+ return {
627
+ path: "/bun1",
628
+ detectedLockfile: "bun.lockb",
629
+ detectedPackageManager: "bun@1.x"
630
+ };
552
631
  case "yarn":
553
- return no_override;
554
- }
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;
632
+ return {
633
+ path: void 0,
634
+ detectedLockfile: "yarn.lock",
635
+ detectedPackageManager: "yarn"
636
+ };
572
637
  }
573
- return {
574
- packageName: before,
575
- packageVersionRange: after
576
- };
577
638
  }
578
639
  function getPathForPackageManager({
579
640
  cliType,
@@ -582,12 +643,15 @@ function getPathForPackageManager({
582
643
  env
583
644
  }) {
584
645
  const corepackEnabled = env.ENABLE_EXPERIMENTAL_COREPACK === "1";
585
- const overrides = getPathOverrideForPackageManager({
646
+ let overrides = getPathOverrideForPackageManager({
586
647
  cliType,
587
648
  lockfileVersion,
588
- corepackEnabled,
649
+ corepackPackageManager: void 0,
589
650
  nodeVersion
590
651
  });
652
+ if (corepackEnabled) {
653
+ overrides = NO_OVERRIDE;
654
+ }
591
655
  const alreadyInPath = (newPath) => {
592
656
  const oldPath = env.PATH ?? "";
593
657
  return oldPath.split(import_path.default.delimiter).includes(newPath);
@@ -708,6 +772,7 @@ const installDependencies = (0, import_util.deprecate)(
708
772
  );
709
773
  // Annotate the CommonJS export names for ESM import in node:
710
774
  0 && (module.exports = {
775
+ detectPackageManager,
711
776
  execCommand,
712
777
  getEnvForPackageManager,
713
778
  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 = SemVer;
13075
+ exports2 = module2.exports = SemVer2;
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 SemVer) {
13208
+ if (version instanceof SemVer2) {
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 SemVer(version, options);
13222
+ return new SemVer2(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 = SemVer;
13238
- function SemVer(version, options) {
13237
+ exports2.SemVer = SemVer2;
13238
+ function SemVer2(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 SemVer) {
13245
+ if (version instanceof SemVer2) {
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 SemVer)) {
13258
- return new SemVer(version, options);
13257
+ if (!(this instanceof SemVer2)) {
13258
+ return new SemVer2(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
- SemVer.prototype.format = function() {
13296
+ SemVer2.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
- SemVer.prototype.toString = function() {
13303
+ SemVer2.prototype.toString = function() {
13304
13304
  return this.version;
13305
13305
  };
13306
- SemVer.prototype.compare = function(other) {
13306
+ SemVer2.prototype.compare = function(other) {
13307
13307
  debug2("SemVer.compare", this.version, this.options, other);
13308
- if (!(other instanceof SemVer)) {
13309
- other = new SemVer(other, this.options);
13308
+ if (!(other instanceof SemVer2)) {
13309
+ other = new SemVer2(other, this.options);
13310
13310
  }
13311
13311
  return this.compareMain(other) || this.comparePre(other);
13312
13312
  };
13313
- SemVer.prototype.compareMain = function(other) {
13314
- if (!(other instanceof SemVer)) {
13315
- other = new SemVer(other, this.options);
13313
+ SemVer2.prototype.compareMain = function(other) {
13314
+ if (!(other instanceof SemVer2)) {
13315
+ other = new SemVer2(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
- SemVer.prototype.comparePre = function(other) {
13320
- if (!(other instanceof SemVer)) {
13321
- other = new SemVer(other, this.options);
13319
+ SemVer2.prototype.comparePre = function(other) {
13320
+ if (!(other instanceof SemVer2)) {
13321
+ other = new SemVer2(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
- SemVer.prototype.inc = function(release, identifier) {
13348
+ SemVer2.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 SemVer(version, loose).inc(release, identifier).version;
13434
+ return new SemVer2(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 SemVer(a, loose).major;
13478
+ return new SemVer2(a, loose).major;
13479
13479
  }
13480
13480
  exports2.minor = minor;
13481
13481
  function minor(a, loose) {
13482
- return new SemVer(a, loose).minor;
13482
+ return new SemVer2(a, loose).minor;
13483
13483
  }
13484
13484
  exports2.patch = patch;
13485
13485
  function patch(a, loose) {
13486
- return new SemVer(a, loose).patch;
13486
+ return new SemVer2(a, loose).patch;
13487
13487
  }
13488
13488
  exports2.compare = compare;
13489
13489
  function compare(a, b, loose) {
13490
- return new SemVer(a, loose).compare(new SemVer(b, loose));
13490
+ return new SemVer2(a, loose).compare(new SemVer2(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 SemVer(m[2], this.options.loose);
13613
+ this.semver = new SemVer2(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 SemVer(version, this.options);
13625
+ version = new SemVer2(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 SemVer(version, this.options);
13922
+ version = new SemVer2(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 SemVer(max, options);
13976
+ maxSV = new SemVer2(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 SemVer(min, options);
13995
+ minSV = new SemVer2(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 SemVer("0.0.0");
14004
+ var minver = new SemVer2("0.0.0");
14005
14005
  if (range.test(minver)) {
14006
14006
  return minver;
14007
14007
  }
14008
- minver = new SemVer("0.0.0-0");
14008
+ minver = new SemVer2("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 SemVer(comparator.semver.version);
14016
+ var compver = new SemVer2(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 SemVer(version, options);
14062
+ version = new SemVer2(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 SemVer) {
14126
+ if (version instanceof SemVer2) {
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 = SemVer;
14307
+ exports2 = module2.exports = SemVer2;
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 SemVer) {
14449
+ if (version instanceof SemVer2) {
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 SemVer(version, options);
14463
+ return new SemVer2(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 = SemVer;
14479
- function SemVer(version, options) {
14478
+ exports2.SemVer = SemVer2;
14479
+ function SemVer2(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 SemVer) {
14486
+ if (version instanceof SemVer2) {
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 SemVer)) {
14499
- return new SemVer(version, options);
14498
+ if (!(this instanceof SemVer2)) {
14499
+ return new SemVer2(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
- SemVer.prototype.format = function() {
14537
+ SemVer2.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
- SemVer.prototype.toString = function() {
14544
+ SemVer2.prototype.toString = function() {
14545
14545
  return this.version;
14546
14546
  };
14547
- SemVer.prototype.compare = function(other) {
14547
+ SemVer2.prototype.compare = function(other) {
14548
14548
  debug2("SemVer.compare", this.version, this.options, other);
14549
- if (!(other instanceof SemVer)) {
14550
- other = new SemVer(other, this.options);
14549
+ if (!(other instanceof SemVer2)) {
14550
+ other = new SemVer2(other, this.options);
14551
14551
  }
14552
14552
  return this.compareMain(other) || this.comparePre(other);
14553
14553
  };
14554
- SemVer.prototype.compareMain = function(other) {
14555
- if (!(other instanceof SemVer)) {
14556
- other = new SemVer(other, this.options);
14554
+ SemVer2.prototype.compareMain = function(other) {
14555
+ if (!(other instanceof SemVer2)) {
14556
+ other = new SemVer2(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
- SemVer.prototype.comparePre = function(other) {
14561
- if (!(other instanceof SemVer)) {
14562
- other = new SemVer(other, this.options);
14560
+ SemVer2.prototype.comparePre = function(other) {
14561
+ if (!(other instanceof SemVer2)) {
14562
+ other = new SemVer2(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
- SemVer.prototype.compareBuild = function(other) {
14590
- if (!(other instanceof SemVer)) {
14591
- other = new SemVer(other, this.options);
14589
+ SemVer2.prototype.compareBuild = function(other) {
14590
+ if (!(other instanceof SemVer2)) {
14591
+ other = new SemVer2(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
- SemVer.prototype.inc = function(release, identifier) {
14611
+ SemVer2.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 SemVer(version, loose).inc(release, identifier).version;
14697
+ return new SemVer2(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 SemVer(a, loose).major;
14741
+ return new SemVer2(a, loose).major;
14742
14742
  }
14743
14743
  exports2.minor = minor;
14744
14744
  function minor(a, loose) {
14745
- return new SemVer(a, loose).minor;
14745
+ return new SemVer2(a, loose).minor;
14746
14746
  }
14747
14747
  exports2.patch = patch;
14748
14748
  function patch(a, loose) {
14749
- return new SemVer(a, loose).patch;
14749
+ return new SemVer2(a, loose).patch;
14750
14750
  }
14751
14751
  exports2.compare = compare;
14752
14752
  function compare(a, b, loose) {
14753
- return new SemVer(a, loose).compare(new SemVer(b, loose));
14753
+ return new SemVer2(a, loose).compare(new SemVer2(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 SemVer(a, loose);
14762
- var versionB = new SemVer(b, loose);
14761
+ var versionA = new SemVer2(a, loose);
14762
+ var versionB = new SemVer2(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 SemVer(m[2], this.options.loose);
14882
+ this.semver = new SemVer2(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 SemVer(version, this.options);
14895
+ version = new SemVer2(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 SemVer(version, this.options);
15216
+ version = new SemVer2(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 SemVer(max, options);
15273
+ maxSV = new SemVer2(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 SemVer(min, options);
15292
+ minSV = new SemVer2(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 SemVer("0.0.0");
15301
+ var minver = new SemVer2("0.0.0");
15302
15302
  if (range.test(minver)) {
15303
15303
  return minver;
15304
15304
  }
15305
- minver = new SemVer("0.0.0-0");
15305
+ minver = new SemVer2("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 SemVer(comparator.semver.version);
15313
+ var compver = new SemVer2(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 SemVer(version, options);
15359
+ version = new SemVer2(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 SemVer) {
15423
+ if (version instanceof SemVer2) {
15424
15424
  return version;
15425
15425
  }
15426
15426
  if (typeof version === "number") {
@@ -21786,6 +21786,11 @@ 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
+ };
21789
21794
  function spawnAsync(command, args, opts = {}) {
21790
21795
  return new Promise((resolve, reject) => {
21791
21796
  const stderrLogs = [];
@@ -22147,8 +22152,9 @@ function getEnvForPackageManager({
22147
22152
  } = getPathOverrideForPackageManager({
22148
22153
  cliType,
22149
22154
  lockfileVersion,
22150
- corepackEnabled,
22151
- nodeVersion
22155
+ corepackPackageManager: packageJsonPackageManager,
22156
+ nodeVersion,
22157
+ corepackEnabled
22152
22158
  });
22153
22159
  if (corepackEnabled) {
22154
22160
  debug(
@@ -22186,10 +22192,8 @@ function getEnvForPackageManager({
22186
22192
  }
22187
22193
  return newEnv;
22188
22194
  }
22189
- function detectPnpmVersion(lockfileVersion, corepackEnabled) {
22195
+ function detectPnpmVersion(lockfileVersion) {
22190
22196
  switch (true) {
22191
- case corepackEnabled:
22192
- return "corepack_enabled";
22193
22197
  case lockfileVersion === void 0:
22194
22198
  return "not found";
22195
22199
  case lockfileVersion === 5.3:
@@ -22204,98 +22208,154 @@ function detectPnpmVersion(lockfileVersion, corepackEnabled) {
22204
22208
  return "not found";
22205
22209
  }
22206
22210
  }
22207
- function shouldUseNpm7(lockfileVersion, nodeVersion) {
22208
- if (lockfileVersion === void 0)
22209
- return false;
22210
- return lockfileVersion >= 2 && (nodeVersion?.major || 0) < 16;
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
+ }
22211
22235
  }
22212
22236
  function getPathOverrideForPackageManager({
22213
22237
  cliType,
22214
22238
  lockfileVersion,
22215
- corepackEnabled,
22216
- nodeVersion
22239
+ corepackPackageManager,
22240
+ corepackEnabled = true
22217
22241
  }) {
22218
- const no_override = {
22219
- detectedLockfile: void 0,
22220
- detectedPackageManager: void 0,
22221
- path: void 0
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
22222
22310
  };
22311
+ }
22312
+ function detectPackageManager(cliType, lockfileVersion) {
22223
22313
  switch (cliType) {
22224
22314
  case "npm":
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
- }
22315
+ return void 0;
22237
22316
  case "pnpm":
22238
- switch (detectPnpmVersion(lockfileVersion, corepackEnabled)) {
22239
- case "corepack_enabled":
22240
- return no_override;
22317
+ switch (detectPnpmVersion(lockfileVersion)) {
22241
22318
  case "pnpm 7":
22242
22319
  return {
22243
22320
  path: "/pnpm7/node_modules/.bin",
22244
22321
  detectedLockfile: "pnpm-lock.yaml",
22245
- detectedPackageManager: "pnpm 7"
22322
+ detectedPackageManager: "pnpm@7.x"
22246
22323
  };
22247
22324
  case "pnpm 8":
22248
22325
  return {
22249
22326
  path: "/pnpm8/node_modules/.bin",
22250
22327
  detectedLockfile: "pnpm-lock.yaml",
22251
- detectedPackageManager: "pnpm 8"
22328
+ detectedPackageManager: "pnpm@8.x"
22252
22329
  };
22253
22330
  case "pnpm 9":
22254
22331
  return {
22255
22332
  path: "/pnpm9/node_modules/.bin",
22256
22333
  detectedLockfile: "pnpm-lock.yaml",
22257
- detectedPackageManager: "pnpm 9"
22334
+ detectedPackageManager: "pnpm@9.x"
22258
22335
  };
22259
22336
  case "pnpm 6":
22260
- default:
22261
- return no_override;
22262
- }
22263
- case "bun":
22264
- switch (true) {
22265
- case corepackEnabled:
22266
- return no_override;
22267
- default:
22268
22337
  return {
22269
- path: "/bun1",
22270
- detectedLockfile: "bun.lockb",
22271
- detectedPackageManager: "Bun"
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"
22272
22342
  };
22343
+ default:
22344
+ return void 0;
22273
22345
  }
22346
+ case "bun":
22347
+ return {
22348
+ path: "/bun1",
22349
+ detectedLockfile: "bun.lockb",
22350
+ detectedPackageManager: "bun@1.x"
22351
+ };
22274
22352
  case "yarn":
22275
- return no_override;
22276
- }
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;
22353
+ return {
22354
+ path: void 0,
22355
+ detectedLockfile: "yarn.lock",
22356
+ detectedPackageManager: "yarn"
22357
+ };
22294
22358
  }
22295
- return {
22296
- packageName: before,
22297
- packageVersionRange: after
22298
- };
22299
22359
  }
22300
22360
  function getPathForPackageManager({
22301
22361
  cliType,
@@ -22304,12 +22364,15 @@ function getPathForPackageManager({
22304
22364
  env
22305
22365
  }) {
22306
22366
  const corepackEnabled = env.ENABLE_EXPERIMENTAL_COREPACK === "1";
22307
- const overrides = getPathOverrideForPackageManager({
22367
+ let overrides = getPathOverrideForPackageManager({
22308
22368
  cliType,
22309
22369
  lockfileVersion,
22310
- corepackEnabled,
22370
+ corepackPackageManager: void 0,
22311
22371
  nodeVersion
22312
22372
  });
22373
+ if (corepackEnabled) {
22374
+ overrides = NO_OVERRIDE;
22375
+ }
22313
22376
  const alreadyInPath = (newPath) => {
22314
22377
  const oldPath = env.PATH ?? "";
22315
22378
  return oldPath.split(import_path5.default.delimiter).includes(newPath);
package/dist/types.d.ts CHANGED
@@ -96,6 +96,12 @@ export interface BuildOptions {
96
96
  * on the build environment.
97
97
  */
98
98
  meta?: Meta;
99
+ /**
100
+ * A callback to be invoked by a builder after a project's
101
+ * build command has been run but before the outputs have been
102
+ * fully processed
103
+ */
104
+ buildCallback?: (opts: Omit<BuildOptions, 'buildCallback'>) => Promise<void>;
99
105
  }
100
106
  export interface PrepareCacheOptions {
101
107
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vercel/build-utils",
3
- "version": "8.3.0",
3
+ "version": "8.3.2",
4
4
  "license": "Apache-2.0",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.js",