@itrocks/dependency 0.0.2 → 0.0.4

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 (2) hide show
  1. package/cjs/dependency.js +48 -13
  2. package/package.json +1 -2
package/cjs/dependency.js CHANGED
@@ -2,28 +2,63 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.dependencies = dependencies;
4
4
  const app_dir_1 = require("@itrocks/app-dir");
5
- const dependency_graph_1 = require("dependency-graph");
6
5
  const list_installed_1 = require("list-installed");
7
6
  async function dependencies(path = app_dir_1.appDir) {
8
7
  const dependencies = new Map;
9
- const graph = new dependency_graph_1.DepGraph();
8
+ const already = new Set;
9
+ const result = new Array;
10
+ // list installed packages and their dependencies
10
11
  for (const [packageName, packageJson] of (await (0, list_installed_1.listInstalled)(path)).entries()) {
11
- dependencies.set(packageName, Object.keys(packageJson.dependencies ?? {}));
12
- }
13
- for (const packageName of dependencies.keys()) {
14
- graph.addNode(packageName);
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
+ }
15
25
  }
26
+ // remove not-installed dependencies
16
27
  for (const [packageName, packageDependencies] of dependencies.entries()) {
17
- if (packageName.startsWith('@itrocks'))
18
- console.log('deps of', packageName + ':');
19
28
  for (const dependency of packageDependencies) {
20
- if (dependencies.has(dependency)) {
21
- if (packageName.startsWith('@itrocks'))
22
- console.log('>', dependency);
23
- graph.addDependency(packageName, dependency);
29
+ if (!dependencies.has(dependency)) {
30
+ packageDependencies.delete(dependency);
24
31
  }
25
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(', ');
26
60
  }
27
- return graph.overallOrder();
61
+ // done
62
+ return result;
28
63
  }
29
64
  //# sourceMappingURL=dependency.js.map
package/package.json CHANGED
@@ -4,7 +4,6 @@
4
4
  "email": "baptiste@pillot.fr"
5
5
  },
6
6
  "dependencies": {
7
- "dependency-graph": "^1.0",
8
7
  "list-installed": "^5.3"
9
8
  },
10
9
  "description": "Builds a dependency-sorted list of Nodes.js modules",
@@ -45,5 +44,5 @@
45
44
  "build": "tsc"
46
45
  },
47
46
  "types": "./cjs/dependency.d.ts",
48
- "version": "0.0.2"
47
+ "version": "0.0.4"
49
48
  }