zx-bulk-release 2.3.0 → 2.3.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/CHANGELOG.md CHANGED
@@ -1,3 +1,13 @@
1
+ ## [2.3.2](https://github.com/semrel-extra/zx-bulk-release/compare/v2.3.1...v2.3.2) (2023-04-02)
2
+
3
+ ### Fixes & improvements
4
+ * perf: update @semrel-extra/topo to v1.9.0 ([b6fcd15](https://github.com/semrel-extra/zx-bulk-release/commit/b6fcd15f449d1588522a68b9d51555d8966c925a))
5
+
6
+ ## [2.3.1](https://github.com/semrel-extra/zx-bulk-release/compare/v2.3.0...v2.3.1) (2023-04-02)
7
+
8
+ ### Fixes & improvements
9
+ * refactor: use `traverseQueue`, `traverseDeps` from @semrel-extra/topo ([70d6cf4](https://github.com/semrel-extra/zx-bulk-release/commit/70d6cf41fdfd1436b561f9eb1d94254408e6d6e5))
10
+
1
11
  ## [2.3.0](https://github.com/semrel-extra/zx-bulk-release/compare/v2.2.17...v2.3.0) (2023-03-28)
2
12
 
3
13
  ### Features
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "zx-bulk-release",
3
3
  "alias": "bulk-release",
4
- "version": "2.3.0",
4
+ "version": "2.3.2",
5
5
  "description": "zx-based alternative for multi-semantic-release",
6
6
  "type": "module",
7
7
  "exports": {
@@ -22,7 +22,7 @@
22
22
  "docs": "mkdir -p docs && cp ./README.md ./docs/README.md"
23
23
  },
24
24
  "dependencies": {
25
- "@semrel-extra/topo": "^1.7.0",
25
+ "@semrel-extra/topo": "^1.9.0",
26
26
  "cosmiconfig": "^8.1.3",
27
27
  "queuefy": "^1.2.1",
28
28
  "zx-extra": "^2.5.4"
@@ -30,7 +30,7 @@
30
30
  "devDependencies": {
31
31
  "c8": "^7.13.0",
32
32
  "uvu": "^0.5.6",
33
- "verdaccio": "^5.22.1"
33
+ "verdaccio": "^5.23.1"
34
34
  },
35
35
  "publishConfig": {
36
36
  "access": "public"
@@ -1,27 +1,12 @@
1
1
  import {semver} from 'zx-extra'
2
- import {topo as _topo} from '@semrel-extra/topo'
2
+ import {topo as _topo, traverseDeps} from '@semrel-extra/topo'
3
3
 
4
- export const depScopes = ['dependencies', 'devDependencies', 'peerDependencies', 'optionalDependencies']
5
-
6
- export const traverseDeps = async (pkg, packages, fn) => {
7
- const {manifest} = pkg
8
-
9
- for (let scope of depScopes) {
10
- const deps = manifest[scope]
11
- if (!deps) continue
12
-
13
- for (let [name, version] of Object.entries(deps)) {
14
- if (!packages[name]) continue
15
-
16
- await fn(pkg, {name, version, deps, scope, pkg: packages[name]})
17
- }
18
- }
19
- }
4
+ export {traverseQueue, traverseDeps} from '@semrel-extra/topo'
20
5
 
21
6
  export const updateDeps = async (pkg, packages) => {
22
7
  const changes = []
23
8
 
24
- await traverseDeps(pkg, packages, async (_, {name, version, deps, scope, pkg: dep}) => {
9
+ await traverseDeps({pkg, packages, cb: async ({name, version, deps, scope, pkg: dep}) => {
25
10
  const prev = pkg.latest.meta?.[scope]?.[name]
26
11
  const actual = dep?.version
27
12
  const next = resolveNextVersion(version, actual, prev)
@@ -37,7 +22,7 @@ export const updateDeps = async (pkg, packages) => {
37
22
  change: 'perf',
38
23
  subj: `perf: ${name} updated to ${next}`,
39
24
  })
40
- })
25
+ }})
41
26
 
42
27
  return changes
43
28
  }
@@ -78,14 +63,3 @@ export const topo = async ({flags = {}, cwd} = {}) => {
78
63
 
79
64
  return _topo({cwd, pkgFilter, depFilter})
80
65
  }
81
-
82
- export const traverseQueue = async ({queue, prev, cb}) => {
83
- const acc = {}
84
-
85
- return Promise.all(queue.map((name) =>
86
- (acc[name] = (async () => {
87
- await Promise.all((prev.get(name) || []).map((p) => acc[p]))
88
- await cb(name)
89
- })()))
90
- )
91
- }
@@ -116,7 +116,7 @@ const build = memoizeBy(async (pkg, run = runCmd, flags = {}, self = build) => w
116
116
  $.scope = pkg.name
117
117
 
118
118
  await Promise.all([
119
- traverseDeps(pkg, pkg.context.packages, async (_, {pkg}) => self(pkg, run, flags, self)),
119
+ traverseDeps({pkg, packages: pkg.context.packages, cb: async({pkg}) => self(pkg, run, flags, self)}),
120
120
  pkg.changes.length === 0 && pkg.config.npmFetch && !flags.noNpmFetch
121
121
  ? fetchPkg(pkg)
122
122
  : Promise.resolve()