@ms-cloudpack/package-utilities 0.0.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.
Files changed (74) hide show
  1. package/lib/createResolveMap.d.ts +19 -0
  2. package/lib/createResolveMap.js +120 -0
  3. package/lib/createResolveMap.js.map +1 -0
  4. package/lib/createResolveMap.test.d.ts +1 -0
  5. package/lib/createResolveMap.test.js +12 -0
  6. package/lib/createResolveMap.test.js.map +1 -0
  7. package/lib/evaluateImportsFromEntries.d.ts +31 -0
  8. package/lib/evaluateImportsFromEntries.js +149 -0
  9. package/lib/evaluateImportsFromEntries.js.map +1 -0
  10. package/lib/evaluateImportsFromEntries.test.d.ts +1 -0
  11. package/lib/evaluateImportsFromEntries.test.js +9 -0
  12. package/lib/evaluateImportsFromEntries.test.js.map +1 -0
  13. package/lib/filterJson.d.ts +3 -0
  14. package/lib/filterJson.js +21 -0
  15. package/lib/filterJson.js.map +1 -0
  16. package/lib/getExportPathFromEntry.d.ts +5 -0
  17. package/lib/getExportPathFromEntry.js +27 -0
  18. package/lib/getExportPathFromEntry.js.map +1 -0
  19. package/lib/getExportPathFromEntry.test.d.ts +1 -0
  20. package/lib/getExportPathFromEntry.test.js +34 -0
  21. package/lib/getExportPathFromEntry.test.js.map +1 -0
  22. package/lib/getInstalledPackages.d.ts +44 -0
  23. package/lib/getInstalledPackages.js +87 -0
  24. package/lib/getInstalledPackages.js.map +1 -0
  25. package/lib/getInstalledPackages.test.d.ts +1 -0
  26. package/lib/getInstalledPackages.test.js +14 -0
  27. package/lib/getInstalledPackages.test.js.map +1 -0
  28. package/lib/getPackageDefinition.d.ts +22 -0
  29. package/lib/getPackageDefinition.js +25 -0
  30. package/lib/getPackageDefinition.js.map +1 -0
  31. package/lib/index.d.ts +6 -0
  32. package/lib/index.js +6 -0
  33. package/lib/index.js.map +1 -0
  34. package/lib/isExternalPackage.d.ts +1 -0
  35. package/lib/isExternalPackage.js +9 -0
  36. package/lib/isExternalPackage.js.map +1 -0
  37. package/lib/isExternalPackage.test.d.ts +1 -0
  38. package/lib/isExternalPackage.test.js +12 -0
  39. package/lib/isExternalPackage.test.js.map +1 -0
  40. package/lib/isFile.d.ts +1 -0
  41. package/lib/isFile.js +12 -0
  42. package/lib/isFile.js.map +1 -0
  43. package/lib/isFile.test.d.ts +1 -0
  44. package/lib/isFile.test.js +16 -0
  45. package/lib/isFile.test.js.map +1 -0
  46. package/lib/isFolder.d.ts +1 -0
  47. package/lib/isFolder.js +10 -0
  48. package/lib/isFolder.js.map +1 -0
  49. package/lib/isFolder.test.d.ts +1 -0
  50. package/lib/isFolder.test.js +15 -0
  51. package/lib/isFolder.test.js.map +1 -0
  52. package/lib/parseImportString.d.ts +6 -0
  53. package/lib/parseImportString.js +9 -0
  54. package/lib/parseImportString.js.map +1 -0
  55. package/lib/parseImportString.test.d.ts +1 -0
  56. package/lib/parseImportString.test.js +20 -0
  57. package/lib/parseImportString.test.js.map +1 -0
  58. package/lib/resolve.d.ts +1 -0
  59. package/lib/resolve.js +21 -0
  60. package/lib/resolve.js.map +1 -0
  61. package/lib/resolve.test.d.ts +1 -0
  62. package/lib/resolve.test.js +12 -0
  63. package/lib/resolve.test.js.map +1 -0
  64. package/lib/resolveImportFromPackage.test.d.ts +1 -0
  65. package/lib/resolveImportFromPackage.test.js +153 -0
  66. package/lib/resolveImportFromPackage.test.js.map +1 -0
  67. package/lib/resolveImportFromPackagePath.d.ts +11 -0
  68. package/lib/resolveImportFromPackagePath.js +113 -0
  69. package/lib/resolveImportFromPackagePath.js.map +1 -0
  70. package/lib/testPaths.d.ts +3 -0
  71. package/lib/testPaths.js +6 -0
  72. package/lib/testPaths.js.map +1 -0
  73. package/lib/tsdoc-metadata.json +11 -0
  74. package/package.json +36 -0
