@mznjs/mbump 1.0.2 → 1.1.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.
@@ -1,196 +0,0 @@
1
- import { ProgressEvent, loadBumpConfig, versionBump, versionBumpInfo } from "bumpp";
2
- import { consola } from "consola";
3
- import { oraPromise } from "ora";
4
- import { existsSync } from "node:fs";
5
- import { readFile, writeFile } from "node:fs/promises";
6
- import { generateMarkDown, getGitDiff, getLastGitTag, loadChangelogConfig, parseCommits } from "changelogen";
7
- import { x } from "tinyexec";
8
- import { defu } from "defu";
9
- import { loadConfig, presetMini } from "esconf";
10
- import { glob } from "tinyglobby";
11
-
12
- //#region src/changelog.ts
13
- /**
14
- * 获取远程仓库的最新tag
15
- * @returns
16
- */
17
- async function getTag() {
18
- try {
19
- return await getLastGitTag();
20
- } catch (_e) {
21
- return "";
22
- }
23
- }
24
- /**
25
- * 生成changelog
26
- * @param rawConfig
27
- */
28
- async function changelog(rawConfig) {
29
- const config = {
30
- ...rawConfig,
31
- newVersion: rawConfig.to,
32
- to: `v${rawConfig.to}`,
33
- from: `v${rawConfig.from}`
34
- };
35
- const rawCommits = await getGitDiff(config.from);
36
- const commits = parseCommits(rawCommits, config).filter((c) => config.types[c.type] && !(c.type === "chore" && c.scope === "deps" && !c.isBreaking));
37
- let markdown = await generateMarkDown(commits, config);
38
- markdown = markdown.replace("#### ⚠️ Breaking Changes", `#### ${config.types.BreakingChange.title}`).replace("### ❤️ Contributors", "### ❤️ 贡献者");
39
- let changelogMD;
40
- if (existsSync(config.output)) changelogMD = await readFile(config.output, "utf8");
41
- else changelogMD = "# Changelog\n\n";
42
- const lastEntry = changelogMD.match(/^###?\s+.*$/m);
43
- if (lastEntry) changelogMD = `${changelogMD.slice(0, lastEntry.index) + markdown}\n\n${changelogMD.slice(lastEntry.index)}`;
44
- else changelogMD += `\n${markdown}\n\n`;
45
- await writeFile(config.output, changelogMD);
46
- await x("git", [
47
- "add",
48
- config.output,
49
- "package.json"
50
- ]);
51
- await x("git", [
52
- "commit",
53
- "-m",
54
- `chore: update ${config.output}`
55
- ]);
56
- return {
57
- markdown,
58
- changelogMD
59
- };
60
- }
61
-
62
- //#endregion
63
- //#region src/config.ts
64
- function getDefaultsChangeLogConfig() {
65
- return { types: {
66
- feat: { title: "🚀 特性" },
67
- perf: { title: "🔥 性能优化" },
68
- fix: { title: "🩹 修复" },
69
- refactor: { title: "💅 重构" },
70
- examples: { title: "🏀 示例" },
71
- docs: { title: "📖 文档" },
72
- chore: { title: "🏡 框架" },
73
- build: { title: "📦 打包" },
74
- test: { title: "✅ 测试" },
75
- BreakingChange: { title: "🚨 破坏性改动" },
76
- style: { title: "🎨 样式" }
77
- } };
78
- }
79
- /**
80
- * 合并配置项
81
- * @param rawConfig
82
- */
83
- async function resolveConfig(rawConfig) {
84
- const cwd = process.cwd();
85
- const changelog$1 = await loadChangelogConfig(cwd, getDefaultsChangeLogConfig());
86
- const bumpp = await loadBumpConfig({
87
- cwd,
88
- files: ["package.json", "package-lock.json"],
89
- commit: true,
90
- tag: true,
91
- push: true,
92
- confirm: false,
93
- ignoreScripts: false,
94
- noVerify: false
95
- });
96
- const { config } = await loadConfig({ presets: [presetMini({
97
- name: "mbump",
98
- configName: "config",
99
- rcFile: true,
100
- globalRc: true
101
- })] });
102
- const _resolveConfig = defu(rawConfig, config, {
103
- changelog: changelog$1,
104
- bumpp,
105
- accesstoken: {}
106
- });
107
- if (rawConfig.bumpp?.recursive) {
108
- const files = await glob("**/package.json", {
109
- ignore: ["**/node_modules/**"],
110
- cwd,
111
- onlyFiles: true
112
- });
113
- files.forEach((item) => {
114
- _resolveConfig.bumpp.files.push(item);
115
- });
116
- }
117
- _resolveConfig.bumpp.recursive = false;
118
- _resolveConfig.bumpp.files = [...new Set(_resolveConfig.bumpp.files)];
119
- return _resolveConfig;
120
- }
121
- const defineConfig = (config) => config;
122
-
123
- //#endregion
124
- //#region src/bump.ts
125
- /**
126
- * antfu/bumpp progress
127
- */
128
- function progress({ event, script, updatedFiles, skippedFiles, newVersion }) {
129
- switch (event) {
130
- case ProgressEvent.FileUpdated:
131
- consola.success(`Updated ${updatedFiles.pop()} to ${newVersion}`);
132
- break;
133
- case ProgressEvent.FileSkipped:
134
- consola.info(`${skippedFiles.pop()} did not need to be updated`);
135
- break;
136
- case ProgressEvent.GitCommit:
137
- consola.info("Git commit");
138
- break;
139
- case ProgressEvent.GitTag:
140
- consola.info("Git tag");
141
- break;
142
- case ProgressEvent.GitPush:
143
- consola.success("Git push");
144
- break;
145
- case ProgressEvent.NpmScript:
146
- consola.success(`Npm run ${script}`);
147
- break;
148
- }
149
- }
150
- /**
151
- * 更新版本
152
- * @param option
153
- */
154
- async function bumpVersion(option = {}) {
155
- const config = await resolveConfig(option);
156
- const currentTag = await getTag();
157
- const { state } = await versionBumpInfo();
158
- const res = { config };
159
- res.bumpp = state;
160
- if (currentTag) res.changelog = await oraPromise(changelog({
161
- ...config.changelog,
162
- to: state.newVersion,
163
- from: state.currentVersion
164
- }), {
165
- text: "changelog",
166
- successText: `Update ${config.changelog.output} success`,
167
- failText: `Update ${config.changelog.output} success`
168
- });
169
- await versionBump({
170
- ...config.bumpp,
171
- progress,
172
- release: state.newVersion
173
- });
174
- return res;
175
- }
176
- /**
177
- * 更新版本伴随基础 release 基础等待动画
178
- * @param option 更新版本配置
179
- * @param addRelease release脚本
180
- * @param provider git 远程储存提供商
181
- */
182
- async function bumpVersionWithBaseRelease(option = {}, addRelease, provider) {
183
- const { bumpp, changelog: changelog$1, config } = await bumpVersion(option);
184
- await oraPromise(addRelease({
185
- bumpp,
186
- changelog: changelog$1,
187
- config
188
- }), {
189
- text: `${provider} Release`,
190
- successText: ` [${provider}] add release v${bumpp.newVersion} success`,
191
- failText: `[${provider}] add release v${bumpp.newVersion} fail`
192
- });
193
- }
194
-
195
- //#endregion
196
- export { bumpVersion, bumpVersionWithBaseRelease, defineConfig };
@@ -1 +0,0 @@
1
- export * from "changelogen"
@@ -1 +0,0 @@
1
- export * from "changelogen"
@@ -1,76 +0,0 @@
1
- import { VersionBumpOptions, versionBumpInfo } from "bumpp";
2
- import { ChangelogConfig, ResolvedChangelogConfig } from "changelogen";
3
-
4
- //#region src/changelog.d.ts
5
- /**
6
- * 生成changelog
7
- * @param rawConfig
8
- */
9
- declare function changelog(rawConfig: ResolvedChangelogConfig): Promise<{
10
- markdown: string;
11
- changelogMD: string;
12
- }>;
13
-
14
- //#endregion
15
- //#region src/types.d.ts
16
- /**
17
- * changelog 生成配置信息
18
- */
19
- interface ChangelogOptions extends Omit<Partial<ChangelogConfig>, 'cwd' | 'tokens' | 'newVersion' | 'to' | 'from' | 'publish'> {
20
- }
21
- interface Accesstokens {
22
- [key: string]: string;
23
- }
24
- /**
25
- * 用户配置信息
26
- */
27
- interface Config {
28
- /**
29
- * changelog 生成配置信息
30
- */
31
- changelog?: ChangelogOptions;
32
- /**
33
- * bumpp 配置信息
34
- */
35
- bumpp?: Omit<VersionBumpOptions, 'progress' | 'cwd'>;
36
- accesstoken?: Accesstokens;
37
- }
38
- /**
39
- * 合并后的配置信息
40
- */
41
- interface ResolveConfig {
42
- /**
43
- * changelog 生成配置信息
44
- */
45
- changelog: ResolvedChangelogConfig;
46
- /**
47
- * bumpp 配置信息
48
- */
49
- bumpp: Omit<VersionBumpOptions, 'progress'>;
50
- accesstoken: Accesstokens;
51
- }
52
- /**
53
- * bumpp 生成结果
54
- */
55
- type BumppResult = Awaited<ReturnType<typeof versionBumpInfo>>;
56
- /**
57
- * changelog 生成结果
58
- */
59
- type ChangelogResult = Awaited<ReturnType<typeof changelog>>;
60
- /**
61
- * bumppVersion 方法返回结果
62
- */
63
- interface BumpVersion {
64
- /**
65
- * bumpp 生成结果
66
- */
67
- bumpp: BumppResult['state'];
68
- /**
69
- * changelog 生成结果
70
- */
71
- changelog: ChangelogResult;
72
- config: ResolveConfig;
73
- }
74
-
75
- //#endregion
76
- export { Accesstokens, BumpVersion, BumppResult, ChangelogOptions, ChangelogResult, Config, ResolveConfig };