spec-agent 1.0.3 → 2.0.0
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.md +42 -2
- package/USAGE_FROM_NPM.md +280 -0
- package/dist/commands/analyze.d.ts.map +1 -1
- package/dist/commands/analyze.js +14 -1
- package/dist/commands/analyze.js.map +1 -1
- package/dist/commands/execute.d.ts +15 -0
- package/dist/commands/execute.d.ts.map +1 -0
- package/dist/commands/execute.js +298 -0
- package/dist/commands/execute.js.map +1 -0
- package/dist/commands/handoff.d.ts +11 -0
- package/dist/commands/handoff.d.ts.map +1 -0
- package/dist/commands/handoff.js +320 -0
- package/dist/commands/handoff.js.map +1 -0
- package/dist/commands/learn.d.ts +7 -0
- package/dist/commands/learn.d.ts.map +1 -1
- package/dist/commands/learn.js +31 -4
- package/dist/commands/learn.js.map +1 -1
- package/dist/commands/pipeline.d.ts +1 -0
- package/dist/commands/pipeline.d.ts.map +1 -1
- package/dist/commands/pipeline.js +5 -0
- package/dist/commands/pipeline.js.map +1 -1
- package/dist/commands/scan.js +17 -15
- package/dist/commands/scan.js.map +1 -1
- package/dist/index.js +73 -2
- package/dist/index.js.map +1 -1
- package/dist/services/llm.d.ts +2 -2
- package/dist/services/llm.d.ts.map +1 -1
- package/dist/services/llm.js +8 -2
- package/dist/services/llm.js.map +1 -1
- package/package.json +4 -3
- package/spec-agent-implementation.md +46 -1
- package/src/commands/analyze.ts +14 -1
- package/src/commands/execute.ts +358 -0
- package/src/commands/handoff.ts +351 -0
- package/src/commands/learn.ts +41 -6
- package/src/commands/pipeline.ts +8 -0
- package/src/commands/scan.ts +18 -18
- package/src/index.ts +41 -2
- package/src/services/llm.ts +10 -2
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.executeCommand = executeCommand;
|
|
37
|
+
const path = __importStar(require("path"));
|
|
38
|
+
const fs = __importStar(require("fs-extra"));
|
|
39
|
+
const logger_1 = require("../utils/logger");
|
|
40
|
+
const file_1 = require("../utils/file");
|
|
41
|
+
async function executeCommand(options, command) {
|
|
42
|
+
const logger = new logger_1.Logger();
|
|
43
|
+
try {
|
|
44
|
+
const workspacePath = path.resolve(options.workspace);
|
|
45
|
+
const bundlePath = options.bundle
|
|
46
|
+
? path.resolve(options.bundle)
|
|
47
|
+
: path.join(workspacePath, 'handoff', 'handoff_bundle.json');
|
|
48
|
+
const executionDir = path.join(workspacePath, 'execution');
|
|
49
|
+
const statePath = path.join(executionDir, 'run_state.json');
|
|
50
|
+
const reportPath = path.join(executionDir, 'execution_report.json');
|
|
51
|
+
const inboxDir = path.join(executionDir, 'inbox');
|
|
52
|
+
const handoffTasksDir = path.join(workspacePath, 'handoff', 'tasks');
|
|
53
|
+
const maxParallel = Math.max(1, parseInt(options.maxParallel || '4', 10) || 4);
|
|
54
|
+
const maxRetries = Math.max(0, parseInt(options.retry || '1', 10) || 1);
|
|
55
|
+
if (!(await (0, file_1.fileExists)(bundlePath))) {
|
|
56
|
+
logger.error(`handoff bundle not found: ${bundlePath}`);
|
|
57
|
+
logger.info('Run spec-agent handoff first.');
|
|
58
|
+
process.exit(1);
|
|
59
|
+
}
|
|
60
|
+
const bundle = await (0, file_1.readJson)(bundlePath);
|
|
61
|
+
await (0, file_1.ensureDir)(executionDir);
|
|
62
|
+
await (0, file_1.ensureDir)(inboxDir);
|
|
63
|
+
if (options.reset && await (0, file_1.fileExists)(statePath)) {
|
|
64
|
+
await fs.remove(statePath);
|
|
65
|
+
logger.warn('Existing run_state.json removed due to --reset');
|
|
66
|
+
}
|
|
67
|
+
const state = await loadOrInitState(statePath, bundlePath, workspacePath, maxParallel, maxRetries, bundle, logger);
|
|
68
|
+
applyManualTransitions(state, options, logger);
|
|
69
|
+
applyBlockedStatus(state);
|
|
70
|
+
const scheduled = scheduleRunningTasks(state, maxParallel);
|
|
71
|
+
for (const taskId of scheduled) {
|
|
72
|
+
await createInboxFile(taskId, handoffTasksDir, inboxDir);
|
|
73
|
+
state.history.push({
|
|
74
|
+
at: new Date().toISOString(),
|
|
75
|
+
action: 'scheduled',
|
|
76
|
+
taskId,
|
|
77
|
+
detail: 'Moved to running and generated inbox task file',
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
state.maxParallel = maxParallel;
|
|
81
|
+
state.updatedAt = new Date().toISOString();
|
|
82
|
+
if (!options.dryRun) {
|
|
83
|
+
await (0, file_1.writeJson)(statePath, state);
|
|
84
|
+
await (0, file_1.writeJson)(reportPath, buildExecutionReport(state));
|
|
85
|
+
}
|
|
86
|
+
const summary = summarizeState(state);
|
|
87
|
+
logger.info(`Execution workspace: ${workspacePath}`);
|
|
88
|
+
logger.info(`Bundle: ${bundlePath}`);
|
|
89
|
+
logger.info(`State: ${statePath}`);
|
|
90
|
+
logger.info(`Report: ${reportPath}`);
|
|
91
|
+
logger.info(`Status => pending:${summary.pending} running:${summary.running} succeeded:${summary.succeeded} failed:${summary.failed} blocked:${summary.blocked}`);
|
|
92
|
+
if (scheduled.length > 0) {
|
|
93
|
+
logger.success(`Scheduled ${scheduled.length} tasks: ${scheduled.join(', ')}`);
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
logger.info('No new tasks scheduled in this round.');
|
|
97
|
+
}
|
|
98
|
+
if (options.dryRun) {
|
|
99
|
+
logger.warn('Dry run mode - state/report files were not written.');
|
|
100
|
+
}
|
|
101
|
+
logger.json({
|
|
102
|
+
status: 'success',
|
|
103
|
+
scheduled,
|
|
104
|
+
summary,
|
|
105
|
+
statePath,
|
|
106
|
+
reportPath,
|
|
107
|
+
inboxDir,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
const logger = new logger_1.Logger();
|
|
112
|
+
logger.error(`Execute failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
113
|
+
process.exit(1);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
async function loadOrInitState(statePath, bundlePath, workspacePath, maxParallel, maxRetries, bundle, logger) {
|
|
117
|
+
if (await (0, file_1.fileExists)(statePath)) {
|
|
118
|
+
const state = await (0, file_1.readJson)(statePath);
|
|
119
|
+
reconcileStateWithBundle(state, bundle, maxRetries, logger);
|
|
120
|
+
return state;
|
|
121
|
+
}
|
|
122
|
+
const now = new Date().toISOString();
|
|
123
|
+
const tasks = {};
|
|
124
|
+
for (const task of bundle.tasks || []) {
|
|
125
|
+
tasks[task.id] = {
|
|
126
|
+
taskId: task.id,
|
|
127
|
+
name: task.name,
|
|
128
|
+
assignedAgent: task.assignedAgent || 'UNKNOWN',
|
|
129
|
+
dependencies: task.dependencies || [],
|
|
130
|
+
status: 'pending',
|
|
131
|
+
attempts: 0,
|
|
132
|
+
maxAttempts: maxRetries + 1,
|
|
133
|
+
updatedAt: now,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
return {
|
|
137
|
+
version: '2.0.0-beta',
|
|
138
|
+
createdAt: now,
|
|
139
|
+
updatedAt: now,
|
|
140
|
+
workspace: workspacePath,
|
|
141
|
+
bundlePath,
|
|
142
|
+
maxParallel,
|
|
143
|
+
tasks,
|
|
144
|
+
history: [{ at: now, action: 'init', detail: `Initialized from ${bundlePath}` }],
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
function reconcileStateWithBundle(state, bundle, maxRetries, logger) {
|
|
148
|
+
const now = new Date().toISOString();
|
|
149
|
+
const existingIds = new Set(Object.keys(state.tasks));
|
|
150
|
+
let added = 0;
|
|
151
|
+
for (const task of bundle.tasks || []) {
|
|
152
|
+
if (existingIds.has(task.id)) {
|
|
153
|
+
continue;
|
|
154
|
+
}
|
|
155
|
+
state.tasks[task.id] = {
|
|
156
|
+
taskId: task.id,
|
|
157
|
+
name: task.name,
|
|
158
|
+
assignedAgent: task.assignedAgent || 'UNKNOWN',
|
|
159
|
+
dependencies: task.dependencies || [],
|
|
160
|
+
status: 'pending',
|
|
161
|
+
attempts: 0,
|
|
162
|
+
maxAttempts: maxRetries + 1,
|
|
163
|
+
updatedAt: now,
|
|
164
|
+
};
|
|
165
|
+
added++;
|
|
166
|
+
}
|
|
167
|
+
if (added > 0) {
|
|
168
|
+
logger.warn(`Detected ${added} new tasks from bundle, appended to run state`);
|
|
169
|
+
state.history.push({ at: now, action: 'reconcile', detail: `Added ${added} new tasks from bundle` });
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
function parseTaskIds(raw) {
|
|
173
|
+
if (!raw)
|
|
174
|
+
return [];
|
|
175
|
+
return raw
|
|
176
|
+
.split(',')
|
|
177
|
+
.map(item => item.trim())
|
|
178
|
+
.filter(Boolean);
|
|
179
|
+
}
|
|
180
|
+
function applyManualTransitions(state, options, logger) {
|
|
181
|
+
const now = new Date().toISOString();
|
|
182
|
+
const completeIds = parseTaskIds(options.complete);
|
|
183
|
+
const failIds = parseTaskIds(options.fail);
|
|
184
|
+
for (const taskId of completeIds) {
|
|
185
|
+
const task = state.tasks[taskId];
|
|
186
|
+
if (!task) {
|
|
187
|
+
logger.warn(`Complete ignored (task not found): ${taskId}`);
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
task.status = 'succeeded';
|
|
191
|
+
task.lastError = undefined;
|
|
192
|
+
task.updatedAt = now;
|
|
193
|
+
state.history.push({ at: now, action: 'complete', taskId });
|
|
194
|
+
}
|
|
195
|
+
for (const taskId of failIds) {
|
|
196
|
+
const task = state.tasks[taskId];
|
|
197
|
+
if (!task) {
|
|
198
|
+
logger.warn(`Fail ignored (task not found): ${taskId}`);
|
|
199
|
+
continue;
|
|
200
|
+
}
|
|
201
|
+
task.attempts += 1;
|
|
202
|
+
task.updatedAt = now;
|
|
203
|
+
task.lastError = options.error || 'manual failure';
|
|
204
|
+
if (task.attempts < task.maxAttempts) {
|
|
205
|
+
task.status = 'pending';
|
|
206
|
+
state.history.push({
|
|
207
|
+
at: now,
|
|
208
|
+
action: 'retry',
|
|
209
|
+
taskId,
|
|
210
|
+
detail: `attempt ${task.attempts}/${task.maxAttempts - 1}`,
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
task.status = 'failed';
|
|
215
|
+
state.history.push({
|
|
216
|
+
at: now,
|
|
217
|
+
action: 'failed',
|
|
218
|
+
taskId,
|
|
219
|
+
detail: `attempt ${task.attempts}/${task.maxAttempts - 1}`,
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
function applyBlockedStatus(state) {
|
|
225
|
+
const now = new Date().toISOString();
|
|
226
|
+
for (const task of Object.values(state.tasks)) {
|
|
227
|
+
if (task.status !== 'pending')
|
|
228
|
+
continue;
|
|
229
|
+
const hasHardFailedDependency = task.dependencies.some(depId => state.tasks[depId]?.status === 'failed');
|
|
230
|
+
if (hasHardFailedDependency) {
|
|
231
|
+
task.status = 'blocked';
|
|
232
|
+
task.updatedAt = now;
|
|
233
|
+
task.lastError = 'blocked by failed dependency';
|
|
234
|
+
state.history.push({ at: now, action: 'blocked', taskId: task.taskId, detail: task.lastError });
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
function scheduleRunningTasks(state, maxParallel) {
|
|
239
|
+
const now = new Date().toISOString();
|
|
240
|
+
const currentRunning = Object.values(state.tasks).filter(task => task.status === 'running').length;
|
|
241
|
+
const availableSlots = Math.max(0, maxParallel - currentRunning);
|
|
242
|
+
if (availableSlots <= 0)
|
|
243
|
+
return [];
|
|
244
|
+
const ready = Object.values(state.tasks).filter(task => {
|
|
245
|
+
if (task.status !== 'pending')
|
|
246
|
+
return false;
|
|
247
|
+
if (task.dependencies.length === 0)
|
|
248
|
+
return true;
|
|
249
|
+
return task.dependencies.every(depId => state.tasks[depId]?.status === 'succeeded');
|
|
250
|
+
});
|
|
251
|
+
ready.sort((a, b) => a.taskId.localeCompare(b.taskId));
|
|
252
|
+
const picked = ready.slice(0, availableSlots);
|
|
253
|
+
for (const task of picked) {
|
|
254
|
+
task.status = 'running';
|
|
255
|
+
task.updatedAt = now;
|
|
256
|
+
}
|
|
257
|
+
return picked.map(task => task.taskId);
|
|
258
|
+
}
|
|
259
|
+
async function createInboxFile(taskId, handoffTasksDir, inboxDir) {
|
|
260
|
+
const source = path.join(handoffTasksDir, `${taskId}.md`);
|
|
261
|
+
const target = path.join(inboxDir, `${taskId}.md`);
|
|
262
|
+
if (await (0, file_1.fileExists)(source)) {
|
|
263
|
+
await fs.copyFile(source, target);
|
|
264
|
+
return;
|
|
265
|
+
}
|
|
266
|
+
await fs.writeFile(target, `# ${taskId}\n\nTask prompt file not found in handoff/tasks.\n`, 'utf-8');
|
|
267
|
+
}
|
|
268
|
+
function summarizeState(state) {
|
|
269
|
+
const summary = {
|
|
270
|
+
pending: 0,
|
|
271
|
+
running: 0,
|
|
272
|
+
succeeded: 0,
|
|
273
|
+
failed: 0,
|
|
274
|
+
blocked: 0,
|
|
275
|
+
};
|
|
276
|
+
for (const task of Object.values(state.tasks)) {
|
|
277
|
+
summary[task.status] += 1;
|
|
278
|
+
}
|
|
279
|
+
return summary;
|
|
280
|
+
}
|
|
281
|
+
function buildExecutionReport(state) {
|
|
282
|
+
const summary = summarizeState(state);
|
|
283
|
+
const done = summary.succeeded + summary.failed + summary.blocked;
|
|
284
|
+
const total = Object.keys(state.tasks).length;
|
|
285
|
+
const completionRate = total === 0 ? 0 : Number(((done / total) * 100).toFixed(2));
|
|
286
|
+
return {
|
|
287
|
+
version: '2.0.0-beta',
|
|
288
|
+
generatedAt: new Date().toISOString(),
|
|
289
|
+
workspace: state.workspace,
|
|
290
|
+
bundlePath: state.bundlePath,
|
|
291
|
+
maxParallel: state.maxParallel,
|
|
292
|
+
totalTasks: total,
|
|
293
|
+
summary,
|
|
294
|
+
completionRate,
|
|
295
|
+
lastEvents: state.history.slice(-30),
|
|
296
|
+
};
|
|
297
|
+
}
|
|
298
|
+
//# sourceMappingURL=execute.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute.js","sourceRoot":"","sources":["../../src/commands/execute.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
interface HandoffOptions {
|
|
3
|
+
workspace: string;
|
|
4
|
+
output: string;
|
|
5
|
+
target: string;
|
|
6
|
+
includeSummaries?: boolean;
|
|
7
|
+
dryRun?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function handoffCommand(options: HandoffOptions, command: Command): Promise<void>;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=handoff.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handoff.d.ts","sourceRoot":"","sources":["../../src/commands/handoff.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKpC,UAAU,cAAc;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAcD,wBAAsB,cAAc,CAAC,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAmJ7F"}
|
|
@@ -0,0 +1,320 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.handoffCommand = handoffCommand;
|
|
37
|
+
const path = __importStar(require("path"));
|
|
38
|
+
const fs = __importStar(require("fs-extra"));
|
|
39
|
+
const logger_1 = require("../utils/logger");
|
|
40
|
+
const file_1 = require("../utils/file");
|
|
41
|
+
async function handoffCommand(options, command) {
|
|
42
|
+
const logger = new logger_1.Logger();
|
|
43
|
+
try {
|
|
44
|
+
const workspacePath = path.resolve(options.workspace);
|
|
45
|
+
const dispatchPath = path.join(workspacePath, 'dispatch_plan.json');
|
|
46
|
+
const taskPlanPath = path.join(workspacePath, 'task_plan.json');
|
|
47
|
+
const specPath = path.join(workspacePath, 'spec_summary.json');
|
|
48
|
+
if (!(await (0, file_1.fileExists)(dispatchPath))) {
|
|
49
|
+
logger.error(`dispatch_plan.json not found in workspace: ${workspacePath}`);
|
|
50
|
+
logger.info('Run spec-agent dispatch first.');
|
|
51
|
+
process.exit(1);
|
|
52
|
+
}
|
|
53
|
+
if (!(await (0, file_1.fileExists)(taskPlanPath))) {
|
|
54
|
+
logger.error(`task_plan.json not found in workspace: ${workspacePath}`);
|
|
55
|
+
logger.info('Run spec-agent plan first.');
|
|
56
|
+
process.exit(1);
|
|
57
|
+
}
|
|
58
|
+
const outputPath = path.isAbsolute(options.output)
|
|
59
|
+
? options.output
|
|
60
|
+
: path.join(workspacePath, options.output || 'handoff');
|
|
61
|
+
const dispatch = await (0, file_1.readJson)(dispatchPath);
|
|
62
|
+
const taskPlan = await (0, file_1.readJson)(taskPlanPath);
|
|
63
|
+
const spec = (await (0, file_1.fileExists)(specPath)) ? await (0, file_1.readJson)(specPath) : null;
|
|
64
|
+
const taskById = new Map();
|
|
65
|
+
for (const group of taskPlan.parallelGroups) {
|
|
66
|
+
for (const task of group.tasks) {
|
|
67
|
+
taskById.set(task.id, task);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
const sourceChunkMap = buildSourceChunkMap(spec);
|
|
71
|
+
const handoffTasks = [];
|
|
72
|
+
const agentTaskMap = new Map();
|
|
73
|
+
for (const [agentType, agents] of Object.entries(dispatch.agentPools)) {
|
|
74
|
+
for (const agent of agents) {
|
|
75
|
+
const rows = [];
|
|
76
|
+
for (const taskId of agent.assignedTasks) {
|
|
77
|
+
const task = taskById.get(taskId);
|
|
78
|
+
if (!task)
|
|
79
|
+
continue;
|
|
80
|
+
const mapped = {
|
|
81
|
+
id: task.id,
|
|
82
|
+
name: task.name,
|
|
83
|
+
type: task.type,
|
|
84
|
+
priority: task.priority,
|
|
85
|
+
dependencies: task.dependencies || [],
|
|
86
|
+
assignedAgent: agent.agentId,
|
|
87
|
+
assignedType: agentType,
|
|
88
|
+
estimatedHours: task.estimatedHours,
|
|
89
|
+
sourceChunks: guessSourceChunks(task, sourceChunkMap),
|
|
90
|
+
};
|
|
91
|
+
rows.push(mapped);
|
|
92
|
+
handoffTasks.push(mapped);
|
|
93
|
+
}
|
|
94
|
+
agentTaskMap.set(agent.agentId, rows);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
if (options.dryRun) {
|
|
98
|
+
logger.info('Dry run mode - handoff plan:');
|
|
99
|
+
logger.info(` workspace: ${workspacePath}`);
|
|
100
|
+
logger.info(` target: ${normalizeTarget(options.target)}`);
|
|
101
|
+
logger.info(` agents: ${agentTaskMap.size}`);
|
|
102
|
+
logger.info(` tasks: ${handoffTasks.length}`);
|
|
103
|
+
logger.info(` output: ${outputPath}`);
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
await (0, file_1.ensureDir)(outputPath);
|
|
107
|
+
const tasksDir = path.join(outputPath, 'tasks');
|
|
108
|
+
const agentsDir = path.join(outputPath, 'agents');
|
|
109
|
+
await (0, file_1.ensureDir)(tasksDir);
|
|
110
|
+
await (0, file_1.ensureDir)(agentsDir);
|
|
111
|
+
// Per-task handoff prompts.
|
|
112
|
+
for (const row of handoffTasks) {
|
|
113
|
+
const markdown = renderTaskPrompt({
|
|
114
|
+
row,
|
|
115
|
+
workspacePath,
|
|
116
|
+
target: normalizeTarget(options.target),
|
|
117
|
+
includeSummaries: Boolean(options.includeSummaries),
|
|
118
|
+
});
|
|
119
|
+
await fs.writeFile(path.join(tasksDir, `${row.id}.md`), markdown, 'utf-8');
|
|
120
|
+
}
|
|
121
|
+
// Per-agent task list.
|
|
122
|
+
for (const [agentId, rows] of agentTaskMap) {
|
|
123
|
+
const markdown = renderAgentPrompt({
|
|
124
|
+
agentId,
|
|
125
|
+
rows,
|
|
126
|
+
target: normalizeTarget(options.target),
|
|
127
|
+
});
|
|
128
|
+
await fs.writeFile(path.join(agentsDir, `${agentId}.md`), markdown, 'utf-8');
|
|
129
|
+
}
|
|
130
|
+
const bundlePath = path.join(outputPath, 'handoff_bundle.json');
|
|
131
|
+
await (0, file_1.writeJson)(bundlePath, {
|
|
132
|
+
version: '2.0.0-beta',
|
|
133
|
+
createdAt: new Date().toISOString(),
|
|
134
|
+
workspace: workspacePath,
|
|
135
|
+
target: normalizeTarget(options.target),
|
|
136
|
+
artifacts: {
|
|
137
|
+
specSummary: spec ? 'spec_summary.json' : null,
|
|
138
|
+
taskPlan: 'task_plan.json',
|
|
139
|
+
dispatchPlan: 'dispatch_plan.json',
|
|
140
|
+
summariesDir: options.includeSummaries ? 'summaries/' : null,
|
|
141
|
+
},
|
|
142
|
+
totals: {
|
|
143
|
+
agents: agentTaskMap.size,
|
|
144
|
+
tasks: handoffTasks.length,
|
|
145
|
+
},
|
|
146
|
+
tasks: handoffTasks,
|
|
147
|
+
unassigned: dispatch.unassigned,
|
|
148
|
+
});
|
|
149
|
+
const indexPath = path.join(outputPath, 'index.md');
|
|
150
|
+
await fs.writeFile(indexPath, renderIndexMarkdown({
|
|
151
|
+
target: normalizeTarget(options.target),
|
|
152
|
+
totalAgents: agentTaskMap.size,
|
|
153
|
+
totalTasks: handoffTasks.length,
|
|
154
|
+
includeSummaries: Boolean(options.includeSummaries),
|
|
155
|
+
}), 'utf-8');
|
|
156
|
+
logger.success('Handoff bundle generated');
|
|
157
|
+
logger.json({
|
|
158
|
+
status: 'success',
|
|
159
|
+
workspace: workspacePath,
|
|
160
|
+
target: normalizeTarget(options.target),
|
|
161
|
+
totalAgents: agentTaskMap.size,
|
|
162
|
+
totalTasks: handoffTasks.length,
|
|
163
|
+
outputPath,
|
|
164
|
+
bundlePath,
|
|
165
|
+
indexPath,
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
catch (error) {
|
|
169
|
+
logger.error(`Handoff failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
170
|
+
process.exit(1);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
function normalizeTarget(target) {
|
|
174
|
+
const value = (target || 'generic').toLowerCase();
|
|
175
|
+
if (['cursor', 'qcoder', 'codebuddy', 'generic'].includes(value)) {
|
|
176
|
+
return value;
|
|
177
|
+
}
|
|
178
|
+
return 'generic';
|
|
179
|
+
}
|
|
180
|
+
function buildSourceChunkMap(spec) {
|
|
181
|
+
const features = new Map();
|
|
182
|
+
const pages = new Map();
|
|
183
|
+
const apis = new Map();
|
|
184
|
+
if (!spec)
|
|
185
|
+
return { features, pages, apis };
|
|
186
|
+
for (const item of spec.features || []) {
|
|
187
|
+
const key = normalizeName(item.name);
|
|
188
|
+
features.set(key, pushUnique(features.get(key), item.sourceChunk));
|
|
189
|
+
}
|
|
190
|
+
for (const item of spec.pages || []) {
|
|
191
|
+
const key = normalizeName(item.name);
|
|
192
|
+
pages.set(key, pushUnique(pages.get(key), item.sourceChunk));
|
|
193
|
+
}
|
|
194
|
+
for (const item of spec.apis || []) {
|
|
195
|
+
const key = normalizeName(`${item.method} ${item.path}`);
|
|
196
|
+
apis.set(key, pushUnique(apis.get(key), item.sourceChunk));
|
|
197
|
+
}
|
|
198
|
+
return { features, pages, apis };
|
|
199
|
+
}
|
|
200
|
+
function guessSourceChunks(task, sourceMap) {
|
|
201
|
+
const key = normalizeName(task.name);
|
|
202
|
+
if (task.type === 'feature' || task.type === 'component') {
|
|
203
|
+
return sourceMap.features.get(key);
|
|
204
|
+
}
|
|
205
|
+
if (task.type === 'page') {
|
|
206
|
+
return sourceMap.pages.get(key);
|
|
207
|
+
}
|
|
208
|
+
if (task.type === 'api') {
|
|
209
|
+
return sourceMap.apis.get(key);
|
|
210
|
+
}
|
|
211
|
+
return undefined;
|
|
212
|
+
}
|
|
213
|
+
function renderTaskPrompt(input) {
|
|
214
|
+
const { row, workspacePath, target, includeSummaries } = input;
|
|
215
|
+
const sourceChunkText = row.sourceChunks && row.sourceChunks.length > 0
|
|
216
|
+
? row.sourceChunks.map(i => `chunk_${i}_summary.json`).join(', ')
|
|
217
|
+
: '未定位到明确 source chunk,请从 spec_summary.json 补充判断';
|
|
218
|
+
return [
|
|
219
|
+
`# Task Handoff - ${row.id} ${row.name}`,
|
|
220
|
+
'',
|
|
221
|
+
`- Target Tool: ${target}`,
|
|
222
|
+
`- Assigned Agent: ${row.assignedAgent} (${row.assignedType})`,
|
|
223
|
+
`- Priority: ${row.priority}`,
|
|
224
|
+
`- Type: ${row.type}`,
|
|
225
|
+
`- Estimated Hours: ${row.estimatedHours ?? 'N/A'}`,
|
|
226
|
+
'',
|
|
227
|
+
'## Objective',
|
|
228
|
+
'',
|
|
229
|
+
`实现任务 **${row.id} ${row.name}**,仅处理当前任务与已满足依赖,不越界扩展。`,
|
|
230
|
+
'',
|
|
231
|
+
'## Dependencies',
|
|
232
|
+
'',
|
|
233
|
+
row.dependencies.length > 0 ? row.dependencies.map(dep => `- ${dep}`).join('\n') : '- 无',
|
|
234
|
+
'',
|
|
235
|
+
'## Required Inputs',
|
|
236
|
+
'',
|
|
237
|
+
'- `spec_summary.json`',
|
|
238
|
+
'- `task_plan.json`',
|
|
239
|
+
'- `dispatch_plan.json`',
|
|
240
|
+
includeSummaries ? '- `summaries/`' : '- (可选)`summaries/`',
|
|
241
|
+
'',
|
|
242
|
+
'## Suggested Evidence',
|
|
243
|
+
'',
|
|
244
|
+
`- ${sourceChunkText}`,
|
|
245
|
+
'',
|
|
246
|
+
'## Execution Constraints',
|
|
247
|
+
'',
|
|
248
|
+
'- 只改与该任务直接相关文件;避免大范围重构',
|
|
249
|
+
'- 明确列出修改文件与验证步骤',
|
|
250
|
+
'- 信息不足时先输出缺失项,再请求补充,不要臆造接口',
|
|
251
|
+
'',
|
|
252
|
+
'## Deliverables',
|
|
253
|
+
'',
|
|
254
|
+
'- 变更文件列表',
|
|
255
|
+
'- 关键实现说明(why + what)',
|
|
256
|
+
'- 可复现实测步骤(命令)',
|
|
257
|
+
'',
|
|
258
|
+
'## Workspace',
|
|
259
|
+
'',
|
|
260
|
+
`- Root: ${workspacePath}`,
|
|
261
|
+
].join('\n');
|
|
262
|
+
}
|
|
263
|
+
function renderAgentPrompt(input) {
|
|
264
|
+
const { agentId, rows, target } = input;
|
|
265
|
+
const lines = rows.map(row => `- ${row.id} | ${row.priority} | ${row.type} | deps: ${row.dependencies.join(', ') || '-'} | ${row.name}`);
|
|
266
|
+
return [
|
|
267
|
+
`# Agent Handoff - ${agentId}`,
|
|
268
|
+
'',
|
|
269
|
+
`- Target Tool: ${target}`,
|
|
270
|
+
`- Total Tasks: ${rows.length}`,
|
|
271
|
+
'',
|
|
272
|
+
'## Task Queue',
|
|
273
|
+
'',
|
|
274
|
+
...(lines.length > 0 ? lines : ['- 无任务']),
|
|
275
|
+
'',
|
|
276
|
+
'## Recommended Order',
|
|
277
|
+
'',
|
|
278
|
+
'1. 先完成依赖少/无依赖任务',
|
|
279
|
+
'2. 优先处理 P0 -> P1 -> P2 -> P3',
|
|
280
|
+
'3. 每完成一项,回填任务状态与变更摘要',
|
|
281
|
+
].join('\n');
|
|
282
|
+
}
|
|
283
|
+
function renderIndexMarkdown(input) {
|
|
284
|
+
const { target, totalAgents, totalTasks, includeSummaries } = input;
|
|
285
|
+
return [
|
|
286
|
+
'# Handoff Bundle Index',
|
|
287
|
+
'',
|
|
288
|
+
`- Target: ${target}`,
|
|
289
|
+
`- Total Agents: ${totalAgents}`,
|
|
290
|
+
`- Total Tasks: ${totalTasks}`,
|
|
291
|
+
`- Include Summaries: ${includeSummaries ? 'yes' : 'no'}`,
|
|
292
|
+
'',
|
|
293
|
+
'## Files',
|
|
294
|
+
'',
|
|
295
|
+
'- `handoff_bundle.json`: 机器可读任务总览',
|
|
296
|
+
'- `agents/*.md`: 每个 agent 的任务队列',
|
|
297
|
+
'- `tasks/*.md`: 每个任务可直接投喂编码 Agent 的提示词模板',
|
|
298
|
+
'',
|
|
299
|
+
'## Quick Start',
|
|
300
|
+
'',
|
|
301
|
+
'1. 先打开 `agents/<AGENT_ID>.md` 确认任务顺序',
|
|
302
|
+
'2. 按顺序将 `tasks/<TASK_ID>.md` 投喂到目标工具执行',
|
|
303
|
+
'3. 每完成一个任务后人工回填状态到你的任务系统',
|
|
304
|
+
].join('\n');
|
|
305
|
+
}
|
|
306
|
+
function normalizeName(input) {
|
|
307
|
+
return (input || '')
|
|
308
|
+
.toLowerCase()
|
|
309
|
+
.replace(/[^\u4e00-\u9fa5a-z0-9\s/:_-]/gi, ' ')
|
|
310
|
+
.replace(/\s+/g, ' ')
|
|
311
|
+
.trim();
|
|
312
|
+
}
|
|
313
|
+
function pushUnique(existing, value) {
|
|
314
|
+
const base = existing ? existing.slice() : [];
|
|
315
|
+
if (!base.includes(value)) {
|
|
316
|
+
base.push(value);
|
|
317
|
+
}
|
|
318
|
+
return base;
|
|
319
|
+
}
|
|
320
|
+
//# sourceMappingURL=handoff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handoff.js","sourceRoot":"","sources":["../../src/commands/handoff.ts"],"names":[],"mappings":"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"}
|