zx-bulk-release 2.3.0 → 2.3.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.
- package/CHANGELOG.md +5 -0
- package/package.json +3 -3
- package/src/main/js/deps.js +4 -30
- package/src/main/js/processor.js +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,8 @@
|
|
|
1
|
+
## [2.3.1](https://github.com/semrel-extra/zx-bulk-release/compare/v2.3.0...v2.3.1) (2023-04-02)
|
|
2
|
+
|
|
3
|
+
### Fixes & improvements
|
|
4
|
+
* refactor: use `traverseQueue`, `traverseDeps` from @semrel-extra/topo ([70d6cf4](https://github.com/semrel-extra/zx-bulk-release/commit/70d6cf41fdfd1436b561f9eb1d94254408e6d6e5))
|
|
5
|
+
|
|
1
6
|
## [2.3.0](https://github.com/semrel-extra/zx-bulk-release/compare/v2.2.17...v2.3.0) (2023-03-28)
|
|
2
7
|
|
|
3
8
|
### 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.
|
|
4
|
+
"version": "2.3.1",
|
|
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.
|
|
25
|
+
"@semrel-extra/topo": "^1.8.1",
|
|
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.
|
|
33
|
+
"verdaccio": "^5.23.1"
|
|
34
34
|
},
|
|
35
35
|
"publishConfig": {
|
|
36
36
|
"access": "public"
|
package/src/main/js/deps.js
CHANGED
|
@@ -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
|
|
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 (
|
|
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
|
-
}
|
package/src/main/js/processor.js
CHANGED
|
@@ -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
|
|
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()
|