@@ -0,0 +1,19 @@
1
+ import type { InstalledPackagesResult } from './getInstalledPackages.js';
2
+ export declare type ResolveMapEntry = {
3
+ version: string;
4
+ path: string;
5
+ entry: string;
6
+ scopedVersions?: {
7
+ [packageNameAndVersion: `${string}@${string}`]: ResolveMapEntry;
8
+ };
9
+ };
10
+ export declare type ResolveMap = {
11
+ [packageName: string]: ResolveMapEntry;
12
+ };
13
+ export declare function createResolveMap(options: {
14
+ appPath: string;
15
+ additionalPaths?: string[];
16
+ }): Promise<{
17
+ resolveMap: ResolveMap;
18
+ stats: InstalledPackagesResult['stats'];
19
+ }>;
@@ -0,0 +1,120 @@
1
+ import { getInstalledPackages } from './getInstalledPackages.js';
2
+ // import fs from 'fs';
3
+ // import path from 'path';
4
+ import { resolveImportFromPackagePath } from './resolveImportFromPackagePath.js';
5
+ /*
6
+ For each package:
7
+
8
+ 1. Resolve the version required from the lockfile.
9
+ 2. Determine what version is installed.
10
+ 3. If version required was not found, default to the version installed.
11
+ 4. If no lockfile version is installed, get metadata and use the latest.
12
+ 5. If there is no installed version, or the version installed does not
13
+ satisfy the required version, install the version required.
14
+
15
+ Repeat this process for each *unique* version resolved.
16
+
17
+ {
18
+ react: {
19
+ '7.1.0': { path: '...', requiredBy: [ { name: 'foo', version: '1.1.1' }, { name: 'bar'}],
20
+ '6.9.0': [ { name: 'baz' } ]
21
+ },
22
+ etc...
23
+ }
24
+
25
+ This should be enough to know which dependencies have dupes.
26
+
27
+ Then, optimize the resolve map to top-level the most common/latest versions. This map will provide
28
+ physical paths for resolving dependencies, where each key in the package object represents the scope.
29
+ This is useful because at esbuild resolve time, we can quickly identify which package the import source
30
+ is coming from, and quickly look up the package resolution by:
31
+
32
+ `const packageDetails = resolveMap[requestPackage][sourcePackage] || resolveMap[requestPackage].default`
33
+
34
+ {
35
+ react: {
36
+ version: string;
37
+ path: '/tmp/react/7.1.0',
38
+ entry: './lib/index.js'
39
+
40
+ scopedVersions: {
41
+ baz: { // when bar imports 'react', resolve to this other location.
42
+ path: '/tmp/react/6.9.0'
43
+ entry: './lib/index.js'
44
+ }
45
+ }
46
+ },
47
+ etc: ...
48
+ }
49
+
50
+ By optimizing the default to be the most common package, we can reduce the scope entries.
51
+
52
+ Note that when we have dupes, this will keep them intact and will not try to optimize. It could be that
53
+ holding back one package could dedupe. In the example above, perhaps "foo" and "bar" packages could be
54
+ downgraded to a build which accepts 6.9.0. But it could also introduce other dupes.
55
+ */
56
+ export async function createResolveMap(options) {
57
+ const { appPath, additionalPaths = [] } = options;
58
+ // First, create a merged dependency list.
59
+ // const dependencies = {};
60
+ // Grab what's installed, so that we can default to use those packages.
61
+ const { installedPackages, stats } = await getInstalledPackages([
62
+ appPath,
63
+ ...additionalPaths,
64
+ ]);
65
+ // await writeFile(
66
+ // path.join(appPath, "install-map.json"),
67
+ // JSON.stringify({ installedPackages, stats }, null, 2),
68
+ // "utf8"
69
+ // );
70
+ // // Add the dependencies for the appPath.
71
+ // await addDependencies(dependencies, appPath, installedPackages);
72
+ // // Add deps for additional paths.
73
+ // for (let additionalPath of additionalPaths) {
74
+ // await addDependencies(dependencies, additionalPath, installedPackages);
75
+ // }
76
+ // Now that we have the resolved dependency list, optimize it as the resolveMap.
77
+ const resolveMap = {};
78
+ // Iterate through installed packages.
79
+ for (const packageName of Object.keys(installedPackages)) {
80
+ // Get installed versions, sorted by the number of dependencies (greatest to least)
81
+ const versions = Object.keys(installedPackages[packageName]).sort((a, b) => installedPackages[packageName][a].requiredBy?.length >
82
+ installedPackages[packageName][b].requiredBy.length
83
+ ? -1
84
+ : 1);
85
+ // Default to the most used version to dedupe. All other versions scope to specifics.
86
+ const defaultVersionEntry = installedPackages[packageName][versions[0]];
87
+ // Define the default resolved version for the package.
88
+ const depResolveEntry = (resolveMap[packageName] = {
89
+ version: versions[0],
90
+ path: defaultVersionEntry.path,
91
+ entry: await resolveImportFromPackagePath(defaultVersionEntry.path, '', {
92
+ preferSource: false,
93
+ })
94
+ });
95
+ // If we have additional versions, scope each of those to their specific parents
96
+ if (versions.length > 1) {
97
+ const scopedVersionEntries = (depResolveEntry.scopedVersions = {});
98
+ for (let i = 1; i < versions.length; i++) {
99
+ const scopedVersion = versions[i];
100
+ const scopedPackage = installedPackages[packageName][scopedVersion];
101
+ for (const dep of scopedPackage.requiredBy) {
102
+ scopedVersionEntries[`${dep.name}@${dep.version}`] = {
103
+ version: scopedVersion,
104
+ path: scopedPackage.path,
105
+ entry: await resolveImportFromPackagePath(scopedPackage.path, '', {
106
+ preferSource: false,
107
+ }),
108
+ };
109
+ }
110
+ }
111
+ }
112
+ }
113
+ // await writeFile(
114
+ // path.join(appPath, 'resolve-map.json'),
115
+ // JSON.stringify(resolveMap, null, 2),
116
+ // 'utf8'
117
+ // );
118
+ return { resolveMap, stats };
119
+ }
120
+ //# sourceMappingURL=createResolveMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createResolveMap.js","sourceRoot":"../src/","sources":["createResolveMap.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,uBAAuB;AACvB,2BAA2B;AAC3B,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AAejF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAkDE;AACF,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,OAGtC;IACC,MAAM,EAAE,OAAO,EAAE,eAAe,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC;IAElD,0CAA0C;IAC1C,2BAA2B;IAE3B,uEAAuE;IACvE,MAAM,EAAE,iBAAiB,EAAE,KAAK,EAAE,GAAG,MAAM,oBAAoB,CAAC;QAC9D,OAAO;QACP,GAAG,eAAe;KACnB,CAAC,CAAC;IAEH,mBAAmB;IACnB,4CAA4C;IAC5C,2DAA2D;IAC3D,WAAW;IACX,KAAK;IAEL,2CAA2C;IAC3C,mEAAmE;IAEnE,oCAAoC;IACpC,gDAAgD;IAChD,4EAA4E;IAC5E,IAAI;IAEJ,gFAAgF;IAChF,MAAM,UAAU,GAAe,EAAE,CAAC;IAElC,sCAAsC;IACtC,KAAK,MAAM,WAAW,IAAI,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;QACxD,mFAAmF;QACnF,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACzE,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,MAAM;YAClD,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM;YACnD,CAAC,CAAC,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC,CACN,CAAC;QAEF,qFAAqF;QACrF,MAAM,mBAAmB,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAExE,uDAAuD;QACvD,MAAM,eAAe,GAAoB,CAAC,UAAU,CAAC,WAAW,CAAC,GAAG;YAClE,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;YACpB,IAAI,EAAE,mBAAmB,CAAC,IAAI;YAC9B,KAAK,EAAE,MAAM,4BAA4B,CAAC,mBAAmB,CAAC,IAAI,EAAE,EAAE,EAAE;gBACtE,YAAY,EAAE,KAAK;aACpB,CAAC;SACH,CAAC,CAAC;QAEH,gFAAgF;QAChF,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,MAAM,oBAAoB,GAAsC,CAAC,eAAe,CAAC,cAAc,GAAG,EAAE,CAAC,CAAC;YAEtG,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACxC,MAAM,aAAa,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,CAAC;gBAEpE,KAAK,MAAM,GAAG,IAAI,aAAa,CAAC,UAAU,EAAE;oBAC1C,oBAAoB,CAAC,GAAG,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC,GAAG;wBACnD,OAAO,EAAE,aAAa;wBACtB,IAAI,EAAE,aAAa,CAAC,IAAI;wBACxB,KAAK,EAAE,MAAM,4BAA4B,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,EAAE;4BAChE,YAAY,EAAE,KAAK;yBACpB,CAAC;qBACH,CAAC;iBACH;aACF;SACF;KACF;IAED,mBAAmB;IACnB,4CAA4C;IAC5C,yCAAyC;IACzC,WAAW;IACX,KAAK;IAEL,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,12 @@
1
+ import { slash } from '@ms-cloudpack/path-utilities';
2
+ import path from 'path';
3
+ import { createResolveMap } from './createResolveMap.js';
4
+ import { filterJson } from './filterJson.js';
5
+ import { testProject1Path } from '../src/testPaths.js';
6
+ const createResolveMapSafe = async (options) => filterJson(await createResolveMap(options), 'path', (oldPath) => slash(path.relative(testProject1Path, oldPath)));
7
+ describe('createResolveMap', () => {
8
+ it('can create a resolve map', async () => {
9
+ expect(await createResolveMapSafe({ appPath: testProject1Path })).toMatchSnapshot();
10
+ });
11
+ });
12
+ //# sourceMappingURL=createResolveMap.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createResolveMap.test.js","sourceRoot":"../src/","sources":["createResolveMap.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,8BAA8B,CAAC;AACrD,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,MAAM,oBAAoB,GAA4B,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,CACjF,MAAM,gBAAgB,CAAC,OAAO,CAAC,EAC/B,MAAM,EACN,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,CAC7D,CAAC;AAEF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,CAAC,MAAM,oBAAoB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC,eAAe,EAAE,CAAA;IACrF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { type ResolveMap } from './createResolveMap.js';
2
+ declare type PackageExports = {
3
+ [packageName: string]: {
4
+ [version: string]: {
5
+ [importPath: string]: {
6
+ count: number;
7
+ import: string | undefined;
8
+ };
9
+ };
10
+ };
11
+ };
12
+ export interface EvaluateImportsFromEntriesStats {
13
+ parsedSourceFiles: number;
14
+ parseErrors: string[];
15
+ uniqueImports: number;
16
+ uniquePackages: number;
17
+ unresolvedPackages: {
18
+ name: string;
19
+ from: string;
20
+ }[];
21
+ unresolvedPackageImports: {
22
+ name: string;
23
+ path: string;
24
+ from: string;
25
+ }[];
26
+ }
27
+ export declare function evaluateImportsFromEntries(entries: string[], resolveMap?: ResolveMap, allExports?: PackageExports): Promise<{
28
+ exports: PackageExports;
29
+ stats: EvaluateImportsFromEntriesStats;
30
+ }>;
31
+ export {};
@@ -0,0 +1,149 @@
1
+ import fs from 'fs';
2
+ import path from 'path';
3
+ import { parseImportString } from './parseImportString.js';
4
+ import { resolveImportFromPackagePath } from "./resolveImportFromPackagePath.js";
5
+ import { resolve } from './resolve.js';
6
+ import babelParser from '@babel/parser';
7
+ import traverseAPI from '@babel/traverse';
8
+ import { getPackageDefinition } from './getPackageDefinition.js';
9
+ const { readFile } = fs.promises;
10
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
11
+ const traverse = traverseAPI.default;
12
+ const sourceExtensions = ['.ts', '.tsx', '.js', '.cjs', '.mjs', '.jsx'];
13
+ function resolveSource(sourcePath) {
14
+ const originalExt = path.extname(sourcePath);
15
+ if (!originalExt) {
16
+ for (const ext of sourceExtensions) {
17
+ if (fs.existsSync(sourcePath + ext)) {
18
+ return sourcePath + ext;
19
+ }
20
+ }
21
+ }
22
+ else if (sourceExtensions.indexOf(originalExt) >= 0) {
23
+ return sourcePath;
24
+ }
25
+ }
26
+ export async function evaluateImportsFromEntries(entries, resolveMap, allExports = {}) {
27
+ const entriesToEvaluate = [...entries];
28
+ const visitedPaths = new Set();
29
+ const addEntry = (newEntry) => {
30
+ const ext = path.extname(newEntry);
31
+ if (!visitedPaths.has(newEntry) && (!ext || sourceExtensions.indexOf(ext) >= 0)) {
32
+ entriesToEvaluate.push(newEntry);
33
+ }
34
+ };
35
+ const stats = {
36
+ parsedSourceFiles: 0,
37
+ parseErrors: [],
38
+ uniqueImports: 0,
39
+ uniquePackages: 0,
40
+ unresolvedPackages: [],
41
+ unresolvedPackageImports: []
42
+ };
43
+ // Skip entry file paths we've already visited.
44
+ while (entriesToEvaluate.length) {
45
+ const entry = entriesToEvaluate.shift();
46
+ console.log(`${entriesToEvaluate.length}: Adding ${entry}`);
47
+ if (visitedPaths.has(entry)) {
48
+ continue;
49
+ }
50
+ visitedPaths.add(entry);
51
+ // Get imports in entry file.
52
+ const content = await readFile(entry, 'utf8');
53
+ const importValues = [];
54
+ try {
55
+ const plugins = [
56
+ 'typescript',
57
+ 'decorators-legacy',
58
+ 'objectRestSpread',
59
+ 'optionalChaining',
60
+ 'nullishCoalescingOperator',
61
+ ];
62
+ const isJsx = ['.jsx', '.tsx'].indexOf(path.extname(entry)) >= 0;
63
+ if (isJsx) {
64
+ plugins.push('jsx');
65
+ }
66
+ const ast = babelParser.parse(content, {
67
+ sourceType: 'unambiguous',
68
+ plugins
69
+ });
70
+ traverse(ast, {
71
+ ImportDeclaration(astPath) {
72
+ if (astPath.node.source) {
73
+ importValues.push(astPath.node.source?.value);
74
+ }
75
+ },
76
+ ExportDeclaration(astPath) {
77
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
78
+ if (astPath.node.source) {
79
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
80
+ importValues.push(astPath.node.source?.value);
81
+ }
82
+ }
83
+ });
84
+ stats.parsedSourceFiles++;
85
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
86
+ }
87
+ catch (e) {
88
+ stats.parseErrors.push(entry);
89
+ console.log(`Failed: "${entry}"`, e?.toString());
90
+ }
91
+ for (const importValue of importValues) {
92
+ if (importValue) {
93
+ if (importValue[0] !== '.') {
94
+ const { packageName, importPath } = parseImportString(importValue);
95
+ let packagePath;
96
+ // Fix import path
97
+ const fixedImportPath = (!importPath) ? '.' : './' + importPath;
98
+ // Get package path
99
+ try {
100
+ packagePath = await resolve(packageName, path.dirname(entry));
101
+ }
102
+ catch (e) {
103
+ stats.unresolvedPackages.push({ name: packageName, from: entry });
104
+ console.log(`Unable to resolve "${packageName}" from "${entry}"`);
105
+ }
106
+ if (packagePath) {
107
+ const version = (await getPackageDefinition(packagePath, true))?.version || "unknown";
108
+ if (!allExports[packageName]?.[version]) {
109
+ stats.uniquePackages++;
110
+ }
111
+ const packageMap = allExports[packageName] = allExports[packageName] || {};
112
+ const versionMap = packageMap[version] = packageMap[version] || {};
113
+ // TODO: resolve should take in resolveMap to support resolution overrides
114
+ const relativeImportPath = await resolveImportFromPackagePath(packagePath, importPath, { preferSource: true });
115
+ const fullPath = relativeImportPath && path.join(packagePath, relativeImportPath);
116
+ let importDefinition = versionMap[fixedImportPath];
117
+ if (!importDefinition) {
118
+ stats.uniqueImports++;
119
+ importDefinition = versionMap[fixedImportPath] = {
120
+ import: undefined,
121
+ count: 0
122
+ };
123
+ }
124
+ if (fs.existsSync(fullPath)) {
125
+ importDefinition.import = './' + relativeImportPath;
126
+ addEntry(fullPath);
127
+ }
128
+ else {
129
+ stats.unresolvedPackageImports.push({ name: packageName, path: importPath, from: entry });
130
+ console.log(`Unable to resolve "${packageName}"${importPath ? ` (${importPath})` : ''} from "${entry}"`);
131
+ }
132
+ importDefinition.count++;
133
+ }
134
+ }
135
+ else { // relative path
136
+ // Not a package. Traverse source if needed.
137
+ const relativeSourcePath = resolveSource(path.resolve(path.dirname(entry), importValue));
138
+ if (relativeSourcePath) {
139
+ // console.log(`Adding ${relativeSourcePath}, "${importValue}"`);
140
+ addEntry(relativeSourcePath);
141
+ }
142
+ }
143
+ }
144
+ }
145
+ }
146
+ console.log(stats);
147
+ return { exports: allExports, stats };
148
+ }
149
+ //# sourceMappingURL=evaluateImportsFromEntries.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evaluateImportsFromEntries.js","sourceRoot":"../src/","sources":["evaluateImportsFromEntries.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,9 @@
1
+ import path from 'path';
2
+ import { evaluateImportsFromEntries } from "./evaluateImportsFromEntries.js";
3
+ import { testProject1Path } from '../src/testPaths.js';
4
+ describe('evaluateImportsFromEntries', () => {
5
+ it('can evaluate exports map', async () => {
6
+ expect(await evaluateImportsFromEntries([path.join(testProject1Path, 'src/index.ts')])).toMatchSnapshot();
7
+ });
8
+ });
9
+ //# sourceMappingURL=evaluateImportsFromEntries.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evaluateImportsFromEntries.test.js","sourceRoot":"../src/","sources":["evaluateImportsFromEntries.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAE1C,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;QAExC,MAAM,CACJ,MAAM,0BAA0B,CAC9B,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,cAAc,CAAC,CAAC,CAC9C,CACF,CAAC,eAAe,EAAE,CAAC;IACtB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function filterJson<T extends {
2
+ [key: string]: any;
3
+ }>(json: T, propName: string, filterFunction: (oldValue: string) => string): T;
@@ -0,0 +1,21 @@
1
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
2
+ export function filterJson(json, propName, filterFunction) {
3
+ for (const [name, value] of Object.entries(json)) {
4
+ if (typeof value === 'string' && name == propName) {
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ json[name] = filterFunction(value);
7
+ }
8
+ else if (typeof value === 'object') {
9
+ if (Array.isArray(value)) {
10
+ for (const item of value) {
11
+ if (typeof item === 'object') {
12
+ filterJson(value, propName, filterFunction);
13
+ }
14
+ }
15
+ }
16
+ filterJson(value, propName, filterFunction);
17
+ }
18
+ }
19
+ return json;
20
+ }
21
+ //# sourceMappingURL=filterJson.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filterJson.js","sourceRoot":"../src/","sources":["filterJson.ts"],"names":[],"mappings":"AAAA,8DAA8D;AAC9D,MAAM,UAAU,UAAU,CACxB,IAAO,EACP,QAAgB,EAChB,cAA4C;IAE5C,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QAChD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,IAAI,IAAI,QAAQ,EAAE;YACjD,8DAA8D;YAC7D,IAAY,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;SAC7C;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YACpC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACxB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;oBACxB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;wBAC5B,UAAU,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;qBAC7C;iBACF;aACF;YACD,UAAU,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;SAC7C;KACF;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { ExportsEntry } from './getPackageDefinition.js';
2
+ /**
3
+ * Given an export map entry, return the esm entry string value. (Parses arrays, maps, has a fallback system.)
4
+ */
5
+ export declare function getExportPathFromEntry(exportEntry: ExportsEntry): string | undefined;
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Given an export map entry, return the esm entry string value. (Parses arrays, maps, has a fallback system.)
3
+ */
4
+ export function getExportPathFromEntry(exportEntry) {
5
+ let exportPath = undefined;
6
+ if (exportEntry) {
7
+ if (typeof exportEntry === 'string') {
8
+ exportPath = exportEntry;
9
+ }
10
+ else if (typeof exportEntry === 'object') {
11
+ if (Array.isArray(exportEntry)) {
12
+ for (const entry of exportEntry) {
13
+ const value = getExportPathFromEntry(entry);
14
+ if (value) {
15
+ exportPath = value;
16
+ break;
17
+ }
18
+ }
19
+ }
20
+ else {
21
+ exportPath = getExportPathFromEntry(exportEntry['browser'] || exportEntry['import'] || exportEntry['default']);
22
+ }
23
+ }
24
+ }
25
+ return exportPath;
26
+ }
27
+ //# sourceMappingURL=getExportPathFromEntry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getExportPathFromEntry.js","sourceRoot":"../src/","sources":["getExportPathFromEntry.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,MAAM,UAAU,sBAAsB,CAAC,WAAyB;IAC9D,IAAI,UAAU,GAAG,SAAS,CAAC;IAE3B,IAAI,WAAW,EAAE;QACf,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;YACnC,UAAU,GAAG,WAAW,CAAC;SAC1B;aAAM,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;YAC1C,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBAC9B,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE;oBAC/B,MAAM,KAAK,GAAG,sBAAsB,CAAC,KAAK,CAAC,CAAC;oBAE5C,IAAI,KAAK,EAAE;wBACT,UAAU,GAAG,KAAK,CAAC;wBACnB,MAAM;qBACP;iBACF;aACF;iBAAM;gBACL,UAAU,GAAG,sBAAsB,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC;aAChH;SACF;KACF;IAED,OAAO,UAAU,CAAC;AACpB,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,34 @@
1
+ import { getExportPathFromEntry } from './getExportPathFromEntry.js';
2
+ describe('getExportPathFromEntry', () => {
3
+ it('gets a path from a string', () => {
4
+ expect(getExportPathFromEntry('string')).toEqual('string');
5
+ });
6
+ it('prioritizes browser response', () => {
7
+ expect(getExportPathFromEntry({
8
+ 'browser': 'browser',
9
+ 'import': 'import',
10
+ 'default': 'default',
11
+ 'require': 'require'
12
+ })).toEqual('browser');
13
+ });
14
+ it('falls back to import path if browser is missing', () => {
15
+ expect(getExportPathFromEntry({
16
+ 'import': 'import',
17
+ 'default': 'default',
18
+ 'require': 'require'
19
+ })).toEqual('import');
20
+ });
21
+ it('falls back to default if import is missing', () => {
22
+ expect(getExportPathFromEntry({
23
+ 'default': 'default',
24
+ 'require': 'require'
25
+ })).toEqual('default');
26
+ });
27
+ it('handles arrays', () => {
28
+ expect(getExportPathFromEntry([{
29
+ 'default': 'default',
30
+ 'require': 'require'
31
+ }])).toEqual('default');
32
+ });
33
+ });
34
+ //# sourceMappingURL=getExportPathFromEntry.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getExportPathFromEntry.test.js","sourceRoot":"../src/","sources":["getExportPathFromEntry.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAErE,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;IAEtC,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,sBAAsB,CAAC;YAC5B,SAAS,EAAE,SAAS;YACpB,QAAQ,EAAE,QAAQ;YAClB,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,CAAC,sBAAsB,CAAC;YAC5B,QAAQ,EAAE,QAAQ;YAClB,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACxB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,MAAM,CAAC,sBAAsB,CAAC;YAC5B,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,SAAS;SACrB,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gBAAgB,EAAE,GAAG,EAAE;QACxB,MAAM,CAAC,sBAAsB,CAAC,CAAC;gBAC7B,SAAS,EAAE,SAAS;gBACpB,SAAS,EAAE,SAAS;aACrB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;AAGL,CAAC,CAAC,CAAA"}
@@ -0,0 +1,44 @@
1
+ import type { PackageDefinition } from './getPackageDefinition.js';
2
+ export declare type PackageReference = {
3
+ name: string;
4
+ version: string;
5
+ requiredVersion?: string;
6
+ path?: PackageReference[];
7
+ };
8
+ export declare type InstalledPackagesResult = {
9
+ installedPackages: {
10
+ [packageName: string]: {
11
+ [version: string]: {
12
+ path: string;
13
+ requiredBy: PackageReference[];
14
+ };
15
+ };
16
+ };
17
+ stats?: {
18
+ totalPackageNames: number;
19
+ totalInstalled: number;
20
+ packagesWithDuplicates: number;
21
+ };
22
+ };
23
+ /**
24
+ * Traverses a package folder and uses standard node package resolution to resolve the on-disk location
25
+ * of all dependencies. The map returned follows this format:
26
+ *
27
+ * {
28
+ * [packageName]: {
29
+ * [packageVersion]: {
30
+ * path: '/path/to/package',
31
+ * requiredBy: [
32
+ * { name, version, path, requiredVersion },
33
+ * ...
34
+ * ],
35
+ * // If the same package version is installed in multiple locations, we track this.
36
+ * duplicates: [
37
+ * { ... }
38
+ * ]
39
+ * }
40
+ * }
41
+ * }
42
+ *
43
+ */
44
+ export declare function getInstalledPackages(appPaths: string | string[], installedPackages?: InstalledPackagesResult['installedPackages'], ancestors?: PackageReference[], visited?: Record<string, PackageDefinition>): Promise<InstalledPackagesResult>;
@@ -0,0 +1,87 @@
1
+ import { getPackageDefinition } from './getPackageDefinition.js';
2
+ import { resolve } from './resolve.js';
3
+ /**
4
+ * Traverses a package folder and uses standard node package resolution to resolve the on-disk location
5
+ * of all dependencies. The map returned follows this format:
6
+ *
7
+ * {
8
+ * [packageName]: {
9
+ * [packageVersion]: {
10
+ * path: '/path/to/package',
11
+ * requiredBy: [
12
+ * { name, version, path, requiredVersion },
13
+ * ...
14
+ * ],
15
+ * // If the same package version is installed in multiple locations, we track this.
16
+ * duplicates: [
17
+ * { ... }
18
+ * ]
19
+ * }
20
+ * }
21
+ * }
22
+ *
23
+ */
24
+ export async function getInstalledPackages(appPaths, installedPackages = {}, ancestors = [], visited = {}) {
25
+ let stats = undefined;
26
+ appPaths = Array.isArray(appPaths) ? appPaths : [appPaths];
27
+ for (const appPath of appPaths) {
28
+ const definition = await getPackageDefinition(appPath, true);
29
+ if (definition?.dependencies) {
30
+ for (const [dependencyName, requiredVersion] of Object.entries(definition.dependencies)) {
31
+ // Grab the path to the dependency.
32
+ const dependencyPath = await resolve(dependencyName, appPath);
33
+ if (dependencyPath) {
34
+ // It's installed. What version is this?
35
+ const dependencyDefinition = visited[dependencyPath] ||
36
+ (await getPackageDefinition(dependencyPath));
37
+ if (!dependencyDefinition) {
38
+ throw new Error(`Unable to resolve dependency at path "${dependencyPath}"`);
39
+ }
40
+ const { version: dependencyVersion } = dependencyDefinition;
41
+ // Ensure that the entry in the results is initialized.
42
+ installedPackages[dependencyName] =
43
+ installedPackages[dependencyName] || {};
44
+ installedPackages[dependencyName][dependencyVersion] = installedPackages[dependencyName][dependencyVersion] || {
45
+ path: dependencyPath,
46
+ requiredBy: [],
47
+ };
48
+ // Add this package to the requiredBy list.
49
+ installedPackages[dependencyName][dependencyVersion].requiredBy.push({
50
+ name: definition.name,
51
+ version: definition.version,
52
+ requiredVersion,
53
+ path: ancestors,
54
+ });
55
+ // If we haven't yet visited this dependency, track the definition and traverse its dependencies.
56
+ if (!visited[dependencyPath]) {
57
+ visited[dependencyPath] = dependencyDefinition;
58
+ await getInstalledPackages(dependencyPath, installedPackages, [
59
+ ...ancestors,
60
+ {
61
+ name: dependencyDefinition.name,
62
+ version: dependencyDefinition.version,
63
+ },
64
+ ], visited);
65
+ }
66
+ }
67
+ else {
68
+ // It's required, but not installed.
69
+ console.log(`The package "${dependencyName}@${requiredVersion}" was required but not installed.`, ancestors);
70
+ }
71
+ }
72
+ }
73
+ if (ancestors.length === 0) {
74
+ const packageNames = Object.keys(installedPackages);
75
+ stats = {
76
+ totalPackageNames: packageNames.length,
77
+ totalInstalled: packageNames.reduce((val, name) => val + Object.keys(installedPackages[name]).length, 0),
78
+ packagesWithDuplicates: packageNames.reduce((val, name) => val + (Object.keys(installedPackages[name]).length > 1 ? 1 : 0), 0),
79
+ };
80
+ }
81
+ }
82
+ return {
83
+ installedPackages,
84
+ stats
85
+ };
86
+ }
87
+ //# sourceMappingURL=getInstalledPackages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getInstalledPackages.js","sourceRoot":"../src/","sources":["getInstalledPackages.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};