@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.
@@ -1 +1 @@
1
- export declare function buildGraph(): void;
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.buildGraph = buildGraph;
4
- function buildGraph() {
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
- "dependency-graph": "^1.0"
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.1"
47
+ "version": "0.0.3"
48
48
  }