@itrocks/dependency 0.0.1 → 0.0.3
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/cjs/dependency.d.ts +1 -1
- package/cjs/dependency.js +60 -2
- package/package.json +2 -2
package/cjs/dependency.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare function
|
|
1
|
+
export declare function dependencies(path?: string): Promise<string[]>;
|
package/cjs/dependency.js
CHANGED
|
@@ -1,6 +1,64 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
3
|
+
exports.dependencies = dependencies;
|
|
4
|
+
const app_dir_1 = require("@itrocks/app-dir");
|
|
5
|
+
const list_installed_1 = require("list-installed");
|
|
6
|
+
async function dependencies(path = app_dir_1.appDir) {
|
|
7
|
+
const dependencies = new Map;
|
|
8
|
+
const already = new Set;
|
|
9
|
+
const result = new Array;
|
|
10
|
+
// list installed packages and their dependencies
|
|
11
|
+
for (const [packageName, packageJson] of (await (0, list_installed_1.listInstalled)(path)).entries()) {
|
|
12
|
+
const packageDependencies = new Set;
|
|
13
|
+
for (const dependency of Object.keys(packageJson.dependencies ?? {})) {
|
|
14
|
+
if (!already.has(dependency)) {
|
|
15
|
+
packageDependencies.add(dependency);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
if (packageDependencies.size) {
|
|
19
|
+
dependencies.set(packageName, packageDependencies);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
already.add(packageName);
|
|
23
|
+
result.push(packageName);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
// remove not-installed dependencies
|
|
27
|
+
for (const [packageName, packageDependencies] of dependencies.entries()) {
|
|
28
|
+
for (const dependency of packageDependencies) {
|
|
29
|
+
if (!dependencies.has(dependency)) {
|
|
30
|
+
packageDependencies.delete(dependency);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
if (!packageDependencies.size) {
|
|
34
|
+
dependencies.delete(packageName);
|
|
35
|
+
already.add(packageName);
|
|
36
|
+
result.push(packageName);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
// order packages by their dependencies
|
|
40
|
+
let didSomething = true;
|
|
41
|
+
while (dependencies && didSomething) {
|
|
42
|
+
didSomething = false;
|
|
43
|
+
for (const [packageName, packageDependencies] of dependencies.entries()) {
|
|
44
|
+
for (const dependency of packageDependencies) {
|
|
45
|
+
if (already.has(dependency)) {
|
|
46
|
+
packageDependencies.delete(dependency);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (!packageDependencies.size) {
|
|
50
|
+
dependencies.delete(packageName);
|
|
51
|
+
already.add(packageName);
|
|
52
|
+
result.push(packageName);
|
|
53
|
+
didSomething = true;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// cyclic dependency error
|
|
58
|
+
if (dependencies.size) {
|
|
59
|
+
throw 'Cyclic dependencies: ' + new Array(dependencies.keys()).join(', ');
|
|
60
|
+
}
|
|
61
|
+
// done
|
|
62
|
+
return result;
|
|
5
63
|
}
|
|
6
64
|
//# sourceMappingURL=dependency.js.map
|
package/package.json
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"email": "baptiste@pillot.fr"
|
|
5
5
|
},
|
|
6
6
|
"dependencies": {
|
|
7
|
-
"
|
|
7
|
+
"list-installed": "^5.3"
|
|
8
8
|
},
|
|
9
9
|
"description": "Builds a dependency-sorted list of Nodes.js modules",
|
|
10
10
|
"devDependencies": {
|
|
@@ -44,5 +44,5 @@
|
|
|
44
44
|
"build": "tsc"
|
|
45
45
|
},
|
|
46
46
|
"types": "./cjs/dependency.d.ts",
|
|
47
|
-
"version": "0.0.
|
|
47
|
+
"version": "0.0.3"
|
|
48
48
|
}
|