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,89 @@
|
|
|
1
|
+
import type { WorktreeInfo } from '../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* 识别目标类型
|
|
4
|
+
*/
|
|
5
|
+
export type TargetType = 'id' | 'branch' | 'auto';
|
|
6
|
+
/**
|
|
7
|
+
* 判断目标参数类型
|
|
8
|
+
*/
|
|
9
|
+
export declare function identifyTargetType(target: string | undefined): TargetType;
|
|
10
|
+
/**
|
|
11
|
+
* 自动识别当前 worktree
|
|
12
|
+
*/
|
|
13
|
+
export declare function autoDetectWorktree(): Promise<number | null>;
|
|
14
|
+
/**
|
|
15
|
+
* 根据目标参数查找 worktree
|
|
16
|
+
*/
|
|
17
|
+
export declare function findWorktreeTarget(target: string | undefined, mainDir: string, worktreesDir: string): Promise<WorktreeInfo>;
|
|
18
|
+
/**
|
|
19
|
+
* 检查 git 工作目录状态是否干净
|
|
20
|
+
*/
|
|
21
|
+
export declare function checkGitWorkingDirectory(dirPath: string, dirName: string): Promise<void>;
|
|
22
|
+
/**
|
|
23
|
+
* 更新结果
|
|
24
|
+
*/
|
|
25
|
+
export interface UpdateResult {
|
|
26
|
+
success: boolean;
|
|
27
|
+
conflictFiles?: string[];
|
|
28
|
+
error?: string;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* 批量更新结果
|
|
32
|
+
*/
|
|
33
|
+
export interface BatchUpdateResult {
|
|
34
|
+
total: number;
|
|
35
|
+
succeeded: number;
|
|
36
|
+
failed: number;
|
|
37
|
+
skipped: number;
|
|
38
|
+
results: Array<{
|
|
39
|
+
worktree: WorktreeInfo;
|
|
40
|
+
success: boolean;
|
|
41
|
+
error?: string;
|
|
42
|
+
skipped?: boolean;
|
|
43
|
+
}>;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 拉取主分支最新代码
|
|
47
|
+
*/
|
|
48
|
+
export declare function pullMainBranch(mainDir: string, skipPull?: boolean): Promise<void>;
|
|
49
|
+
/**
|
|
50
|
+
* 使用 rebase 更新 worktree
|
|
51
|
+
*/
|
|
52
|
+
export declare function rebaseWorktree(worktreePath: string, mainBranch: string): Promise<UpdateResult>;
|
|
53
|
+
/**
|
|
54
|
+
* 使用 merge 更新 worktree
|
|
55
|
+
*/
|
|
56
|
+
export declare function mergeMainIntoWorktree(worktreePath: string, mainBranch: string): Promise<UpdateResult>;
|
|
57
|
+
/**
|
|
58
|
+
* 更新单个 worktree
|
|
59
|
+
*/
|
|
60
|
+
export declare function updateSingleWorktree(worktree: WorktreeInfo, mainBranch: string, useRebase: boolean): Promise<UpdateResult>;
|
|
61
|
+
/**
|
|
62
|
+
* 批量更新所有 worktree
|
|
63
|
+
*/
|
|
64
|
+
export declare function updateAllWorktrees(worktrees: WorktreeInfo[], mainBranch: string, useRebase: boolean): Promise<BatchUpdateResult>;
|
|
65
|
+
/**
|
|
66
|
+
* 显示检测到的 worktree 信息
|
|
67
|
+
*/
|
|
68
|
+
export declare function displayWorktreeInfo(worktree: WorktreeInfo): void;
|
|
69
|
+
/**
|
|
70
|
+
* 显示更新成功信息
|
|
71
|
+
*/
|
|
72
|
+
export declare function displayUpdateSuccess(mainBranch: string, worktreeBranch: string, useRebase: boolean): void;
|
|
73
|
+
/**
|
|
74
|
+
* 显示 rebase 冲突信息
|
|
75
|
+
*/
|
|
76
|
+
export declare function displayRebaseConflict(conflictFiles: string[], _worktreePath: string): void;
|
|
77
|
+
/**
|
|
78
|
+
* 显示 merge 冲突信息
|
|
79
|
+
*/
|
|
80
|
+
export declare function displayMergeConflict(conflictFiles: string[], _worktreePath: string): void;
|
|
81
|
+
/**
|
|
82
|
+
* 显示批量更新结果
|
|
83
|
+
*/
|
|
84
|
+
export declare function displayBatchUpdateResult(result: BatchUpdateResult): void;
|
|
85
|
+
/**
|
|
86
|
+
* 显示发现的 worktree 列表
|
|
87
|
+
*/
|
|
88
|
+
export declare function displayWorktreeList(worktrees: WorktreeInfo[]): void;
|
|
89
|
+
//# sourceMappingURL=update.helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.helpers.d.ts","sourceRoot":"","sources":["../../src/commands/update.helpers.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAetD;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,QAAQ,GAAG,MAAM,CAAC;AAElD;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,CAYzE;AAED;;GAEG;AACH,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAEjE;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,MAAM,EAAE,MAAM,GAAG,SAAS,EAC1B,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,YAAY,CAAC,CA4CvB;AAED;;GAEG;AACH,wBAAsB,wBAAwB,CAC5C,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CAmBf;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,KAAK,CAAC;QACb,QAAQ,EAAE,YAAY,CAAC;QACvB,OAAO,EAAE,OAAO,CAAC;QACjB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,CAAC,CAAC;CACJ;AAED;;GAEG;AACH,wBAAsB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,UAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,CAyBrF;AAGD;;GAEG;AACH,wBAAsB,cAAc,CAClC,YAAY,EAAE,MAAM,EACpB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,YAAY,CAAC,CA4BvB;AAED;;GAEG;AACH,wBAAsB,qBAAqB,CACzC,YAAY,EAAE,MAAM,EACpB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,YAAY,CAAC,CA4BvB;AAED;;GAEG;AACH,wBAAsB,oBAAoB,CACxC,QAAQ,EAAE,YAAY,EACtB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,OAAO,GACjB,OAAO,CAAC,YAAY,CAAC,CAMvB;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,YAAY,EAAE,EACzB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,OAAO,GACjB,OAAO,CAAC,iBAAiB,CAAC,CA+C5B;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,YAAY,GAAG,IAAI,CAOhE;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,UAAU,EAAE,MAAM,EAClB,cAAc,EAAE,MAAM,EACtB,SAAS,EAAE,OAAO,GACjB,IAAI,CAMN;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,aAAa,EAAE,MAAM,EAAE,EACvB,aAAa,EAAE,MAAM,GACpB,IAAI,CAuBN;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,aAAa,EAAE,MAAM,EAAE,EACvB,aAAa,EAAE,MAAM,GACpB,IAAI,CAuBN;AAED;;GAEG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,iBAAiB,GAAG,IAAI,CA4BxE;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,YAAY,EAAE,GAAG,IAAI,CAMnE"}
|
|
@@ -0,0 +1,335 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import simpleGit from 'simple-git';
|
|
3
|
+
import { ColynError } from '../types/index.js';
|
|
4
|
+
import { getRelevantStatusFiles } from '../core/git.js';
|
|
5
|
+
import { output, outputLine, outputSuccess, outputError, outputWarning, outputBold, outputStep } from '../utils/logger.js';
|
|
6
|
+
import { discoverWorktrees, getCurrentWorktreeId } from '../core/discovery.js';
|
|
7
|
+
import { t } from '../i18n/index.js';
|
|
8
|
+
/**
|
|
9
|
+
* 判断目标参数类型
|
|
10
|
+
*/
|
|
11
|
+
export function identifyTargetType(target) {
|
|
12
|
+
if (!target) {
|
|
13
|
+
return 'auto';
|
|
14
|
+
}
|
|
15
|
+
// 纯数字视为 ID
|
|
16
|
+
if (/^\d+$/.test(target)) {
|
|
17
|
+
return 'id';
|
|
18
|
+
}
|
|
19
|
+
// 非纯数字视为分支名
|
|
20
|
+
return 'branch';
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* 自动识别当前 worktree
|
|
24
|
+
*/
|
|
25
|
+
export async function autoDetectWorktree() {
|
|
26
|
+
return getCurrentWorktreeId();
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* 根据目标参数查找 worktree
|
|
30
|
+
*/
|
|
31
|
+
export async function findWorktreeTarget(target, mainDir, worktreesDir) {
|
|
32
|
+
const worktrees = await discoverWorktrees(mainDir, worktreesDir);
|
|
33
|
+
const targetType = identifyTargetType(target);
|
|
34
|
+
let worktree;
|
|
35
|
+
if (targetType === 'auto') {
|
|
36
|
+
// 自动识别当前 worktree
|
|
37
|
+
const worktreeId = await autoDetectWorktree();
|
|
38
|
+
if (worktreeId === null) {
|
|
39
|
+
throw new ColynError(t('commands.update.cannotAutoDetect'), t('commands.update.cannotAutoDetectHint'));
|
|
40
|
+
}
|
|
41
|
+
worktree = worktrees.find(w => w.id === worktreeId);
|
|
42
|
+
if (!worktree) {
|
|
43
|
+
throw new ColynError(t('commands.update.worktreeNotFound', { id: worktreeId }), t('commands.update.worktreeNotFoundHint'));
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else if (targetType === 'id') {
|
|
47
|
+
// 按 ID 查找
|
|
48
|
+
const id = parseInt(target);
|
|
49
|
+
worktree = worktrees.find(w => w.id === id);
|
|
50
|
+
if (!worktree) {
|
|
51
|
+
throw new ColynError(t('commands.update.worktreeNotFound', { id }), t('commands.update.branchNotFoundHint'));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
// 按分支名查找
|
|
56
|
+
worktree = worktrees.find(w => w.branch === target);
|
|
57
|
+
if (!worktree) {
|
|
58
|
+
throw new ColynError(t('commands.update.branchNotFound', { branch: target ?? '' }), t('commands.update.branchNotFoundHint'));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return worktree;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* 检查 git 工作目录状态是否干净
|
|
65
|
+
*/
|
|
66
|
+
export async function checkGitWorkingDirectory(dirPath, dirName) {
|
|
67
|
+
const git = simpleGit(dirPath);
|
|
68
|
+
const status = await git.status();
|
|
69
|
+
const changedFiles = getRelevantStatusFiles(status);
|
|
70
|
+
if (changedFiles.length > 0) {
|
|
71
|
+
const filesStr = changedFiles.slice(0, 5).map(f => ` - ${f}`).join('\n') +
|
|
72
|
+
(changedFiles.length > 5 ? `\n ... ${t('commands.remove.moreFiles', { count: changedFiles.length - 5 })}` : '');
|
|
73
|
+
throw new ColynError(t('commands.update.dirHasUncommitted', { name: dirName }), t('commands.update.dirHasUncommittedHint', {
|
|
74
|
+
name: dirName,
|
|
75
|
+
path: dirPath,
|
|
76
|
+
count: changedFiles.length,
|
|
77
|
+
files: filesStr
|
|
78
|
+
}));
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* 拉取主分支最新代码
|
|
83
|
+
*/
|
|
84
|
+
export async function pullMainBranch(mainDir, skipPull = false) {
|
|
85
|
+
// 如果指定跳过 pull,直接返回
|
|
86
|
+
if (skipPull) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const git = simpleGit(mainDir);
|
|
90
|
+
try {
|
|
91
|
+
// 检查当前分支是否有上游分支
|
|
92
|
+
try {
|
|
93
|
+
await git.raw(['rev-parse', '--abbrev-ref', '@{upstream}']);
|
|
94
|
+
// 如果命令成功,说明有上游分支,执行 pull
|
|
95
|
+
await git.pull();
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
// 没有上游分支,跳过 pull
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
catch (error) {
|
|
103
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
104
|
+
throw new ColynError(t('commands.update.pullFailed'), t('commands.update.pullFailedHint', { error: errorMessage }));
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* 使用 rebase 更新 worktree
|
|
109
|
+
*/
|
|
110
|
+
export async function rebaseWorktree(worktreePath, mainBranch) {
|
|
111
|
+
const git = simpleGit(worktreePath);
|
|
112
|
+
try {
|
|
113
|
+
await git.rebase([mainBranch]);
|
|
114
|
+
return { success: true };
|
|
115
|
+
}
|
|
116
|
+
catch (error) {
|
|
117
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
118
|
+
// 检查是否是冲突
|
|
119
|
+
if (errorMessage.includes('CONFLICT') || errorMessage.includes('could not apply')) {
|
|
120
|
+
// 获取冲突文件列表
|
|
121
|
+
const status = await git.status();
|
|
122
|
+
const conflictFiles = status.conflicted;
|
|
123
|
+
return {
|
|
124
|
+
success: false,
|
|
125
|
+
conflictFiles,
|
|
126
|
+
error: 'rebase_conflict'
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
return {
|
|
130
|
+
success: false,
|
|
131
|
+
error: errorMessage
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* 使用 merge 更新 worktree
|
|
137
|
+
*/
|
|
138
|
+
export async function mergeMainIntoWorktree(worktreePath, mainBranch) {
|
|
139
|
+
const git = simpleGit(worktreePath);
|
|
140
|
+
try {
|
|
141
|
+
await git.merge([mainBranch]);
|
|
142
|
+
return { success: true };
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
146
|
+
// 检查是否是冲突
|
|
147
|
+
if (errorMessage.includes('CONFLICT') || errorMessage.includes('Automatic merge failed')) {
|
|
148
|
+
// 获取冲突文件列表
|
|
149
|
+
const status = await git.status();
|
|
150
|
+
const conflictFiles = status.conflicted;
|
|
151
|
+
return {
|
|
152
|
+
success: false,
|
|
153
|
+
conflictFiles,
|
|
154
|
+
error: 'merge_conflict'
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
return {
|
|
158
|
+
success: false,
|
|
159
|
+
error: errorMessage
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* 更新单个 worktree
|
|
165
|
+
*/
|
|
166
|
+
export async function updateSingleWorktree(worktree, mainBranch, useRebase) {
|
|
167
|
+
if (useRebase) {
|
|
168
|
+
return rebaseWorktree(worktree.path, mainBranch);
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
return mergeMainIntoWorktree(worktree.path, mainBranch);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* 批量更新所有 worktree
|
|
176
|
+
*/
|
|
177
|
+
export async function updateAllWorktrees(worktrees, mainBranch, useRebase) {
|
|
178
|
+
const results = [];
|
|
179
|
+
let succeeded = 0;
|
|
180
|
+
let failed = 0;
|
|
181
|
+
let skipped = 0;
|
|
182
|
+
for (const worktree of worktrees) {
|
|
183
|
+
// 检查工作目录是否干净
|
|
184
|
+
try {
|
|
185
|
+
await checkGitWorkingDirectory(worktree.path, `task-${worktree.id}`);
|
|
186
|
+
}
|
|
187
|
+
catch {
|
|
188
|
+
// 工作目录不干净,跳过
|
|
189
|
+
results.push({
|
|
190
|
+
worktree,
|
|
191
|
+
success: false,
|
|
192
|
+
skipped: true,
|
|
193
|
+
error: t('commands.update.dirtySkipped')
|
|
194
|
+
});
|
|
195
|
+
skipped++;
|
|
196
|
+
continue;
|
|
197
|
+
}
|
|
198
|
+
// 执行更新
|
|
199
|
+
const result = await updateSingleWorktree(worktree, mainBranch, useRebase);
|
|
200
|
+
if (result.success) {
|
|
201
|
+
results.push({ worktree, success: true });
|
|
202
|
+
succeeded++;
|
|
203
|
+
}
|
|
204
|
+
else {
|
|
205
|
+
results.push({
|
|
206
|
+
worktree,
|
|
207
|
+
success: false,
|
|
208
|
+
error: result.error === 'rebase_conflict' || result.error === 'merge_conflict'
|
|
209
|
+
? t('commands.update.hasConflict')
|
|
210
|
+
: result.error
|
|
211
|
+
});
|
|
212
|
+
failed++;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return {
|
|
216
|
+
total: worktrees.length,
|
|
217
|
+
succeeded,
|
|
218
|
+
failed,
|
|
219
|
+
skipped,
|
|
220
|
+
results
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* 显示检测到的 worktree 信息
|
|
225
|
+
*/
|
|
226
|
+
export function displayWorktreeInfo(worktree) {
|
|
227
|
+
outputLine();
|
|
228
|
+
outputBold(t('commands.update.detectedWorktree'));
|
|
229
|
+
output(` ID: ${worktree.id}`);
|
|
230
|
+
output(` ${t('commands.update.branchLabel')}: ${worktree.branch}`);
|
|
231
|
+
output(` ${t('commands.update.pathLabel')}: ${worktree.path}`);
|
|
232
|
+
outputLine();
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* 显示更新成功信息
|
|
236
|
+
*/
|
|
237
|
+
export function displayUpdateSuccess(mainBranch, worktreeBranch, useRebase) {
|
|
238
|
+
outputLine();
|
|
239
|
+
outputSuccess(t('commands.update.updateComplete'));
|
|
240
|
+
output(` ${t('commands.update.mainBranchLabel', { branch: mainBranch })} → ${worktreeBranch}`);
|
|
241
|
+
output(` ${t('commands.update.strategyLabel')}: ${useRebase ? 'rebase' : 'merge'}`);
|
|
242
|
+
outputLine();
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* 显示 rebase 冲突信息
|
|
246
|
+
*/
|
|
247
|
+
export function displayRebaseConflict(conflictFiles, _worktreePath) {
|
|
248
|
+
outputLine();
|
|
249
|
+
outputError(t('commands.update.rebaseConflictTitle'));
|
|
250
|
+
outputLine();
|
|
251
|
+
outputBold(t('commands.update.conflictFiles'));
|
|
252
|
+
for (const file of conflictFiles) {
|
|
253
|
+
output(` ${file}`);
|
|
254
|
+
}
|
|
255
|
+
outputLine();
|
|
256
|
+
outputBold(t('commands.update.resolveSteps'));
|
|
257
|
+
outputStep(` ${t('commands.update.rebaseStep1')}`);
|
|
258
|
+
outputLine();
|
|
259
|
+
outputStep(` ${t('commands.update.rebaseStep2')}`);
|
|
260
|
+
output(' git add <file>');
|
|
261
|
+
outputLine();
|
|
262
|
+
outputStep(` ${t('commands.update.rebaseStep3')}`);
|
|
263
|
+
output(' git rebase --continue');
|
|
264
|
+
outputLine();
|
|
265
|
+
outputStep(` ${t('commands.update.rebaseStep4')}`);
|
|
266
|
+
output(' git rebase --abort');
|
|
267
|
+
outputLine();
|
|
268
|
+
}
|
|
269
|
+
/**
|
|
270
|
+
* 显示 merge 冲突信息
|
|
271
|
+
*/
|
|
272
|
+
export function displayMergeConflict(conflictFiles, _worktreePath) {
|
|
273
|
+
outputLine();
|
|
274
|
+
outputError(t('commands.update.mergeConflictTitle'));
|
|
275
|
+
outputLine();
|
|
276
|
+
outputBold(t('commands.update.conflictFiles'));
|
|
277
|
+
for (const file of conflictFiles) {
|
|
278
|
+
output(` ${file}`);
|
|
279
|
+
}
|
|
280
|
+
outputLine();
|
|
281
|
+
outputBold(t('commands.update.resolveSteps'));
|
|
282
|
+
outputStep(` ${t('commands.update.mergeStep1')}`);
|
|
283
|
+
outputLine();
|
|
284
|
+
outputStep(` ${t('commands.update.mergeStep2')}`);
|
|
285
|
+
output(' git add <file>');
|
|
286
|
+
outputLine();
|
|
287
|
+
outputStep(` ${t('commands.update.mergeStep3')}`);
|
|
288
|
+
output(' git commit');
|
|
289
|
+
outputLine();
|
|
290
|
+
outputStep(` ${t('commands.update.mergeStep4')}`);
|
|
291
|
+
output(' git merge --abort');
|
|
292
|
+
outputLine();
|
|
293
|
+
}
|
|
294
|
+
/**
|
|
295
|
+
* 显示批量更新结果
|
|
296
|
+
*/
|
|
297
|
+
export function displayBatchUpdateResult(result) {
|
|
298
|
+
outputLine();
|
|
299
|
+
outputBold(t('commands.update.batchResult'));
|
|
300
|
+
if (result.succeeded > 0) {
|
|
301
|
+
outputSuccess(` ${t('commands.update.batchSucceeded', { count: result.succeeded })}`);
|
|
302
|
+
}
|
|
303
|
+
if (result.failed > 0) {
|
|
304
|
+
outputError(` ${t('commands.update.batchFailed', { count: result.failed })}`);
|
|
305
|
+
}
|
|
306
|
+
if (result.skipped > 0) {
|
|
307
|
+
outputWarning(` ${t('commands.update.batchSkipped', { count: result.skipped })}`);
|
|
308
|
+
}
|
|
309
|
+
outputLine();
|
|
310
|
+
// 显示失败和跳过的详情
|
|
311
|
+
const failedResults = result.results.filter(r => !r.success);
|
|
312
|
+
if (failedResults.length > 0) {
|
|
313
|
+
outputBold(t('commands.update.failedDetails'));
|
|
314
|
+
for (const r of failedResults) {
|
|
315
|
+
if (r.skipped) {
|
|
316
|
+
output(` ${chalk.yellow('○')} task-${r.worktree.id} (${r.worktree.branch}): ${r.error}`);
|
|
317
|
+
}
|
|
318
|
+
else {
|
|
319
|
+
output(` ${chalk.red('✗')} task-${r.worktree.id} (${r.worktree.branch}): ${r.error}`);
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
outputLine();
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
/**
|
|
326
|
+
* 显示发现的 worktree 列表
|
|
327
|
+
*/
|
|
328
|
+
export function displayWorktreeList(worktrees) {
|
|
329
|
+
outputBold(t('commands.update.foundWorktrees', { count: worktrees.length }));
|
|
330
|
+
for (const wt of worktrees) {
|
|
331
|
+
output(` ${wt.id}. task-${wt.id} (${wt.branch})`);
|
|
332
|
+
}
|
|
333
|
+
outputLine();
|
|
334
|
+
}
|
|
335
|
+
//# sourceMappingURL=update.helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.helpers.js","sourceRoot":"","sources":["../../src/commands/update.helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import ora from 'ora';
|
|
2
|
+
import { getProjectPaths, validateProjectInitialized, executeInDirectory } from '../core/paths.js';
|
|
3
|
+
import { getMainBranch, discoverWorktrees } from '../core/discovery.js';
|
|
4
|
+
import { ColynError } from '../types/index.js';
|
|
5
|
+
import { formatError, output, outputResult } from '../utils/logger.js';
|
|
6
|
+
import { checkIsGitRepo } from './add.helpers.js';
|
|
7
|
+
import { findWorktreeTarget, checkGitWorkingDirectory, pullMainBranch, updateSingleWorktree, updateAllWorktrees, displayWorktreeInfo, displayUpdateSuccess, displayRebaseConflict, displayMergeConflict, displayBatchUpdateResult, displayWorktreeList } from './update.helpers.js';
|
|
8
|
+
import { t } from '../i18n/index.js';
|
|
9
|
+
/**
|
|
10
|
+
* Update 命令:将主分支代码更新到 worktree
|
|
11
|
+
*
|
|
12
|
+
* 流程:
|
|
13
|
+
* 1. 检查 worktree 工作目录状态
|
|
14
|
+
* 2. 拉取主分支最新代码
|
|
15
|
+
* 3. 执行 rebase 或 merge
|
|
16
|
+
*/
|
|
17
|
+
async function updateCommand(target, options) {
|
|
18
|
+
try {
|
|
19
|
+
// 步骤1: 获取项目路径并验证
|
|
20
|
+
const paths = await getProjectPaths();
|
|
21
|
+
await validateProjectInitialized(paths);
|
|
22
|
+
// 步骤2: 在主分支目录中检查 git 仓库
|
|
23
|
+
await executeInDirectory(paths.mainDir, async () => {
|
|
24
|
+
await checkIsGitRepo();
|
|
25
|
+
});
|
|
26
|
+
// 获取主分支名称
|
|
27
|
+
const mainBranch = await getMainBranch(paths.mainDir);
|
|
28
|
+
// 确定是否使用 rebase(默认 true)
|
|
29
|
+
const useRebase = !options.noRebase;
|
|
30
|
+
// 确定是否跳过 fetch/pull(默认 false,即执行 fetch/pull)
|
|
31
|
+
const skipFetch = options.fetch === false;
|
|
32
|
+
// 步骤3: 处理批量更新或单个更新
|
|
33
|
+
if (options.all) {
|
|
34
|
+
// 批量更新所有 worktree
|
|
35
|
+
await handleBatchUpdate(paths.mainDir, paths.worktreesDir, mainBranch, useRebase, skipFetch);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
// 单个更新
|
|
39
|
+
await handleSingleUpdate(target, paths.mainDir, paths.worktreesDir, mainBranch, useRebase, skipFetch);
|
|
40
|
+
}
|
|
41
|
+
// 输出 JSON 结果
|
|
42
|
+
const result = { success: true };
|
|
43
|
+
outputResult(result);
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
formatError(error);
|
|
47
|
+
outputResult({ success: false });
|
|
48
|
+
process.exit(1);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* 处理单个 worktree 更新
|
|
53
|
+
*/
|
|
54
|
+
async function handleSingleUpdate(target, mainDir, worktreesDir, mainBranch, useRebase, skipPull) {
|
|
55
|
+
// 查找目标 worktree
|
|
56
|
+
const worktree = await findWorktreeTarget(target, mainDir, worktreesDir);
|
|
57
|
+
// 显示 worktree 信息
|
|
58
|
+
displayWorktreeInfo(worktree);
|
|
59
|
+
// 步骤1: 检查工作目录状态
|
|
60
|
+
const checkSpinner = ora({
|
|
61
|
+
text: t('commands.update.checkingStatus'),
|
|
62
|
+
stream: process.stderr
|
|
63
|
+
}).start();
|
|
64
|
+
try {
|
|
65
|
+
await checkGitWorkingDirectory(worktree.path, `task-${worktree.id}`);
|
|
66
|
+
checkSpinner.succeed(t('commands.update.statusClean'));
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
checkSpinner.fail(t('commands.update.statusDirty'));
|
|
70
|
+
throw error;
|
|
71
|
+
}
|
|
72
|
+
// 步骤2: 拉取主分支最新代码
|
|
73
|
+
const pullSpinner = ora({
|
|
74
|
+
text: t('commands.update.pullingMain'),
|
|
75
|
+
stream: process.stderr
|
|
76
|
+
}).start();
|
|
77
|
+
try {
|
|
78
|
+
await pullMainBranch(mainDir, skipPull);
|
|
79
|
+
pullSpinner.succeed(t('commands.update.pullSuccess'));
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
pullSpinner.fail(t('commands.update.pullFailed'));
|
|
83
|
+
throw error;
|
|
84
|
+
}
|
|
85
|
+
// 步骤3: 执行更新
|
|
86
|
+
const strategy = useRebase ? 'rebase' : 'merge';
|
|
87
|
+
const updateSpinner = ora({
|
|
88
|
+
text: t('commands.update.updating', { strategy }),
|
|
89
|
+
stream: process.stderr
|
|
90
|
+
}).start();
|
|
91
|
+
output(t('commands.update.updateDir', { path: worktree.path }));
|
|
92
|
+
output(t('commands.update.updateCmd', { cmd: useRebase ? `git rebase ${mainBranch}` : `git merge ${mainBranch}` }));
|
|
93
|
+
const result = await updateSingleWorktree(worktree, mainBranch, useRebase);
|
|
94
|
+
if (!result.success) {
|
|
95
|
+
updateSpinner.fail(t('commands.update.updateFailed'));
|
|
96
|
+
if (result.error === 'rebase_conflict') {
|
|
97
|
+
displayRebaseConflict(result.conflictFiles || [], worktree.path);
|
|
98
|
+
}
|
|
99
|
+
else if (result.error === 'merge_conflict') {
|
|
100
|
+
displayMergeConflict(result.conflictFiles || [], worktree.path);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
throw new ColynError(t('commands.update.updateFailed'), result.error || t('common.unknownError'));
|
|
104
|
+
}
|
|
105
|
+
outputResult({ success: false });
|
|
106
|
+
process.exit(1);
|
|
107
|
+
}
|
|
108
|
+
updateSpinner.succeed(t('commands.update.updateSuccess'));
|
|
109
|
+
// 显示成功信息
|
|
110
|
+
displayUpdateSuccess(mainBranch, worktree.branch, useRebase);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* 处理批量更新
|
|
114
|
+
*/
|
|
115
|
+
async function handleBatchUpdate(mainDir, worktreesDir, mainBranch, useRebase, skipPull) {
|
|
116
|
+
// 发现所有 worktree
|
|
117
|
+
const worktrees = await discoverWorktrees(mainDir, worktreesDir);
|
|
118
|
+
if (worktrees.length === 0) {
|
|
119
|
+
throw new ColynError(t('commands.update.noWorktrees'), t('commands.update.noWorktreesHint'));
|
|
120
|
+
}
|
|
121
|
+
// 显示 worktree 列表
|
|
122
|
+
displayWorktreeList(worktrees);
|
|
123
|
+
// 步骤1: 拉取主分支最新代码
|
|
124
|
+
const pullSpinner = ora({
|
|
125
|
+
text: t('commands.update.pullingMain'),
|
|
126
|
+
stream: process.stderr
|
|
127
|
+
}).start();
|
|
128
|
+
try {
|
|
129
|
+
await pullMainBranch(mainDir, skipPull);
|
|
130
|
+
pullSpinner.succeed(t('commands.update.pullSuccess'));
|
|
131
|
+
}
|
|
132
|
+
catch (error) {
|
|
133
|
+
pullSpinner.fail(t('commands.update.pullFailed'));
|
|
134
|
+
throw error;
|
|
135
|
+
}
|
|
136
|
+
// 步骤2: 执行批量更新(内部会检查每个 worktree 的状态)
|
|
137
|
+
const strategy = useRebase ? 'rebase' : 'merge';
|
|
138
|
+
output(t('commands.update.batchUpdating', { strategy }));
|
|
139
|
+
const result = await updateAllWorktrees(worktrees, mainBranch, useRebase);
|
|
140
|
+
// 显示结果
|
|
141
|
+
displayBatchUpdateResult(result);
|
|
142
|
+
// 如果有失败,退出码为 1
|
|
143
|
+
if (result.failed > 0) {
|
|
144
|
+
outputResult({ success: false });
|
|
145
|
+
process.exit(1);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* 执行 update 命令(供其他命令内部调用,不输出 JSON)
|
|
150
|
+
*/
|
|
151
|
+
export async function executeUpdate(target, options) {
|
|
152
|
+
// 步骤1: 获取项目路径并验证
|
|
153
|
+
const paths = await getProjectPaths();
|
|
154
|
+
await validateProjectInitialized(paths);
|
|
155
|
+
// 步骤2: 在主分支目录中检查 git 仓库
|
|
156
|
+
await executeInDirectory(paths.mainDir, async () => {
|
|
157
|
+
await checkIsGitRepo();
|
|
158
|
+
});
|
|
159
|
+
// 获取主分支名称
|
|
160
|
+
const mainBranch = await getMainBranch(paths.mainDir);
|
|
161
|
+
// 确定是否使用 rebase(默认 true)
|
|
162
|
+
const useRebase = !options.noRebase;
|
|
163
|
+
// 步骤3: 处理批量更新或单个更新
|
|
164
|
+
if (options.all) {
|
|
165
|
+
// 批量更新所有 worktree
|
|
166
|
+
await handleBatchUpdate(paths.mainDir, paths.worktreesDir, mainBranch, useRebase, false);
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
// 单个更新
|
|
170
|
+
await handleSingleUpdate(target, paths.mainDir, paths.worktreesDir, mainBranch, useRebase, false);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* 注册 update 命令
|
|
175
|
+
*/
|
|
176
|
+
export function register(program) {
|
|
177
|
+
program
|
|
178
|
+
.command('update [target]')
|
|
179
|
+
.description(t('commands.update.description'))
|
|
180
|
+
.option('--no-rebase', t('commands.update.noRebaseOption'))
|
|
181
|
+
.option('--all', t('commands.update.allOption'))
|
|
182
|
+
.option('--no-fetch', t('commands.update.noFetchOption'))
|
|
183
|
+
.action(async (target, options) => {
|
|
184
|
+
await updateCommand(target, options);
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
//# sourceMappingURL=update.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../src/commands/update.ts"],"names":[],"mappings":"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"}
|