pnpm 7.12.0-0 → 7.12.1

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.
@@ -7,11 +7,11 @@ included:
7
7
  injectedDeps: {}
8
8
  layoutVersion: 5
9
9
  nodeLinker: hoisted
10
- packageManager: pnpm@7.11.1-0
10
+ packageManager: pnpm@7.12.0
11
11
  pendingBuilds:
12
12
  - /node-gyp/9.1.0
13
13
  - /encoding/0.1.13
14
- prunedAt: Thu, 15 Sep 2022 21:47:12 GMT
14
+ prunedAt: Tue, 20 Sep 2022 00:37:24 GMT
15
15
  publicHoistPattern:
16
16
  - '*eslint*'
17
17
  - '*prettier*'
package/dist/pnpm.cjs CHANGED
@@ -3206,7 +3206,7 @@ var require_lib4 = __commonJS({
3206
3206
  var load_json_file_1 = __importDefault(require_load_json_file());
3207
3207
  var defaultManifest = {
3208
3208
  name: "pnpm" != null && true ? "pnpm" : "pnpm",
3209
- version: "7.12.0-0" != null && true ? "7.12.0-0" : "0.0.0"
3209
+ version: "7.12.1" != null && true ? "7.12.1" : "0.0.0"
3210
3210
  };
3211
3211
  var pkgJson;
3212
3212
  if (require.main == null) {
@@ -128857,7 +128857,12 @@ var require_nodeIdUtils = __commonJS({
128857
128857
  "../resolve-dependencies/lib/nodeIdUtils.js"(exports2) {
128858
128858
  "use strict";
128859
128859
  Object.defineProperty(exports2, "__esModule", { value: true });
128860
- exports2.splitNodeId = exports2.createNodeId = exports2.nodeIdContainsSequence = void 0;
128860
+ exports2.splitNodeId = exports2.createNodeId = exports2.nodeIdContainsSequence = exports2.nodeIdContains = void 0;
128861
+ function nodeIdContains(nodeId, pkgId) {
128862
+ const pkgIds = splitNodeId(nodeId);
128863
+ return pkgIds.includes(pkgId);
128864
+ }
128865
+ exports2.nodeIdContains = nodeIdContains;
128861
128866
  function nodeIdContainsSequence(nodeId, pkgId1, pkgId2) {
128862
128867
  const pkgIds = splitNodeId(nodeId);
128863
128868
  pkgIds.pop();
@@ -131504,7 +131509,10 @@ var require_resolveDependencies = __commonJS({
131504
131509
  var pick_registry_for_package_1 = __importDefault(require_lib63());
131505
131510
  var dp = __importStar2(require_lib66());
131506
131511
  var path_exists_1 = __importDefault(require_path_exists());
131512
+ var p_defer_1 = __importDefault(require_p_defer2());
131513
+ var promise_share_1 = __importDefault(require_promise_share());
131507
131514
  var isEmpty_1 = __importDefault(require_isEmpty2());
131515
+ var fromPairs_1 = __importDefault(require_fromPairs());
131508
131516
  var omit_1 = __importDefault(require_omit());
131509
131517
  var zipWith_1 = __importDefault(require_zipWith2());
131510
131518
  var semver_12 = __importDefault(require_semver2());
@@ -131543,11 +131551,15 @@ var require_resolveDependencies = __commonJS({
131543
131551
  if (!Object.keys(importerResolutionResult.missingPeers).length)
131544
131552
  break;
131545
131553
  const wantedDependencies = (0, getNonDevWantedDependencies_1.default)({ dependencies: importerResolutionResult.missingPeers });
131546
- importerResolutionResult = await resolveDependencies(ctx, preferredVersions, wantedDependencies, {
131554
+ const resolveDependenciesResult = await resolveDependencies(ctx, preferredVersions, wantedDependencies, {
131547
131555
  ...options,
131548
131556
  parentPkgAliases,
131549
131557
  publishedBy
131550
131558
  });
131559
+ importerResolutionResult = {
131560
+ pkgAddresses: resolveDependenciesResult.pkgAddresses,
131561
+ ...await resolveDependenciesResult.resolvingPeers
131562
+ };
131551
131563
  pkgAddresses.push(...importerResolutionResult.pkgAddresses);
131552
131564
  }
131553
131565
  return pkgAddresses;
@@ -131566,20 +131578,24 @@ var require_resolveDependencies = __commonJS({
131566
131578
  const pickLowestVersion = ctx.resolutionMode === "time-based";
131567
131579
  const resolveResults = await Promise.all((0, zipWith_1.default)(async (extendedWantedDeps, importer) => {
131568
131580
  const postponedResolutionsQueue = [];
131581
+ const postponedPeersResolutionQueue = [];
131569
131582
  const pkgAddresses = [];
131570
131583
  (await Promise.all(extendedWantedDeps.map((extendedWantedDep) => resolveDependenciesOfDependency(ctx, importer.preferredVersions, {
131571
131584
  ...importer.options,
131572
131585
  parentPkgAliases: importer.parentPkgAliases,
131573
131586
  pickLowestVersion: pickLowestVersion && !importer.updatePackageManifest
131574
- }, extendedWantedDep)))).forEach(({ resolveDependencyResult, postponedResolution }) => {
131587
+ }, extendedWantedDep)))).forEach(({ resolveDependencyResult, postponedPeersResolution, postponedResolution }) => {
131575
131588
  if (resolveDependencyResult) {
131576
131589
  pkgAddresses.push(resolveDependencyResult);
131577
131590
  }
131578
131591
  if (postponedResolution) {
131579
131592
  postponedResolutionsQueue.push(postponedResolution);
131580
131593
  }
131594
+ if (postponedPeersResolution) {
131595
+ postponedPeersResolutionQueue.push(postponedPeersResolution);
131596
+ }
131581
131597
  });
131582
- return { pkgAddresses, postponedResolutionsQueue };
131598
+ return { pkgAddresses, postponedResolutionsQueue, postponedPeersResolutionQueue };
131583
131599
  }, extendedWantedDepsByImporters, importers));
131584
131600
  let publishedBy;
131585
131601
  let time;
@@ -131590,12 +131606,12 @@ var require_resolveDependencies = __commonJS({
131590
131606
  time = result2.newTime;
131591
131607
  }
131592
131608
  }
131593
- const pkgAddressesByImportersWithoutPeers = await Promise.all((0, zipWith_1.default)(async (importer, { pkgAddresses, postponedResolutionsQueue }) => {
131609
+ const pkgAddressesByImportersWithoutPeers = await Promise.all((0, zipWith_1.default)(async (importer, { pkgAddresses, postponedResolutionsQueue, postponedPeersResolutionQueue }) => {
131594
131610
  const newPreferredVersions = { ...importer.preferredVersions };
131595
- const newParentPkgAliases = { ...importer.parentPkgAliases };
131611
+ const currentParentPkgAliases = {};
131596
131612
  for (const pkgAddress of pkgAddresses) {
131597
- if (newParentPkgAliases[pkgAddress.alias] !== true) {
131598
- newParentPkgAliases[pkgAddress.alias] = pkgAddress;
131613
+ if (currentParentPkgAliases[pkgAddress.alias] !== true) {
131614
+ currentParentPkgAliases[pkgAddress.alias] = pkgAddress;
131599
131615
  }
131600
131616
  if (pkgAddress.updated) {
131601
131617
  ctx.updatedSet.add(pkgAddress.alias);
@@ -131608,6 +131624,7 @@ var require_resolveDependencies = __commonJS({
131608
131624
  }
131609
131625
  newPreferredVersions[resolvedPackage.name][resolvedPackage.version] = "version";
131610
131626
  }
131627
+ const newParentPkgAliases = { ...importer.parentPkgAliases, ...currentParentPkgAliases };
131611
131628
  const postponedResolutionOpts = {
131612
131629
  preferredVersions: newPreferredVersions,
131613
131630
  parentPkgAliases: newParentPkgAliases,
@@ -131621,14 +131638,17 @@ var require_resolveDependencies = __commonJS({
131621
131638
  resolvedPeers: {}
131622
131639
  };
131623
131640
  }
131641
+ const postponedPeersResolution = await Promise.all(postponedPeersResolutionQueue.map((postponedMissingPeers) => postponedMissingPeers(postponedResolutionOpts.parentPkgAliases)));
131642
+ const resolvedPeers = [...childrenResults, ...postponedPeersResolution].reduce((acc, { resolvedPeers: resolvedPeers2 }) => Object.assign(acc, resolvedPeers2), {});
131624
131643
  const allMissingPeers = mergePkgsDeps([
131625
- ...pkgAddresses,
131626
- ...childrenResults
131644
+ ...filterMissingPeersFromPkgAddresses(pkgAddresses, currentParentPkgAliases, resolvedPeers),
131645
+ ...childrenResults,
131646
+ ...postponedPeersResolution
131627
131647
  ].map(({ missingPeers }) => missingPeers).filter(Boolean));
131628
131648
  return {
131629
131649
  missingPeers: allMissingPeers,
131630
131650
  pkgAddresses,
131631
- resolvedPeers: [...pkgAddresses, ...childrenResults].reduce((acc, { resolvedPeers }) => Object.assign(acc, resolvedPeers), {})
131651
+ resolvedPeers
131632
131652
  };
131633
131653
  }, importers, resolveResults));
131634
131654
  return {
@@ -131637,6 +131657,19 @@ var require_resolveDependencies = __commonJS({
131637
131657
  time
131638
131658
  };
131639
131659
  }
131660
+ function filterMissingPeersFromPkgAddresses(pkgAddresses, currentParentPkgAliases, resolvedPeers) {
131661
+ return pkgAddresses.map((pkgAddress) => ({
131662
+ ...pkgAddress,
131663
+ missingPeers: (0, fromPairs_1.default)(Object.entries(pkgAddress.missingPeers || {}).filter(([peerName]) => {
131664
+ if (!currentParentPkgAliases[peerName])
131665
+ return true;
131666
+ if (currentParentPkgAliases[peerName] !== true) {
131667
+ resolvedPeers[peerName] = currentParentPkgAliases[peerName];
131668
+ }
131669
+ return false;
131670
+ }))
131671
+ }));
131672
+ }
131640
131673
  function getPublishedByDate(pkgAddresses, timeFromLockfile = {}) {
131641
131674
  const newTime = {};
131642
131675
  for (const pkgAddress of pkgAddresses) {
@@ -131658,20 +131691,24 @@ var require_resolveDependencies = __commonJS({
131658
131691
  resolvedDependencies: options.resolvedDependencies
131659
131692
  });
131660
131693
  const postponedResolutionsQueue = [];
131694
+ const postponedPeersResolutionQueue = [];
131661
131695
  const pkgAddresses = [];
131662
- (await Promise.all(extendedWantedDeps.map((extendedWantedDep) => resolveDependenciesOfDependency(ctx, preferredVersions, options, extendedWantedDep)))).forEach(({ resolveDependencyResult, postponedResolution }) => {
131696
+ (await Promise.all(extendedWantedDeps.map((extendedWantedDep) => resolveDependenciesOfDependency(ctx, preferredVersions, options, extendedWantedDep)))).forEach(({ resolveDependencyResult, postponedResolution, postponedPeersResolution }) => {
131663
131697
  if (resolveDependencyResult) {
131664
131698
  pkgAddresses.push(resolveDependencyResult);
131665
131699
  }
131666
131700
  if (postponedResolution) {
131667
131701
  postponedResolutionsQueue.push(postponedResolution);
131668
131702
  }
131703
+ if (postponedPeersResolution) {
131704
+ postponedPeersResolutionQueue.push(postponedPeersResolution);
131705
+ }
131669
131706
  });
131670
131707
  const newPreferredVersions = { ...preferredVersions };
131671
- const newParentPkgAliases = { ...options.parentPkgAliases };
131708
+ const currentParentPkgAliases = {};
131672
131709
  for (const pkgAddress of pkgAddresses) {
131673
- if (newParentPkgAliases[pkgAddress.alias] !== true) {
131674
- newParentPkgAliases[pkgAddress.alias] = pkgAddress;
131710
+ if (currentParentPkgAliases[pkgAddress.alias] !== true) {
131711
+ currentParentPkgAliases[pkgAddress.alias] = pkgAddress;
131675
131712
  }
131676
131713
  if (pkgAddress.updated) {
131677
131714
  ctx.updatedSet.add(pkgAddress.alias);
@@ -131684,6 +131721,10 @@ var require_resolveDependencies = __commonJS({
131684
131721
  }
131685
131722
  newPreferredVersions[resolvedPackage.name][resolvedPackage.version] = "version";
131686
131723
  }
131724
+ const newParentPkgAliases = {
131725
+ ...options.parentPkgAliases,
131726
+ ...currentParentPkgAliases
131727
+ };
131687
131728
  const postponedResolutionOpts = {
131688
131729
  preferredVersions: newPreferredVersions,
131689
131730
  parentPkgAliases: newParentPkgAliases,
@@ -131692,22 +131733,38 @@ var require_resolveDependencies = __commonJS({
131692
131733
  const childrenResults = await Promise.all(postponedResolutionsQueue.map((postponedResolution) => postponedResolution(postponedResolutionOpts)));
131693
131734
  if (!ctx.autoInstallPeers) {
131694
131735
  return {
131695
- missingPeers: {},
131696
- pkgAddresses,
131697
- resolvedPeers: {}
131736
+ resolvingPeers: Promise.resolve({
131737
+ missingPeers: {},
131738
+ resolvedPeers: {}
131739
+ }),
131740
+ pkgAddresses
131698
131741
  };
131699
131742
  }
131743
+ return {
131744
+ pkgAddresses,
131745
+ resolvingPeers: startResolvingPeers({
131746
+ childrenResults,
131747
+ pkgAddresses,
131748
+ parentPkgAliases: options.parentPkgAliases,
131749
+ currentParentPkgAliases,
131750
+ postponedPeersResolutionQueue
131751
+ })
131752
+ };
131753
+ }
131754
+ exports2.resolveDependencies = resolveDependencies;
131755
+ async function startResolvingPeers({ childrenResults, currentParentPkgAliases, parentPkgAliases, pkgAddresses, postponedPeersResolutionQueue }) {
131756
+ const results = await Promise.all(postponedPeersResolutionQueue.map((postponedPeersResolution) => postponedPeersResolution(parentPkgAliases)));
131757
+ const resolvedPeers = [...childrenResults, ...results].reduce((acc, { resolvedPeers: resolvedPeers2 }) => Object.assign(acc, resolvedPeers2), {});
131700
131758
  const allMissingPeers = mergePkgsDeps([
131701
- ...pkgAddresses,
131702
- ...childrenResults
131759
+ ...filterMissingPeersFromPkgAddresses(pkgAddresses, currentParentPkgAliases, resolvedPeers),
131760
+ ...childrenResults,
131761
+ ...results
131703
131762
  ].map(({ missingPeers }) => missingPeers).filter(Boolean));
131704
131763
  return {
131705
131764
  missingPeers: allMissingPeers,
131706
- pkgAddresses,
131707
- resolvedPeers: [...pkgAddresses, ...childrenResults].reduce((acc, { resolvedPeers }) => Object.assign(acc, resolvedPeers), {})
131765
+ resolvedPeers
131708
131766
  };
131709
131767
  }
131710
- exports2.resolveDependencies = resolveDependencies;
131711
131768
  function mergePkgsDeps(pkgsDeps) {
131712
131769
  const groupedRanges = {};
131713
131770
  for (const deps of pkgsDeps) {
@@ -131759,8 +131816,15 @@ var require_resolveDependencies = __commonJS({
131759
131816
  };
131760
131817
  return { resolveDependencyResult };
131761
131818
  }
131762
- if (!resolveDependencyResult.isNew)
131763
- return { resolveDependencyResult };
131819
+ if (!resolveDependencyResult.isNew) {
131820
+ return {
131821
+ resolveDependencyResult,
131822
+ postponedPeersResolution: resolveDependencyResult.missingPeersOfChildren != null ? async (parentPkgAliases) => {
131823
+ const missingPeers = await resolveDependencyResult.missingPeersOfChildren.get();
131824
+ return filterMissingPeers(missingPeers, {}, parentPkgAliases);
131825
+ } : void 0
131826
+ };
131827
+ }
131764
131828
  const postponedResolution = resolveChildren.bind(null, ctx, {
131765
131829
  parentPkg: resolveDependencyResult,
131766
131830
  dependencyLockfile: extendedWantedDep.infoFromLockfile?.dependencyLockfile,
@@ -131770,7 +131834,27 @@ var require_resolveDependencies = __commonJS({
131770
131834
  });
131771
131835
  return {
131772
131836
  resolveDependencyResult,
131773
- postponedResolution
131837
+ postponedResolution: async (postponedResolutionOpts) => {
131838
+ const { missingPeers, resolvedPeers } = await postponedResolution(postponedResolutionOpts);
131839
+ resolveDependencyResult.missingPeersOfChildren.resolve(missingPeers);
131840
+ return filterMissingPeers(missingPeers, resolvedPeers, postponedResolutionOpts.parentPkgAliases);
131841
+ }
131842
+ };
131843
+ }
131844
+ function filterMissingPeers(missingPeers, resolvedPeers, parentPkgAliases) {
131845
+ const newMissing = {};
131846
+ for (const [peerName, peerVersion] of Object.entries(missingPeers)) {
131847
+ if (parentPkgAliases[peerName]) {
131848
+ if (parentPkgAliases[peerName] !== true) {
131849
+ resolvedPeers[peerName] = parentPkgAliases[peerName];
131850
+ }
131851
+ } else {
131852
+ newMissing[peerName] = peerVersion;
131853
+ }
131854
+ }
131855
+ return {
131856
+ resolvedPeers,
131857
+ missingPeers: newMissing
131774
131858
  };
131775
131859
  }
131776
131860
  async function resolveChildren(ctx, { parentPkg, dependencyLockfile, parentDepth, updateDepth, prefix }, { parentPkgAliases, preferredVersions, publishedBy }) {
@@ -131781,7 +131865,7 @@ var require_resolveDependencies = __commonJS({
131781
131865
  const resolvedDependencies = parentPkg.updated ? void 0 : currentResolvedDependencies;
131782
131866
  const parentDependsOnPeer = Boolean(Object.keys(dependencyLockfile?.peerDependencies ?? parentPkg.pkg.peerDependencies ?? {}).length);
131783
131867
  const wantedDependencies = (0, getNonDevWantedDependencies_1.default)(parentPkg.pkg);
131784
- const { pkgAddresses, missingPeers, resolvedPeers } = await resolveDependencies(ctx, preferredVersions, wantedDependencies, {
131868
+ const { pkgAddresses, resolvingPeers } = await resolveDependencies(ctx, preferredVersions, wantedDependencies, {
131785
131869
  currentDepth: parentDepth + 1,
131786
131870
  parentPkg,
131787
131871
  parentPkgAliases,
@@ -131805,10 +131889,7 @@ var require_resolveDependencies = __commonJS({
131805
131889
  installable: parentPkg.installable,
131806
131890
  resolvedPackage: ctx.resolvedPackagesByDepPath[parentPkg.depPath]
131807
131891
  };
131808
- return {
131809
- missingPeers,
131810
- resolvedPeers
131811
- };
131892
+ return resolvingPeers;
131812
131893
  }
131813
131894
  function getDepsToResolve(wantedDependencies, wantedLockfile, options) {
131814
131895
  const resolvedDependencies = options.resolvedDependencies ?? {};
@@ -132093,6 +132174,25 @@ var require_resolveDependencies = __commonJS({
132093
132174
  }
132094
132175
  }
132095
132176
  const rootDir = pkgResponse.body.resolution.type === "directory" ? path_1.default.resolve(ctx.lockfileDir, pkgResponse.body.resolution["directory"]) : options.prefix;
132177
+ let missingPeersOfChildren;
132178
+ if (!(0, nodeIdUtils_1.nodeIdContains)(options.parentPkg.nodeId, depPath)) {
132179
+ if (ctx.missingPeersOfChildrenByPkgId[pkgResponse.body.id]) {
132180
+ if (!options.parentPkg.nodeId.startsWith(ctx.missingPeersOfChildrenByPkgId[pkgResponse.body.id].parentNodeId)) {
132181
+ missingPeersOfChildren = ctx.missingPeersOfChildrenByPkgId[pkgResponse.body.id].missingPeersOfChildren;
132182
+ }
132183
+ } else {
132184
+ const p = (0, p_defer_1.default)();
132185
+ missingPeersOfChildren = {
132186
+ resolve: p.resolve,
132187
+ reject: p.reject,
132188
+ get: (0, promise_share_1.default)(p.promise)
132189
+ };
132190
+ ctx.missingPeersOfChildrenByPkgId[pkgResponse.body.id] = {
132191
+ parentNodeId: options.parentPkg.nodeId,
132192
+ missingPeersOfChildren
132193
+ };
132194
+ }
132195
+ }
132096
132196
  return {
132097
132197
  alias: wantedDependency.alias || pkg.name,
132098
132198
  depIsLinked,
@@ -132100,9 +132200,10 @@ var require_resolveDependencies = __commonJS({
132100
132200
  isNew,
132101
132201
  nodeId,
132102
132202
  normalizedPref: options.currentDepth === 0 ? pkgResponse.body.normalizedPref : void 0,
132203
+ missingPeersOfChildren,
132103
132204
  pkgId: pkgResponse.body.id,
132104
132205
  rootDir,
132105
- ...getMissingPeers(pkg, options.parentPkgAliases),
132206
+ missingPeers: getMissingPeers(pkg),
132106
132207
  installable,
132107
132208
  isLinkedDependency: void 0,
132108
132209
  pkg,
@@ -132119,19 +132220,14 @@ var require_resolveDependencies = __commonJS({
132119
132220
  version: "0.0.0"
132120
132221
  };
132121
132222
  }
132122
- function getMissingPeers(pkg, parentPkgAliases) {
132223
+ function getMissingPeers(pkg) {
132123
132224
  const missingPeers = {};
132124
- const resolvedPeers = {};
132125
132225
  for (const [peerName, peerVersion] of Object.entries(pkg.peerDependencies ?? {})) {
132126
- if (parentPkgAliases[peerName]) {
132127
- if (parentPkgAliases[peerName] !== true) {
132128
- resolvedPeers[peerName] = parentPkgAliases[peerName];
132129
- }
132130
- } else if (!pkg.peerDependenciesMeta?.[peerName]?.optional) {
132226
+ if (!pkg.peerDependenciesMeta?.[peerName]?.optional) {
132131
132227
  missingPeers[peerName] = peerVersion;
132132
132228
  }
132133
132229
  }
132134
- return { missingPeers, resolvedPeers };
132230
+ return missingPeers;
132135
132231
  }
132136
132232
  function pkgIsLeaf(pkg) {
132137
132233
  return (0, isEmpty_1.default)(pkg.dependencies ?? {}) && (0, isEmpty_1.default)(pkg.optionalDependencies ?? {}) && (0, isEmpty_1.default)(pkg.peerDependencies ?? {});
@@ -132267,7 +132363,8 @@ var require_resolveDependencyTree = __commonJS({
132267
132363
  wantedLockfile: opts.wantedLockfile,
132268
132364
  appliedPatches: /* @__PURE__ */ new Set(),
132269
132365
  updatedSet: /* @__PURE__ */ new Set(),
132270
- workspacePackages: opts.workspacePackages
132366
+ workspacePackages: opts.workspacePackages,
132367
+ missingPeersOfChildrenByPkgId: {}
132271
132368
  };
132272
132369
  const resolveArgs = importers.map((importer) => {
132273
132370
  const projectSnapshot = opts.wantedLockfile.importers[importer.id];
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "pnpm",
3
3
  "description": "Fast, disk space efficient package manager",
4
- "version": "7.12.0-0",
4
+ "version": "7.12.1",
5
5
  "bin": {
6
6
  "pnpm": "bin/pnpm.cjs",
7
7
  "pnpx": "bin/pnpx.cjs"