colyn-cli 3.1.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.
- package/README-en.md +85 -0
- package/README.md +85 -0
- package/bin/colyn +25 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +116 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/add.d.ts +6 -0
- package/dist/commands/add.d.ts.map +1 -0
- package/dist/commands/add.helpers.d.ts +48 -0
- package/dist/commands/add.helpers.d.ts.map +1 -0
- package/dist/commands/add.helpers.js +251 -0
- package/dist/commands/add.helpers.js.map +1 -0
- package/dist/commands/add.js +286 -0
- package/dist/commands/add.js.map +1 -0
- package/dist/commands/checkout.d.ts +16 -0
- package/dist/commands/checkout.d.ts.map +1 -0
- package/dist/commands/checkout.js +428 -0
- package/dist/commands/checkout.js.map +1 -0
- package/dist/commands/completion.d.ts +10 -0
- package/dist/commands/completion.d.ts.map +1 -0
- package/dist/commands/completion.js +380 -0
- package/dist/commands/completion.js.map +1 -0
- package/dist/commands/config.d.ts +11 -0
- package/dist/commands/config.d.ts.map +1 -0
- package/dist/commands/config.js +338 -0
- package/dist/commands/config.js.map +1 -0
- package/dist/commands/index.d.ts +10 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +41 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/info.d.ts +6 -0
- package/dist/commands/info.d.ts.map +1 -0
- package/dist/commands/info.js +374 -0
- package/dist/commands/info.js.map +1 -0
- package/dist/commands/init.d.ts +6 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.handlers.d.ts +27 -0
- package/dist/commands/init.handlers.d.ts.map +1 -0
- package/dist/commands/init.handlers.js +314 -0
- package/dist/commands/init.handlers.js.map +1 -0
- package/dist/commands/init.helpers.d.ts +42 -0
- package/dist/commands/init.helpers.d.ts.map +1 -0
- package/dist/commands/init.helpers.js +275 -0
- package/dist/commands/init.helpers.js.map +1 -0
- package/dist/commands/init.js +61 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/install.d.ts +6 -0
- package/dist/commands/install.d.ts.map +1 -0
- package/dist/commands/install.helpers.d.ts +32 -0
- package/dist/commands/install.helpers.d.ts.map +1 -0
- package/dist/commands/install.helpers.js +124 -0
- package/dist/commands/install.helpers.js.map +1 -0
- package/dist/commands/install.js +104 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/list-project.d.ts +11 -0
- package/dist/commands/list-project.d.ts.map +1 -0
- package/dist/commands/list-project.js +260 -0
- package/dist/commands/list-project.js.map +1 -0
- package/dist/commands/list.d.ts +15 -0
- package/dist/commands/list.d.ts.map +1 -0
- package/dist/commands/list.helpers.d.ts +50 -0
- package/dist/commands/list.helpers.d.ts.map +1 -0
- package/dist/commands/list.helpers.js +143 -0
- package/dist/commands/list.helpers.js.map +1 -0
- package/dist/commands/list.js +530 -0
- package/dist/commands/list.js.map +1 -0
- package/dist/commands/merge.d.ts +6 -0
- package/dist/commands/merge.d.ts.map +1 -0
- package/dist/commands/merge.helpers.d.ts +74 -0
- package/dist/commands/merge.helpers.d.ts.map +1 -0
- package/dist/commands/merge.helpers.js +307 -0
- package/dist/commands/merge.helpers.js.map +1 -0
- package/dist/commands/merge.js +260 -0
- package/dist/commands/merge.js.map +1 -0
- package/dist/commands/release.d.ts +6 -0
- package/dist/commands/release.d.ts.map +1 -0
- package/dist/commands/release.helpers.d.ts +61 -0
- package/dist/commands/release.helpers.d.ts.map +1 -0
- package/dist/commands/release.helpers.js +277 -0
- package/dist/commands/release.helpers.js.map +1 -0
- package/dist/commands/release.js +127 -0
- package/dist/commands/release.js.map +1 -0
- package/dist/commands/remove.d.ts +6 -0
- package/dist/commands/remove.d.ts.map +1 -0
- package/dist/commands/remove.helpers.d.ts +59 -0
- package/dist/commands/remove.helpers.d.ts.map +1 -0
- package/dist/commands/remove.helpers.js +190 -0
- package/dist/commands/remove.helpers.js.map +1 -0
- package/dist/commands/remove.js +137 -0
- package/dist/commands/remove.js.map +1 -0
- package/dist/commands/repair.d.ts +6 -0
- package/dist/commands/repair.d.ts.map +1 -0
- package/dist/commands/repair.helpers.d.ts +5 -0
- package/dist/commands/repair.helpers.d.ts.map +1 -0
- package/dist/commands/repair.helpers.js +499 -0
- package/dist/commands/repair.helpers.js.map +1 -0
- package/dist/commands/repair.js +28 -0
- package/dist/commands/repair.js.map +1 -0
- package/dist/commands/status.d.ts +6 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +116 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/system-integration.d.ts +6 -0
- package/dist/commands/system-integration.d.ts.map +1 -0
- package/dist/commands/system-integration.helpers.d.ts +70 -0
- package/dist/commands/system-integration.helpers.d.ts.map +1 -0
- package/dist/commands/system-integration.helpers.js +313 -0
- package/dist/commands/system-integration.helpers.js.map +1 -0
- package/dist/commands/system-integration.js +132 -0
- package/dist/commands/system-integration.js.map +1 -0
- package/dist/commands/tmux.d.ts +11 -0
- package/dist/commands/tmux.d.ts.map +1 -0
- package/dist/commands/tmux.js +500 -0
- package/dist/commands/tmux.js.map +1 -0
- package/dist/commands/todo.d.ts +6 -0
- package/dist/commands/todo.d.ts.map +1 -0
- package/dist/commands/todo.helpers.d.ts +50 -0
- package/dist/commands/todo.helpers.d.ts.map +1 -0
- package/dist/commands/todo.helpers.js +297 -0
- package/dist/commands/todo.helpers.js.map +1 -0
- package/dist/commands/todo.js +579 -0
- package/dist/commands/todo.js.map +1 -0
- package/dist/commands/update.d.ts +18 -0
- package/dist/commands/update.d.ts.map +1 -0
- package/dist/commands/update.helpers.d.ts +89 -0
- package/dist/commands/update.helpers.d.ts.map +1 -0
- package/dist/commands/update.helpers.js +335 -0
- package/dist/commands/update.helpers.js.map +1 -0
- package/dist/commands/update.js +187 -0
- package/dist/commands/update.js.map +1 -0
- package/dist/core/config-loader.d.ts +47 -0
- package/dist/core/config-loader.d.ts.map +1 -0
- package/dist/core/config-loader.js +188 -0
- package/dist/core/config-loader.js.map +1 -0
- package/dist/core/config-merger.d.ts +29 -0
- package/dist/core/config-merger.d.ts.map +1 -0
- package/dist/core/config-merger.js +100 -0
- package/dist/core/config-merger.js.map +1 -0
- package/dist/core/config-migration.d.ts +64 -0
- package/dist/core/config-migration.d.ts.map +1 -0
- package/dist/core/config-migration.js +340 -0
- package/dist/core/config-migration.js.map +1 -0
- package/dist/core/config-new.d.ts +19 -0
- package/dist/core/config-new.d.ts.map +1 -0
- package/dist/core/config-new.js +58 -0
- package/dist/core/config-new.js.map +1 -0
- package/dist/core/config-schema.d.ts +221 -0
- package/dist/core/config-schema.d.ts.map +1 -0
- package/dist/core/config-schema.js +168 -0
- package/dist/core/config-schema.js.map +1 -0
- package/dist/core/config.d.ts +55 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +143 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/dev-server.d.ts +29 -0
- package/dist/core/dev-server.d.ts.map +1 -0
- package/dist/core/dev-server.js +54 -0
- package/dist/core/dev-server.js.map +1 -0
- package/dist/core/discovery.d.ts +51 -0
- package/dist/core/discovery.d.ts.map +1 -0
- package/dist/core/discovery.js +247 -0
- package/dist/core/discovery.js.map +1 -0
- package/dist/core/env.d.ts +13 -0
- package/dist/core/env.d.ts.map +1 -0
- package/dist/core/env.js +75 -0
- package/dist/core/env.js.map +1 -0
- package/dist/core/git.d.ts +31 -0
- package/dist/core/git.d.ts.map +1 -0
- package/dist/core/git.js +56 -0
- package/dist/core/git.js.map +1 -0
- package/dist/core/paths.d.ts +86 -0
- package/dist/core/paths.d.ts.map +1 -0
- package/dist/core/paths.js +256 -0
- package/dist/core/paths.js.map +1 -0
- package/dist/core/tmux-config.d.ts +174 -0
- package/dist/core/tmux-config.d.ts.map +1 -0
- package/dist/core/tmux-config.js +545 -0
- package/dist/core/tmux-config.js.map +1 -0
- package/dist/core/tmux-config.legacy.d.ts +243 -0
- package/dist/core/tmux-config.legacy.d.ts.map +1 -0
- package/dist/core/tmux-config.legacy.js +896 -0
- package/dist/core/tmux-config.legacy.js.map +1 -0
- package/dist/core/tmux.d.ts +214 -0
- package/dist/core/tmux.d.ts.map +1 -0
- package/dist/core/tmux.js +712 -0
- package/dist/core/tmux.js.map +1 -0
- package/dist/core/toolchain-resolver.d.ts +51 -0
- package/dist/core/toolchain-resolver.d.ts.map +1 -0
- package/dist/core/toolchain-resolver.js +364 -0
- package/dist/core/toolchain-resolver.js.map +1 -0
- package/dist/core/worktree-status.d.ts +20 -0
- package/dist/core/worktree-status.d.ts.map +1 -0
- package/dist/core/worktree-status.js +67 -0
- package/dist/core/worktree-status.js.map +1 -0
- package/dist/i18n/index.d.ts +36 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js +157 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/i18n/locales/en.d.ts +866 -0
- package/dist/i18n/locales/en.d.ts.map +1 -0
- package/dist/i18n/locales/en.js +985 -0
- package/dist/i18n/locales/en.js.map +1 -0
- package/dist/i18n/locales/zh-CN.d.ts +865 -0
- package/dist/i18n/locales/zh-CN.d.ts.map +1 -0
- package/dist/i18n/locales/zh-CN.js +985 -0
- package/dist/i18n/locales/zh-CN.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/plugins/builtin/gradle.d.ts +9 -0
- package/dist/plugins/builtin/gradle.d.ts.map +1 -0
- package/dist/plugins/builtin/gradle.js +164 -0
- package/dist/plugins/builtin/gradle.js.map +1 -0
- package/dist/plugins/builtin/maven.d.ts +9 -0
- package/dist/plugins/builtin/maven.d.ts.map +1 -0
- package/dist/plugins/builtin/maven.js +127 -0
- package/dist/plugins/builtin/maven.js.map +1 -0
- package/dist/plugins/builtin/npm.d.ts +9 -0
- package/dist/plugins/builtin/npm.d.ts.map +1 -0
- package/dist/plugins/builtin/npm.js +238 -0
- package/dist/plugins/builtin/npm.js.map +1 -0
- package/dist/plugins/builtin/pip.d.ts +9 -0
- package/dist/plugins/builtin/pip.d.ts.map +1 -0
- package/dist/plugins/builtin/pip.js +210 -0
- package/dist/plugins/builtin/pip.js.map +1 -0
- package/dist/plugins/builtin/xcode.d.ts +12 -0
- package/dist/plugins/builtin/xcode.d.ts.map +1 -0
- package/dist/plugins/builtin/xcode.js +438 -0
- package/dist/plugins/builtin/xcode.js.map +1 -0
- package/dist/plugins/index.d.ts +13 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +24 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/manager.d.ts +93 -0
- package/dist/plugins/manager.d.ts.map +1 -0
- package/dist/plugins/manager.js +270 -0
- package/dist/plugins/manager.js.map +1 -0
- package/dist/plugins/utils.d.ts +42 -0
- package/dist/plugins/utils.d.ts.map +1 -0
- package/dist/plugins/utils.js +175 -0
- package/dist/plugins/utils.js.map +1 -0
- package/dist/types/index.d.ts +104 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +21 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/plugin.d.ts +200 -0
- package/dist/types/plugin.d.ts.map +1 -0
- package/dist/types/plugin.js +19 -0
- package/dist/types/plugin.js.map +1 -0
- package/dist/utils/logger.d.ts +42 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +80 -0
- package/dist/utils/logger.js.map +1 -0
- package/docs/en/manual/04-command-reference/README.md +58 -0
- package/docs/en/manual/README.md +108 -0
- package/docs/zh-CN/manual/04-command-reference/README.md +58 -0
- package/docs/zh-CN/manual/README.md +108 -0
- package/package.json +65 -0
- package/shell/colyn.sh +55 -0
- package/shell/completion.bash +270 -0
- package/shell/completion.zsh +167 -0
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import ora from 'ora';
|
|
3
|
+
import simpleGit from 'simple-git';
|
|
4
|
+
import { ColynError } from '../types/index.js';
|
|
5
|
+
import { getRelevantStatusFiles } from '../core/git.js';
|
|
6
|
+
import { output, outputLine, outputSuccess, outputError, outputBold, outputStep } from '../utils/logger.js';
|
|
7
|
+
import { discoverWorktrees, getCurrentWorktreeId } from '../core/discovery.js';
|
|
8
|
+
import { t } from '../i18n/index.js';
|
|
9
|
+
/**
|
|
10
|
+
* 判断目标参数类型
|
|
11
|
+
*/
|
|
12
|
+
export function identifyTargetType(target) {
|
|
13
|
+
if (!target) {
|
|
14
|
+
return 'auto';
|
|
15
|
+
}
|
|
16
|
+
// 纯数字视为 ID
|
|
17
|
+
if (/^\d+$/.test(target)) {
|
|
18
|
+
return 'id';
|
|
19
|
+
}
|
|
20
|
+
// 包含任何字符视为分支名
|
|
21
|
+
return 'branch';
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* 自动识别当前 worktree
|
|
25
|
+
* 使用 getCurrentWorktreeId 验证目录名与 .env.local 配置一致
|
|
26
|
+
*/
|
|
27
|
+
export async function autoDetectWorktree() {
|
|
28
|
+
return getCurrentWorktreeId();
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* 根据目标参数查找 worktree
|
|
32
|
+
*/
|
|
33
|
+
export async function findWorktreeTarget(target, mainDir, worktreesDir) {
|
|
34
|
+
const worktrees = await discoverWorktrees(mainDir, worktreesDir);
|
|
35
|
+
const targetType = identifyTargetType(target);
|
|
36
|
+
let worktree;
|
|
37
|
+
if (targetType === 'auto') {
|
|
38
|
+
// 自动识别当前 worktree
|
|
39
|
+
const worktreeId = await autoDetectWorktree();
|
|
40
|
+
if (worktreeId === null) {
|
|
41
|
+
throw new ColynError(t('commands.merge.cannotAutoDetect'), t('commands.merge.cannotAutoDetectHint'));
|
|
42
|
+
}
|
|
43
|
+
worktree = worktrees.find(w => w.id === worktreeId);
|
|
44
|
+
if (!worktree) {
|
|
45
|
+
throw new ColynError(t('commands.merge.worktreeNotFound', { id: worktreeId }), t('commands.merge.worktreeNotFoundHint'));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else if (targetType === 'id') {
|
|
49
|
+
// 按 ID 查找
|
|
50
|
+
const id = parseInt(target);
|
|
51
|
+
worktree = worktrees.find(w => w.id === id);
|
|
52
|
+
if (!worktree) {
|
|
53
|
+
throw new ColynError(t('commands.merge.worktreeNotFound', { id }), t('commands.merge.branchNotFoundHint'));
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
// 按分支名查找
|
|
58
|
+
worktree = worktrees.find(w => w.branch === target);
|
|
59
|
+
if (!worktree) {
|
|
60
|
+
throw new ColynError(t('commands.merge.branchNotFound', { branch: target ?? '' }), t('commands.merge.branchNotFoundHint'));
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return worktree;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* 检查 git 工作目录状态是否干净
|
|
67
|
+
*/
|
|
68
|
+
export async function checkGitWorkingDirectory(dirPath, dirName) {
|
|
69
|
+
const git = simpleGit(dirPath);
|
|
70
|
+
const status = await git.status();
|
|
71
|
+
const changedFiles = getRelevantStatusFiles(status);
|
|
72
|
+
if (changedFiles.length > 0) {
|
|
73
|
+
const filesStr = changedFiles.slice(0, 5).map(f => ` - ${f}`).join('\n') +
|
|
74
|
+
(changedFiles.length > 5 ? `\n ... ${t('commands.remove.moreFiles', { count: changedFiles.length - 5 })}` : '');
|
|
75
|
+
throw new ColynError(t('commands.merge.dirHasUncommitted', { name: dirName }), t('commands.merge.dirHasUncommittedHint', {
|
|
76
|
+
name: dirName,
|
|
77
|
+
path: dirPath,
|
|
78
|
+
count: changedFiles.length,
|
|
79
|
+
files: filesStr
|
|
80
|
+
}));
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* 在 worktree 中更新主分支代码(默认使用 rebase,可选 merge)
|
|
85
|
+
* 这一步确保 worktree 包含主分支的所有更改
|
|
86
|
+
*/
|
|
87
|
+
export async function mergeMainIntoWorktree(worktreePath, mainBranch, useRebase = true) {
|
|
88
|
+
const git = simpleGit(worktreePath);
|
|
89
|
+
try {
|
|
90
|
+
if (useRebase) {
|
|
91
|
+
// 使用 rebase
|
|
92
|
+
await git.rebase([mainBranch]);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
// 使用 merge(允许 fast-forward)
|
|
96
|
+
await git.merge([mainBranch]);
|
|
97
|
+
}
|
|
98
|
+
// 获取最新的 commit hash
|
|
99
|
+
const log = await git.log({ n: 1 });
|
|
100
|
+
const commitHash = log.latest?.hash?.substring(0, 7) || 'unknown';
|
|
101
|
+
return {
|
|
102
|
+
success: true,
|
|
103
|
+
commitHash
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
catch (error) {
|
|
107
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
108
|
+
// 检查是否是冲突
|
|
109
|
+
if (useRebase) {
|
|
110
|
+
// rebase 冲突
|
|
111
|
+
if (errorMessage.includes('CONFLICT') || errorMessage.includes('could not apply')) {
|
|
112
|
+
const status = await git.status();
|
|
113
|
+
const conflictFiles = status.conflicted;
|
|
114
|
+
return {
|
|
115
|
+
success: false,
|
|
116
|
+
conflictFiles,
|
|
117
|
+
error: 'rebase_conflict'
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
// merge 冲突
|
|
123
|
+
if (errorMessage.includes('CONFLICT') || errorMessage.includes('Automatic merge failed')) {
|
|
124
|
+
const status = await git.status();
|
|
125
|
+
const conflictFiles = status.conflicted;
|
|
126
|
+
return {
|
|
127
|
+
success: false,
|
|
128
|
+
conflictFiles,
|
|
129
|
+
error: 'merge_conflict'
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return {
|
|
134
|
+
success: false,
|
|
135
|
+
error: errorMessage
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* 在主分支中合并 worktree 分支(使用 --no-ff)
|
|
141
|
+
* 此时 worktree 已经包含主分支的所有更改,理论上不会有冲突
|
|
142
|
+
*/
|
|
143
|
+
export async function mergeWorktreeIntoMain(mainDir, worktreeBranch) {
|
|
144
|
+
const git = simpleGit(mainDir);
|
|
145
|
+
try {
|
|
146
|
+
// 执行合并(使用 --no-ff 保持清晰的分支历史)
|
|
147
|
+
await git.merge([
|
|
148
|
+
'--no-ff',
|
|
149
|
+
worktreeBranch,
|
|
150
|
+
'-m',
|
|
151
|
+
`Merge branch '${worktreeBranch}'`
|
|
152
|
+
]);
|
|
153
|
+
// 获取合并后的 commit hash
|
|
154
|
+
const log = await git.log({ n: 1 });
|
|
155
|
+
const commitHash = log.latest?.hash?.substring(0, 7) || 'unknown';
|
|
156
|
+
return {
|
|
157
|
+
success: true,
|
|
158
|
+
commitHash
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
catch (error) {
|
|
162
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
163
|
+
// 检查是否是合并冲突(理论上不应该发生)
|
|
164
|
+
if (errorMessage.includes('CONFLICT') || errorMessage.includes('Automatic merge failed')) {
|
|
165
|
+
const status = await git.status();
|
|
166
|
+
const conflictFiles = status.conflicted;
|
|
167
|
+
return {
|
|
168
|
+
success: false,
|
|
169
|
+
conflictFiles,
|
|
170
|
+
error: 'merge_conflict'
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
return {
|
|
174
|
+
success: false,
|
|
175
|
+
error: errorMessage
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* 执行合并操作(保留用于向后兼容,但不推荐使用)
|
|
181
|
+
* @deprecated 请使用 mergeMainIntoWorktree 和 mergeWorktreeIntoMain
|
|
182
|
+
*/
|
|
183
|
+
export async function executeMerge(mainDir, branch, _mainBranch) {
|
|
184
|
+
return mergeWorktreeIntoMain(mainDir, branch);
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* 推送到远程仓库
|
|
188
|
+
*/
|
|
189
|
+
export async function pushToRemote(mainDir, mainBranch) {
|
|
190
|
+
const spinner = ora({ text: t('commands.merge.pushToRemote'), stream: process.stderr }).start();
|
|
191
|
+
try {
|
|
192
|
+
const git = simpleGit(mainDir);
|
|
193
|
+
await git.push('origin', mainBranch);
|
|
194
|
+
spinner.succeed(t('commands.merge.pushed'));
|
|
195
|
+
return { success: true };
|
|
196
|
+
}
|
|
197
|
+
catch (error) {
|
|
198
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
199
|
+
spinner.fail(t('commands.merge.pushFailed'));
|
|
200
|
+
return { success: false, error: errorMessage };
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* 显示检测到的 worktree 信息
|
|
205
|
+
*/
|
|
206
|
+
export function displayWorktreeInfo(worktree) {
|
|
207
|
+
outputLine();
|
|
208
|
+
outputBold(t('commands.merge.detectedWorktree'));
|
|
209
|
+
output(` ID: ${worktree.id}`);
|
|
210
|
+
output(` ${t('commands.merge.detectedBranchLabel')}: ${worktree.branch}`);
|
|
211
|
+
output(` ${t('commands.merge.detectedPathLabel')}: ${worktree.path}`);
|
|
212
|
+
outputLine();
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* 显示前置检查结果
|
|
216
|
+
*/
|
|
217
|
+
export function displayCheckPassed() {
|
|
218
|
+
outputSuccess(t('commands.merge.preCheckPassed'));
|
|
219
|
+
output(chalk.gray(t('commands.merge.mainDirClean')));
|
|
220
|
+
output(chalk.gray(t('commands.merge.worktreeDirClean')));
|
|
221
|
+
outputLine();
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* 显示合并成功信息
|
|
225
|
+
*/
|
|
226
|
+
export function displayMergeSuccess(mainBranch, branch, commitHash, mainDir, worktreePath, worktreeId, pushed, verbose = false) {
|
|
227
|
+
outputLine();
|
|
228
|
+
outputSuccess(t('commands.merge.mergeSuccess'));
|
|
229
|
+
if (pushed) {
|
|
230
|
+
output(chalk.gray(t('commands.merge.mergeAndPushed')));
|
|
231
|
+
}
|
|
232
|
+
if (verbose) {
|
|
233
|
+
outputLine();
|
|
234
|
+
outputBold(t('commands.merge.mergeInfo'));
|
|
235
|
+
output(` ${t('commands.merge.mainBranchLabel', { branch: mainBranch })}`);
|
|
236
|
+
output(` ${t('commands.merge.mergeBranchLabel', { branch })}`);
|
|
237
|
+
output(` ${t('commands.merge.commitLabel', { hash: commitHash, branch })}`);
|
|
238
|
+
outputLine();
|
|
239
|
+
if (!pushed) {
|
|
240
|
+
output(chalk.gray(t('commands.merge.pushLaterHint')));
|
|
241
|
+
output(chalk.gray(` cd "${mainDir}" && git push`));
|
|
242
|
+
outputLine();
|
|
243
|
+
}
|
|
244
|
+
outputBold(t('commands.merge.nextSteps'));
|
|
245
|
+
outputStep(` ${t('commands.merge.step1ViewCode')}`);
|
|
246
|
+
output(` cd "${mainDir}"`);
|
|
247
|
+
outputLine();
|
|
248
|
+
outputStep(` ${t('commands.merge.step2ContinueWorktree')}`);
|
|
249
|
+
output(` cd "${worktreePath}"`);
|
|
250
|
+
outputLine();
|
|
251
|
+
outputStep(` ${t('commands.merge.step3RemoveWorktree')}`);
|
|
252
|
+
output(` colyn remove ${worktreeId}`);
|
|
253
|
+
}
|
|
254
|
+
outputLine();
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* 显示合并冲突信息(在 worktree 中解决)
|
|
258
|
+
*/
|
|
259
|
+
export function displayMergeConflict(conflictFiles, worktreePath, worktreeBranch, mainBranch, isRebase = false) {
|
|
260
|
+
outputLine();
|
|
261
|
+
outputError(t('commands.merge.conflictTitle', { main: mainBranch, branch: worktreeBranch }));
|
|
262
|
+
outputLine();
|
|
263
|
+
outputBold(t('commands.merge.conflictFiles'));
|
|
264
|
+
for (const file of conflictFiles) {
|
|
265
|
+
output(` ${file}`);
|
|
266
|
+
}
|
|
267
|
+
outputLine();
|
|
268
|
+
outputBold(t('commands.merge.resolveSteps'));
|
|
269
|
+
outputStep(` ${t('commands.merge.resolveStep1')}`);
|
|
270
|
+
output(` cd "${worktreePath}"`);
|
|
271
|
+
outputLine();
|
|
272
|
+
outputStep(` ${t('commands.merge.resolveStep2')}`);
|
|
273
|
+
outputLine();
|
|
274
|
+
outputStep(` ${t('commands.merge.resolveStep3')}`);
|
|
275
|
+
output(' git add <file>');
|
|
276
|
+
outputLine();
|
|
277
|
+
if (isRebase) {
|
|
278
|
+
// rebase 冲突的解决步骤
|
|
279
|
+
outputStep(` ${t('commands.merge.resolveStep4Rebase')}`);
|
|
280
|
+
output(' git rebase --continue');
|
|
281
|
+
outputLine();
|
|
282
|
+
outputStep(` ${t('commands.merge.resolveStep4RebaseAbort')}`);
|
|
283
|
+
output(' git rebase --abort');
|
|
284
|
+
}
|
|
285
|
+
else {
|
|
286
|
+
// merge 冲突的解决步骤
|
|
287
|
+
outputStep(` ${t('commands.merge.resolveStep4')}`);
|
|
288
|
+
output(' git commit');
|
|
289
|
+
}
|
|
290
|
+
outputLine();
|
|
291
|
+
outputStep(` ${t('commands.merge.resolveStep5')}`);
|
|
292
|
+
output(` colyn merge ${worktreeBranch}`);
|
|
293
|
+
outputLine();
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* 显示推送失败信息
|
|
297
|
+
*/
|
|
298
|
+
export function displayPushFailed(error, mainDir, mainBranch) {
|
|
299
|
+
outputLine();
|
|
300
|
+
outputError(t('commands.merge.pushFailedTitle'));
|
|
301
|
+
output(chalk.gray(t('commands.merge.pushFailedError', { error })));
|
|
302
|
+
outputLine();
|
|
303
|
+
output(t('commands.merge.pushFailedHint'));
|
|
304
|
+
output(` cd "${mainDir}" && git push origin ${mainBranch}`);
|
|
305
|
+
outputLine();
|
|
306
|
+
}
|
|
307
|
+
//# sourceMappingURL=merge.helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge.helpers.js","sourceRoot":"","sources":["../../src/commands/merge.helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
import Enquirer from 'enquirer';
|
|
2
|
+
import ora from 'ora';
|
|
3
|
+
import { getProjectPaths, validateProjectInitialized, executeInDirectory } from '../core/paths.js';
|
|
4
|
+
import { getMainBranch, discoverWorktrees } from '../core/discovery.js';
|
|
5
|
+
import { ColynError } from '../types/index.js';
|
|
6
|
+
import { formatError, output, outputResult, outputSuccess } from '../utils/logger.js';
|
|
7
|
+
import { checkIsGitRepo } from './add.helpers.js';
|
|
8
|
+
import { findWorktreeTarget, checkGitWorkingDirectory, mergeMainIntoWorktree, mergeWorktreeIntoMain, pushToRemote, displayWorktreeInfo, displayCheckPassed, displayMergeSuccess, displayMergeConflict, displayPushFailed } from './merge.helpers.js';
|
|
9
|
+
import { pluginManager } from '../plugins/index.js';
|
|
10
|
+
import { resolveToolchains } from '../core/toolchain-resolver.js';
|
|
11
|
+
import { pullMainBranch, updateAllWorktrees, displayBatchUpdateResult } from './update.helpers.js';
|
|
12
|
+
import { t } from '../i18n/index.js';
|
|
13
|
+
import { setWorktreeStatus } from '../core/worktree-status.js';
|
|
14
|
+
/**
|
|
15
|
+
* Merge 命令:将 worktree 分支合并回主分支
|
|
16
|
+
*
|
|
17
|
+
* 流程:
|
|
18
|
+
* 1. 前置检查(主分支和 worktree 都干净)
|
|
19
|
+
* 2. 在 worktree 中 rebase 主分支(默认),确保 worktree 包含主分支的所有更改
|
|
20
|
+
* 3. 如果有冲突,提示用户在 worktree 中解决
|
|
21
|
+
* 4. 在主分支中合并 worktree 分支(--no-ff),此时不会有冲突
|
|
22
|
+
* 5. 推送处理
|
|
23
|
+
*/
|
|
24
|
+
async function mergeCommand(target, options) {
|
|
25
|
+
try {
|
|
26
|
+
// 步骤1: 获取项目路径并验证
|
|
27
|
+
const paths = await getProjectPaths();
|
|
28
|
+
await validateProjectInitialized(paths);
|
|
29
|
+
// 步骤2: 在主分支目录中检查 git 仓库
|
|
30
|
+
await executeInDirectory(paths.mainDir, async () => {
|
|
31
|
+
await checkIsGitRepo();
|
|
32
|
+
});
|
|
33
|
+
// 步骤3: 查找目标 worktree
|
|
34
|
+
const worktree = await findWorktreeTarget(target, paths.mainDir, paths.worktreesDir);
|
|
35
|
+
// 显示 worktree 信息
|
|
36
|
+
if (options.verbose) {
|
|
37
|
+
displayWorktreeInfo(worktree);
|
|
38
|
+
}
|
|
39
|
+
// 步骤4: 前置检查
|
|
40
|
+
const checkSpinner = ora({ text: t('commands.merge.preCheck'), stream: process.stderr }).start();
|
|
41
|
+
try {
|
|
42
|
+
// 检查主分支工作目录
|
|
43
|
+
await checkGitWorkingDirectory(paths.mainDir, t('commands.merge.mainDirClean').replace('✓ ', '').replace(' working directory clean', ''));
|
|
44
|
+
// 检查 worktree 工作目录
|
|
45
|
+
await checkGitWorkingDirectory(worktree.path, 'Worktree');
|
|
46
|
+
checkSpinner.succeed(t('commands.merge.preCheckPassed'));
|
|
47
|
+
if (options.verbose) {
|
|
48
|
+
displayCheckPassed();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
checkSpinner.fail(t('commands.merge.preCheckFailed'));
|
|
53
|
+
throw error;
|
|
54
|
+
}
|
|
55
|
+
// 解析工具链上下文
|
|
56
|
+
const contexts = await resolveToolchains(paths.rootDir, worktree.path);
|
|
57
|
+
// 步骤4.5: Lint 和 Build 检查(可通过 --skip-build 跳过)
|
|
58
|
+
if (options.skipBuild) {
|
|
59
|
+
output(t('commands.merge.skippingBuild'));
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
for (const ctx of contexts) {
|
|
63
|
+
const lintSpinner = ora({ text: t('commands.merge.runningLint'), stream: process.stderr }).start();
|
|
64
|
+
try {
|
|
65
|
+
await pluginManager.runLint(ctx.absolutePath, [ctx.toolchainName], options.verbose);
|
|
66
|
+
lintSpinner.succeed(t('commands.merge.lintPassed'));
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
lintSpinner.fail(t('commands.merge.lintFailed'));
|
|
70
|
+
throw error;
|
|
71
|
+
}
|
|
72
|
+
const buildSpinner = ora({ text: t('commands.merge.runningBuild'), stream: process.stderr }).start();
|
|
73
|
+
try {
|
|
74
|
+
await pluginManager.runBuild(ctx.absolutePath, [ctx.toolchainName], options.verbose);
|
|
75
|
+
buildSpinner.succeed(t('commands.merge.buildPassed'));
|
|
76
|
+
}
|
|
77
|
+
catch (error) {
|
|
78
|
+
buildSpinner.fail(t('commands.merge.buildFailed'));
|
|
79
|
+
throw error;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// 步骤5: 获取主分支名称
|
|
84
|
+
const mainBranch = await getMainBranch(paths.mainDir);
|
|
85
|
+
// 确定是否使用 rebase(默认 true)
|
|
86
|
+
const useRebase = !options.noRebase;
|
|
87
|
+
// 步骤6: 在 worktree 中更新主分支代码(确保 worktree 包含主分支的所有更改)
|
|
88
|
+
if (options.verbose) {
|
|
89
|
+
output(t('commands.merge.step1Title'));
|
|
90
|
+
output(t('commands.merge.step1Dir', { path: worktree.path }));
|
|
91
|
+
if (useRebase) {
|
|
92
|
+
output(t('commands.merge.step1CmdRebase', { branch: mainBranch }));
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
output(t('commands.merge.step1Cmd', { branch: mainBranch }));
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
const step1Spinner = ora({ text: useRebase ? t('commands.merge.rebasingMain') : t('commands.merge.mergingMain'), stream: process.stderr }).start();
|
|
99
|
+
const step1Result = await executeInDirectory(worktree.path, async () => {
|
|
100
|
+
return await mergeMainIntoWorktree(worktree.path, mainBranch, useRebase);
|
|
101
|
+
});
|
|
102
|
+
if (!step1Result.success) {
|
|
103
|
+
step1Spinner.fail(useRebase ? t('commands.merge.mainRebaseFailed') : t('commands.merge.mainMergeFailed'));
|
|
104
|
+
if (step1Result.error === 'rebase_conflict' || step1Result.error === 'merge_conflict') {
|
|
105
|
+
// 冲突 - 在 worktree 中解决
|
|
106
|
+
displayMergeConflict(step1Result.conflictFiles || [], worktree.path, worktree.branch, mainBranch, useRebase);
|
|
107
|
+
outputResult({ success: false });
|
|
108
|
+
process.exit(1);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
throw new ColynError(useRebase ? t('commands.merge.mainRebaseFailed') : t('commands.merge.mainMergeFailed'), step1Result.error || t('common.unknownError'));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
step1Spinner.succeed(useRebase ? t('commands.merge.mainRebased') : t('commands.merge.mainMerged'));
|
|
115
|
+
// 步骤7: 在主分支中合并 worktree 分支
|
|
116
|
+
if (options.verbose) {
|
|
117
|
+
output(t('commands.merge.step2Title'));
|
|
118
|
+
output(t('commands.merge.step2Dir', { path: paths.mainDir }));
|
|
119
|
+
output(t('commands.merge.step2Cmd', { branch: worktree.branch }));
|
|
120
|
+
}
|
|
121
|
+
const step2Spinner = ora({ text: t('commands.merge.mergingWorktree'), stream: process.stderr }).start();
|
|
122
|
+
const step2Result = await executeInDirectory(paths.mainDir, async () => {
|
|
123
|
+
return await mergeWorktreeIntoMain(paths.mainDir, worktree.branch);
|
|
124
|
+
});
|
|
125
|
+
if (!step2Result.success) {
|
|
126
|
+
step2Spinner.fail(t('commands.merge.worktreeMergeFailed'));
|
|
127
|
+
// 理论上不应该发生冲突,但还是处理一下
|
|
128
|
+
if (step2Result.error === 'merge_conflict') {
|
|
129
|
+
throw new ColynError(t('commands.merge.unexpectedConflict'), t('commands.merge.unexpectedConflictHint', { path: paths.mainDir }));
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
throw new ColynError(t('commands.merge.mergeFailed'), step2Result.error || t('common.unknownError'));
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
step2Spinner.succeed(t('commands.merge.worktreeMerged'));
|
|
136
|
+
outputSuccess(t('commands.merge.mergeComplete'));
|
|
137
|
+
// 更新 worktree 状态为 idle
|
|
138
|
+
try {
|
|
139
|
+
await setWorktreeStatus(paths.configDir, `task-${worktree.id}`, paths.rootDir, 'idle');
|
|
140
|
+
}
|
|
141
|
+
catch { /* 状态更新失败不影响主流程 */ }
|
|
142
|
+
// 步骤8: 推送处理
|
|
143
|
+
let pushed = false;
|
|
144
|
+
// 检查用户是否显式指定了 --push 或 --no-push 参数
|
|
145
|
+
const explicitPush = process.argv.includes('--push');
|
|
146
|
+
const explicitNoPush = process.argv.includes('--no-push');
|
|
147
|
+
if (explicitPush) {
|
|
148
|
+
// --push: 自动推送
|
|
149
|
+
const pushResult = await pushToRemote(paths.mainDir, mainBranch);
|
|
150
|
+
if (pushResult.success) {
|
|
151
|
+
pushed = true;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
displayPushFailed(pushResult.error || t('common.unknownError'), paths.mainDir, mainBranch);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
else if (!explicitNoPush) {
|
|
158
|
+
// 没有指定 --no-push:询问用户
|
|
159
|
+
const enquirer = new Enquirer({ stdout: process.stderr });
|
|
160
|
+
const response = await enquirer.prompt({
|
|
161
|
+
type: 'confirm',
|
|
162
|
+
name: 'shouldPush',
|
|
163
|
+
message: t('commands.merge.shouldPush'),
|
|
164
|
+
initial: false
|
|
165
|
+
});
|
|
166
|
+
if (response.shouldPush) {
|
|
167
|
+
const pushResult = await pushToRemote(paths.mainDir, mainBranch);
|
|
168
|
+
if (pushResult.success) {
|
|
169
|
+
pushed = true;
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
displayPushFailed(pushResult.error || t('common.unknownError'), paths.mainDir, mainBranch);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
// 指定了 --no-push: 不推送,不询问
|
|
177
|
+
// 步骤9: 显示成功信息
|
|
178
|
+
displayMergeSuccess(mainBranch, worktree.branch, step2Result.commitHash || 'unknown', paths.mainDir, worktree.path, worktree.id, pushed, options.verbose);
|
|
179
|
+
// 步骤10: 自动更新 worktrees
|
|
180
|
+
if (!options.noUpdate) {
|
|
181
|
+
output('');
|
|
182
|
+
// 拉取主分支最新代码(如果已经 push,则主分支已经是最新的)
|
|
183
|
+
if (!pushed) {
|
|
184
|
+
try {
|
|
185
|
+
await pullMainBranch(paths.mainDir, options.fetch === false);
|
|
186
|
+
}
|
|
187
|
+
catch (error) {
|
|
188
|
+
// 拉取失败不影响更新流程,因为本地已经有最新代码
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
if (options.updateAll) {
|
|
192
|
+
// --update-all: 更新所有 worktrees(包括当前的)
|
|
193
|
+
output(t('commands.merge.updatingAllWorktrees'));
|
|
194
|
+
const allWorktrees = await discoverWorktrees(paths.mainDir, paths.worktreesDir);
|
|
195
|
+
if (allWorktrees.length > 0) {
|
|
196
|
+
const updateResult = await updateAllWorktrees(allWorktrees, mainBranch, true // 默认使用 rebase
|
|
197
|
+
);
|
|
198
|
+
displayBatchUpdateResult(updateResult);
|
|
199
|
+
if (updateResult.failed > 0) {
|
|
200
|
+
output('');
|
|
201
|
+
output(t('commands.merge.updatePartialSuccess'));
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
// 默认:仅更新当前 worktree
|
|
207
|
+
output(t('commands.merge.updatingCurrentWorktree'));
|
|
208
|
+
const updateSpinner = ora({
|
|
209
|
+
text: t('commands.update.updating', { strategy: 'rebase' }),
|
|
210
|
+
stream: process.stderr
|
|
211
|
+
}).start();
|
|
212
|
+
const updateResult = await executeInDirectory(worktree.path, async () => {
|
|
213
|
+
return await updateAllWorktrees([worktree], mainBranch, true);
|
|
214
|
+
});
|
|
215
|
+
if (updateResult.succeeded > 0) {
|
|
216
|
+
updateSpinner.succeed(t('commands.update.updateSuccess'));
|
|
217
|
+
}
|
|
218
|
+
else if (updateResult.skipped > 0) {
|
|
219
|
+
updateSpinner.warn(t('commands.update.dirtySkipped'));
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
updateSpinner.fail(t('commands.update.updateFailed'));
|
|
223
|
+
if (updateResult.results[0]?.error) {
|
|
224
|
+
output(t('common.hint') + ': ' + updateResult.results[0].error);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
// 步骤11: 输出 JSON 结果到 stdout(不设置 targetDir,保持在原目录)
|
|
230
|
+
const result = {
|
|
231
|
+
success: true
|
|
232
|
+
};
|
|
233
|
+
outputResult(result);
|
|
234
|
+
}
|
|
235
|
+
catch (error) {
|
|
236
|
+
formatError(error);
|
|
237
|
+
outputResult({ success: false });
|
|
238
|
+
process.exit(1);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* 注册 merge 命令
|
|
243
|
+
*/
|
|
244
|
+
export function register(program) {
|
|
245
|
+
program
|
|
246
|
+
.command('merge [target]')
|
|
247
|
+
.description(t('commands.merge.description'))
|
|
248
|
+
.option('--no-rebase', t('commands.merge.noRebaseOption'))
|
|
249
|
+
.option('--push', t('commands.merge.pushOption'))
|
|
250
|
+
.option('--no-push', t('commands.merge.noPushOption'))
|
|
251
|
+
.option('--no-update', t('commands.merge.noUpdateOption'))
|
|
252
|
+
.option('--update-all', t('commands.merge.updateAllOption'))
|
|
253
|
+
.option('-v, --verbose', t('commands.merge.verboseOption'))
|
|
254
|
+
.option('--no-fetch', t('commands.merge.noFetchOption'))
|
|
255
|
+
.option('--skip-build', t('commands.merge.skipBuildOption'))
|
|
256
|
+
.action(async (target, options) => {
|
|
257
|
+
await mergeCommand(target, options);
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
//# sourceMappingURL=merge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge.js","sourceRoot":"","sources":["../../src/commands/merge.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"release.d.ts","sourceRoot":"","sources":["../../src/commands/release.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AA8JzC;;GAEG;AACH,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAS/C"}
|