feat: 优化 suggestNextStep 依赖提示,修复 finish 归档目录缺失问题,移除 es-toolkit
This commit is contained in:
38
src/cli.ts
38
src/cli.ts
@@ -76,11 +76,26 @@ export function formatChangeStatus(change: ChangeStatus, config?: RuneConfig): s
|
||||
|
||||
export function suggestNextStep(change: ChangeStatus, config?: RuneConfig): string {
|
||||
const prefix = getPmPrefix(config);
|
||||
const planDocs = config?.stages.plan?.documents;
|
||||
if (!change.planCompleted) {
|
||||
const nextDoc = change.documents.find((d) => !d.completed && d.dependMet);
|
||||
if (nextDoc) {
|
||||
return `${prefix} plan ${change.name} ${nextDoc.name}`;
|
||||
}
|
||||
const firstMissingDep = change.documents
|
||||
.filter((d) => !d.completed && !d.dependMet)
|
||||
.map((d) => {
|
||||
const docConfig = planDocs?.find((c) => c.name === d.name);
|
||||
const missing =
|
||||
docConfig?.depend?.filter(
|
||||
(dep) => !change.documents.find((cd) => cd.name === dep)?.completed,
|
||||
) ?? [];
|
||||
return { name: d.name, missing };
|
||||
})
|
||||
.find((d) => d.missing.length > 0);
|
||||
if (firstMissingDep) {
|
||||
return `${prefix} plan ${change.name} ${firstMissingDep.missing[0]}(${firstMissingDep.name} 的前置依赖)`;
|
||||
}
|
||||
return `完成前置依赖后再规划文档`;
|
||||
}
|
||||
|
||||
@@ -261,14 +276,13 @@ cli
|
||||
cli.command("task <change-name>", "任务拆解阶段").action(async (changeName: string) => {
|
||||
validateChangeName(changeName);
|
||||
const root = requireProjectRoot();
|
||||
const config = await loadConfig(root);
|
||||
const changeDir = getChangeDir(root, changeName);
|
||||
if (!existsSync(changeDir)) {
|
||||
const prefix = getPmPrefix();
|
||||
throw new CommandError(`变更"${changeName}"不存在`, {
|
||||
hint: `请先运行 ${prefix} create ${changeName} 创建变更`,
|
||||
hint: `请先运行 ${getPmPrefix(config)} create ${changeName} 创建变更`,
|
||||
});
|
||||
}
|
||||
const config = await loadConfig(root);
|
||||
const prompt = await assembleTaskPrompt(config, root, changeName);
|
||||
console.log(prompt);
|
||||
});
|
||||
@@ -276,14 +290,13 @@ cli.command("task <change-name>", "任务拆解阶段").action(async (changeName
|
||||
cli.command("build <change-name>", "构建阶段").action(async (changeName: string) => {
|
||||
validateChangeName(changeName);
|
||||
const root = requireProjectRoot();
|
||||
const config = await loadConfig(root);
|
||||
const changeDir = getChangeDir(root, changeName);
|
||||
if (!existsSync(changeDir)) {
|
||||
const prefix = getPmPrefix();
|
||||
throw new CommandError(`变更"${changeName}"不存在`, {
|
||||
hint: `请先运行 ${prefix} create ${changeName} 创建变更`,
|
||||
hint: `请先运行 ${getPmPrefix(config)} create ${changeName} 创建变更`,
|
||||
});
|
||||
}
|
||||
const config = await loadConfig(root);
|
||||
const prompt = await assembleBuildPrompt(config, root, changeName);
|
||||
console.log(prompt);
|
||||
});
|
||||
@@ -291,14 +304,13 @@ cli.command("build <change-name>", "构建阶段").action(async (changeName: str
|
||||
cli.command("archive <change-name>", "归档阶段").action(async (changeName: string) => {
|
||||
validateChangeName(changeName);
|
||||
const root = requireProjectRoot();
|
||||
const config = await loadConfig(root);
|
||||
const changeDir = getChangeDir(root, changeName);
|
||||
if (!existsSync(changeDir)) {
|
||||
const prefix = getPmPrefix();
|
||||
throw new CommandError(`变更"${changeName}"不存在`, {
|
||||
hint: `请先运行 ${prefix} create ${changeName} 创建变更`,
|
||||
hint: `请先运行 ${getPmPrefix(config)} create ${changeName} 创建变更`,
|
||||
});
|
||||
}
|
||||
const config = await loadConfig(root);
|
||||
const prompt = await assembleArchivePrompt(config, root, changeName);
|
||||
console.log(prompt);
|
||||
});
|
||||
@@ -306,15 +318,17 @@ cli.command("archive <change-name>", "归档阶段").action(async (changeName: s
|
||||
cli.command("finish <change-name>", "归档变更").action(async (changeName: string) => {
|
||||
validateChangeName(changeName);
|
||||
const root = requireProjectRoot();
|
||||
const config = await loadConfig(root);
|
||||
const changeDir = getChangeDir(root, changeName);
|
||||
if (!existsSync(changeDir)) {
|
||||
const prefix = getPmPrefix();
|
||||
throw new CommandError(`变更"${changeName}"不存在`, {
|
||||
hint: `请先运行 ${prefix} create ${changeName} 创建变更`,
|
||||
hint: `请先运行 ${getPmPrefix(config)} create ${changeName} 创建变更`,
|
||||
});
|
||||
}
|
||||
const today = new Date().toISOString().slice(0, 10);
|
||||
const dest = join(getArchiveDir(root), `${today}-${changeName}`);
|
||||
const archiveDir = getArchiveDir(root);
|
||||
await mkdir(archiveDir, { recursive: true });
|
||||
const dest = join(archiveDir, `${today}-${changeName}`);
|
||||
if (existsSync(dest)) {
|
||||
throw new CommandError(`归档目标 "${today}-${changeName}" 已存在`, {
|
||||
hint: `同一天同一变更名只能归档一次。如需重新归档,请先删除 .rune/archive/${today}-${changeName} 目录`,
|
||||
|
||||
Reference in New Issue
Block a user