@pnpm/core 14.1.1 → 14.1.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/lib/install/getPreferredVersions.d.ts +5 -0
- package/lib/install/getPreferredVersions.js +62 -0
- package/lib/install/getPreferredVersions.js.map +1 -0
- package/lib/install/getPreferredVersions.test.d.ts +1 -0
- package/lib/install/getPreferredVersions.test.js +30 -0
- package/lib/install/getPreferredVersions.test.js.map +1 -0
- package/package.json +30 -30
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { type PackageSnapshots } from '@pnpm/lockfile-utils';
|
|
2
|
+
import { type PreferredVersions } from '@pnpm/resolver-base';
|
|
3
|
+
import { type DependencyManifest, type ProjectManifest } from '@pnpm/types';
|
|
4
|
+
export declare function getAllUniqueSpecs(manifests: DependencyManifest[]): Record<string, string>;
|
|
5
|
+
export declare function getPreferredVersionsFromLockfileAndManifests(snapshots: PackageSnapshots | undefined, manifests: Array<DependencyManifest | ProjectManifest>): PreferredVersions;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.getPreferredVersionsFromLockfileAndManifests = exports.getAllUniqueSpecs = void 0;
|
|
7
|
+
const lockfile_utils_1 = require("@pnpm/lockfile-utils");
|
|
8
|
+
const manifest_utils_1 = require("@pnpm/manifest-utils");
|
|
9
|
+
const resolver_base_1 = require("@pnpm/resolver-base");
|
|
10
|
+
const version_selector_type_1 = __importDefault(require("version-selector-type"));
|
|
11
|
+
function getAllUniqueSpecs(manifests) {
|
|
12
|
+
const allSpecs = {};
|
|
13
|
+
const ignored = new Set();
|
|
14
|
+
for (const manifest of manifests) {
|
|
15
|
+
const specs = (0, manifest_utils_1.getAllDependenciesFromManifest)(manifest);
|
|
16
|
+
for (const [name, spec] of Object.entries(specs)) {
|
|
17
|
+
if (ignored.has(name))
|
|
18
|
+
continue;
|
|
19
|
+
if (allSpecs[name] != null && allSpecs[name] !== spec || spec.includes(':')) {
|
|
20
|
+
ignored.add(name);
|
|
21
|
+
delete allSpecs[name];
|
|
22
|
+
continue;
|
|
23
|
+
}
|
|
24
|
+
allSpecs[name] = spec;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return allSpecs;
|
|
28
|
+
}
|
|
29
|
+
exports.getAllUniqueSpecs = getAllUniqueSpecs;
|
|
30
|
+
function getPreferredVersionsFromLockfileAndManifests(snapshots, manifests) {
|
|
31
|
+
const preferredVersions = {};
|
|
32
|
+
for (const manifest of manifests) {
|
|
33
|
+
const specs = (0, manifest_utils_1.getAllDependenciesFromManifest)(manifest);
|
|
34
|
+
for (const [name, spec] of Object.entries(specs)) {
|
|
35
|
+
const selector = (0, version_selector_type_1.default)(spec);
|
|
36
|
+
if (!selector)
|
|
37
|
+
continue;
|
|
38
|
+
preferredVersions[name] = preferredVersions[name] ?? {};
|
|
39
|
+
preferredVersions[name][spec] = {
|
|
40
|
+
selectorType: selector.type,
|
|
41
|
+
weight: resolver_base_1.DIRECT_DEP_SELECTOR_WEIGHT,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (!snapshots)
|
|
46
|
+
return preferredVersions;
|
|
47
|
+
addPreferredVersionsFromLockfile(snapshots, preferredVersions);
|
|
48
|
+
return preferredVersions;
|
|
49
|
+
}
|
|
50
|
+
exports.getPreferredVersionsFromLockfileAndManifests = getPreferredVersionsFromLockfileAndManifests;
|
|
51
|
+
function addPreferredVersionsFromLockfile(snapshots, preferredVersions) {
|
|
52
|
+
for (const [depPath, snapshot] of Object.entries(snapshots)) {
|
|
53
|
+
const { name, version } = (0, lockfile_utils_1.nameVerFromPkgSnapshot)(depPath, snapshot);
|
|
54
|
+
if (!preferredVersions[name]) {
|
|
55
|
+
preferredVersions[name] = { [version]: 'version' };
|
|
56
|
+
}
|
|
57
|
+
else if (!preferredVersions[name][version]) {
|
|
58
|
+
preferredVersions[name][version] = 'version';
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=getPreferredVersions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getPreferredVersions.js","sourceRoot":"","sources":["../../src/install/getPreferredVersions.ts"],"names":[],"mappings":";;;;;;AAAA,yDAAoF;AACpF,yDAAqE;AACrE,uDAAwF;AAExF,kFAA0D;AAE1D,SAAgB,iBAAiB,CAAE,SAA+B;IAChE,MAAM,QAAQ,GAA2B,EAAE,CAAA;IAC3C,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAA;IACjC,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,IAAA,+CAA8B,EAAC,QAAQ,CAAC,CAAA;QACtD,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjD,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;gBAAE,SAAQ;YAC/B,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC5E,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;gBACjB,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAA;gBACrB,SAAQ;YACV,CAAC;YACD,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA;QACvB,CAAC;IACH,CAAC;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC;AAhBD,8CAgBC;AAED,SAAgB,4CAA4C,CAC1D,SAAuC,EACvC,SAAsD;IAEtD,MAAM,iBAAiB,GAAsB,EAAE,CAAA;IAC/C,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,IAAA,+CAA8B,EAAC,QAAQ,CAAC,CAAA;QACtD,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjD,MAAM,QAAQ,GAAG,IAAA,+BAAsB,EAAC,IAAI,CAAC,CAAA;YAC7C,IAAI,CAAC,QAAQ;gBAAE,SAAQ;YACvB,iBAAiB,CAAC,IAAI,CAAC,GAAG,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;YACvD,iBAAiB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG;gBAC9B,YAAY,EAAE,QAAQ,CAAC,IAAI;gBAC3B,MAAM,EAAE,0CAA0B;aACnC,CAAA;QACH,CAAC;IACH,CAAC;IACD,IAAI,CAAC,SAAS;QAAE,OAAO,iBAAiB,CAAA;IACxC,gCAAgC,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAA;IAC9D,OAAO,iBAAiB,CAAA;AAC1B,CAAC;AApBD,oGAoBC;AAED,SAAS,gCAAgC,CAAE,SAA2B,EAAE,iBAAoC;IAC1G,KAAK,MAAM,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QAC5D,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAA,uCAAsB,EAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QACnE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC;YAC7B,iBAAiB,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,CAAA;QACpD,CAAC;aAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;YAC7C,iBAAiB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,SAAS,CAAA;QAC9C,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const getPreferredVersions_1 = require("./getPreferredVersions");
|
|
4
|
+
test('getAllUniqueSpecs()', () => {
|
|
5
|
+
expect((0, getPreferredVersions_1.getAllUniqueSpecs)([
|
|
6
|
+
{
|
|
7
|
+
name: '',
|
|
8
|
+
version: '',
|
|
9
|
+
dependencies: {
|
|
10
|
+
foo: '1.0.0',
|
|
11
|
+
bar: '1.0.0',
|
|
12
|
+
qar: '1.0.0',
|
|
13
|
+
zoo: 'link:../zoo',
|
|
14
|
+
alpha: 'npm:beta@2',
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
name: '',
|
|
19
|
+
version: '',
|
|
20
|
+
dependencies: {
|
|
21
|
+
bar: '1.0.0',
|
|
22
|
+
qar: '2.0.0',
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
])).toStrictEqual({
|
|
26
|
+
foo: '1.0.0',
|
|
27
|
+
bar: '1.0.0',
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=getPreferredVersions.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getPreferredVersions.test.js","sourceRoot":"","sources":["../../src/install/getPreferredVersions.test.ts"],"names":[],"mappings":";;AAAA,iEAA0D;AAE1D,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE;IAC/B,MAAM,CAAC,IAAA,wCAAiB,EAAC;QACvB;YACE,IAAI,EAAE,EAAE;YACR,OAAO,EAAE,EAAE;YACX,YAAY,EAAE;gBACZ,GAAG,EAAE,OAAO;gBACZ,GAAG,EAAE,OAAO;gBACZ,GAAG,EAAE,OAAO;gBACZ,GAAG,EAAE,aAAa;gBAClB,KAAK,EAAE,YAAY;aACpB;SACF;QACD;YACE,IAAI,EAAE,EAAE;YACR,OAAO,EAAE,EAAE;YACX,YAAY,EAAE;gBACZ,GAAG,EAAE,OAAO;gBACZ,GAAG,EAAE,OAAO;aACb;SACF;KACF,CAAC,CAAC,CAAC,aAAa,CAAC;QAChB,GAAG,EAAE,OAAO;QACZ,GAAG,EAAE,OAAO;KACb,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pnpm/core",
|
|
3
3
|
"description": "Fast, disk space efficient installation engine",
|
|
4
|
-
"version": "14.1.
|
|
4
|
+
"version": "14.1.2",
|
|
5
5
|
"bugs": {
|
|
6
6
|
"url": "https://github.com/pnpm/pnpm/issues"
|
|
7
7
|
},
|
|
@@ -32,46 +32,46 @@
|
|
|
32
32
|
"semver": "^7.6.0",
|
|
33
33
|
"sort-keys": "^4.2.0",
|
|
34
34
|
"version-selector-type": "^3.0.0",
|
|
35
|
-
"@pnpm/build-modules": "12.0.3",
|
|
36
35
|
"@pnpm/constants": "8.0.0",
|
|
37
|
-
"@pnpm/
|
|
38
|
-
"@pnpm/
|
|
36
|
+
"@pnpm/build-modules": "12.0.3",
|
|
37
|
+
"@pnpm/dependency-path": "4.0.0",
|
|
39
38
|
"@pnpm/crypto.base32-hash": "3.0.0",
|
|
39
|
+
"@pnpm/core-loggers": "10.0.0",
|
|
40
|
+
"@pnpm/calc-dep-state": "6.0.1",
|
|
40
41
|
"@pnpm/deps.graph-sequencer": "2.0.1",
|
|
41
|
-
"@pnpm/dependency-path": "4.0.0",
|
|
42
42
|
"@pnpm/error": "6.0.0",
|
|
43
43
|
"@pnpm/get-context": "11.1.1",
|
|
44
44
|
"@pnpm/filter-lockfile": "9.0.3",
|
|
45
|
-
"@pnpm/
|
|
45
|
+
"@pnpm/lifecycle": "17.0.1",
|
|
46
|
+
"@pnpm/hooks.types": "2.0.0",
|
|
46
47
|
"@pnpm/hoist": "9.1.1",
|
|
48
|
+
"@pnpm/lockfile-to-pnp": "4.1.1",
|
|
49
|
+
"@pnpm/headless": "23.1.1",
|
|
47
50
|
"@pnpm/hooks.read-package-hook": "4.0.1",
|
|
48
|
-
"@pnpm/hooks.types": "2.0.0",
|
|
49
|
-
"@pnpm/link-bins": "10.0.0",
|
|
50
|
-
"@pnpm/lifecycle": "17.0.1",
|
|
51
51
|
"@pnpm/lockfile-file": "9.0.4",
|
|
52
|
-
"@pnpm/lockfile-to-pnp": "4.1.1",
|
|
53
52
|
"@pnpm/lockfile-utils": "10.1.1",
|
|
54
53
|
"@pnpm/lockfile-walker": "8.0.1",
|
|
55
|
-
"@pnpm/manifest-utils": "6.0.0",
|
|
56
|
-
"@pnpm/lockfile.preferred-versions": "1.0.2",
|
|
57
54
|
"@pnpm/matcher": "6.0.0",
|
|
58
|
-
"@pnpm/
|
|
55
|
+
"@pnpm/lockfile.preferred-versions": "1.0.2",
|
|
59
56
|
"@pnpm/modules-yaml": "13.1.0",
|
|
60
|
-
"@pnpm/
|
|
61
|
-
"@pnpm/
|
|
62
|
-
"@pnpm/
|
|
63
|
-
"@pnpm/package-requester": "25.1.0",
|
|
64
|
-
"@pnpm/read-modules-dir": "7.0.0",
|
|
57
|
+
"@pnpm/modules-cleaner": "15.1.1",
|
|
58
|
+
"@pnpm/manifest-utils": "6.0.0",
|
|
59
|
+
"@pnpm/link-bins": "10.0.0",
|
|
65
60
|
"@pnpm/prune-lockfile": "6.0.1",
|
|
61
|
+
"@pnpm/read-modules-dir": "7.0.0",
|
|
62
|
+
"@pnpm/parse-wanted-dependency": "6.0.0",
|
|
66
63
|
"@pnpm/read-package-json": "9.0.0",
|
|
67
|
-
"@pnpm/
|
|
68
|
-
"@pnpm/remove-bins": "6.0.0",
|
|
64
|
+
"@pnpm/pkg-manager.direct-dep-linker": "3.0.0",
|
|
69
65
|
"@pnpm/resolver-base": "12.0.0",
|
|
70
|
-
"@pnpm/resolve-dependencies": "32.1.
|
|
66
|
+
"@pnpm/resolve-dependencies": "32.1.2",
|
|
67
|
+
"@pnpm/read-project-manifest": "6.0.0",
|
|
71
68
|
"@pnpm/store-controller-types": "18.0.0",
|
|
72
|
-
"@pnpm/types": "10.0.0",
|
|
73
69
|
"@pnpm/symlink-dependency": "8.0.0",
|
|
74
|
-
"@pnpm/
|
|
70
|
+
"@pnpm/package-requester": "25.1.0",
|
|
71
|
+
"@pnpm/types": "10.0.0",
|
|
72
|
+
"@pnpm/remove-bins": "6.0.0",
|
|
73
|
+
"@pnpm/which-version-is-pinned": "6.0.0",
|
|
74
|
+
"@pnpm/normalize-registries": "6.0.0"
|
|
75
75
|
},
|
|
76
76
|
"devDependencies": {
|
|
77
77
|
"@pnpm/registry-mock": "3.30.0",
|
|
@@ -96,16 +96,16 @@
|
|
|
96
96
|
"write-json-file": "^4.3.0",
|
|
97
97
|
"write-yaml-file": "^5.0.0",
|
|
98
98
|
"@pnpm/assert-project": "2.3.48",
|
|
99
|
-
"@pnpm/
|
|
100
|
-
"@pnpm/assert-store": "1.0.81",
|
|
101
|
-
"@pnpm/core": "14.1.1",
|
|
102
|
-
"@pnpm/git-utils": "2.0.0",
|
|
103
|
-
"@pnpm/crypto.object-hasher": "2.0.0",
|
|
104
|
-
"@pnpm/lockfile-types": "6.0.0",
|
|
99
|
+
"@pnpm/core": "14.1.2",
|
|
105
100
|
"@pnpm/prepare": "0.0.91",
|
|
101
|
+
"@pnpm/assert-store": "1.0.81",
|
|
102
|
+
"@pnpm/package-store": "20.1.0",
|
|
106
103
|
"@pnpm/store-path": "9.0.0",
|
|
104
|
+
"@pnpm/lockfile-types": "6.0.0",
|
|
107
105
|
"@pnpm/store.cafs": "3.0.0",
|
|
108
|
-
"@pnpm/
|
|
106
|
+
"@pnpm/git-utils": "2.0.0",
|
|
107
|
+
"@pnpm/client": "11.0.4",
|
|
108
|
+
"@pnpm/crypto.object-hasher": "2.0.0",
|
|
109
109
|
"@pnpm/test-ipc-server": "0.0.0",
|
|
110
110
|
"@pnpm/test-fixtures": "0.1.21"
|
|
111
111
|
},
|