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.
Files changed (39) hide show
  1. package/README.md +42 -2
  2. package/USAGE_FROM_NPM.md +280 -0
  3. package/dist/commands/analyze.d.ts.map +1 -1
  4. package/dist/commands/analyze.js +14 -1
  5. package/dist/commands/analyze.js.map +1 -1
  6. package/dist/commands/execute.d.ts +15 -0
  7. package/dist/commands/execute.d.ts.map +1 -0
  8. package/dist/commands/execute.js +298 -0
  9. package/dist/commands/execute.js.map +1 -0
  10. package/dist/commands/handoff.d.ts +11 -0
  11. package/dist/commands/handoff.d.ts.map +1 -0
  12. package/dist/commands/handoff.js +320 -0
  13. package/dist/commands/handoff.js.map +1 -0
  14. package/dist/commands/learn.d.ts +7 -0
  15. package/dist/commands/learn.d.ts.map +1 -1
  16. package/dist/commands/learn.js +31 -4
  17. package/dist/commands/learn.js.map +1 -1
  18. package/dist/commands/pipeline.d.ts +1 -0
  19. package/dist/commands/pipeline.d.ts.map +1 -1
  20. package/dist/commands/pipeline.js +5 -0
  21. package/dist/commands/pipeline.js.map +1 -1
  22. package/dist/commands/scan.js +17 -15
  23. package/dist/commands/scan.js.map +1 -1
  24. package/dist/index.js +73 -2
  25. package/dist/index.js.map +1 -1
  26. package/dist/services/llm.d.ts +2 -2
  27. package/dist/services/llm.d.ts.map +1 -1
  28. package/dist/services/llm.js +8 -2
  29. package/dist/services/llm.js.map +1 -1
  30. package/package.json +4 -3
  31. package/spec-agent-implementation.md +46 -1
  32. package/src/commands/analyze.ts +14 -1
  33. package/src/commands/execute.ts +358 -0
  34. package/src/commands/handoff.ts +351 -0
  35. package/src/commands/learn.ts +41 -6
  36. package/src/commands/pipeline.ts +8 -0
  37. package/src/commands/scan.ts +18 -18
  38. package/src/index.ts +41 -2
  39. 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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"}