@e0ipso/ai-task-manager 1.36.1 → 1.37.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 (72) hide show
  1. package/README.md +26 -21
  2. package/dist/cli.js +1 -32
  3. package/dist/cli.js.map +1 -1
  4. package/dist/conflict-detector.d.ts.map +1 -1
  5. package/dist/conflict-detector.js +0 -4
  6. package/dist/conflict-detector.js.map +1 -1
  7. package/dist/index.d.ts +3 -16
  8. package/dist/index.d.ts.map +1 -1
  9. package/dist/index.js +50 -245
  10. package/dist/index.js.map +1 -1
  11. package/dist/metadata.d.ts +9 -0
  12. package/dist/metadata.d.ts.map +1 -1
  13. package/dist/metadata.js +14 -0
  14. package/dist/metadata.js.map +1 -1
  15. package/dist/types.d.ts +18 -18
  16. package/dist/types.d.ts.map +1 -1
  17. package/dist/utils.d.ts +27 -58
  18. package/dist/utils.d.ts.map +1 -1
  19. package/dist/utils.js +93 -219
  20. package/dist/utils.js.map +1 -1
  21. package/package.json +4 -2
  22. package/templates/ai-task-manager/config/TASK_MANAGER.md +3 -3
  23. package/templates/ai-task-manager/config/hooks/PRE_PHASE.md +6 -26
  24. package/templates/ai-task-manager/config/hooks/PRE_TASK_ASSIGNMENT.md +6 -24
  25. package/templates/ai-task-manager/config/templates/PLAN_TEMPLATE.md +1 -1
  26. package/templates/{assistant → harness}/agents/plan-creator.md +2 -2
  27. package/templates/harness/skills/task-create-plan/SKILL.md +120 -0
  28. package/templates/harness/skills/task-create-plan/scripts/find-task-manager-root.cjs +116 -0
  29. package/templates/harness/skills/task-create-plan/scripts/get-next-plan-id.cjs +214 -0
  30. package/templates/harness/skills/task-execute-blueprint/SKILL.md +139 -0
  31. package/templates/harness/skills/task-execute-blueprint/scripts/create-feature-branch.cjs +376 -0
  32. package/templates/harness/skills/task-execute-blueprint/scripts/find-task-manager-root.cjs +116 -0
  33. package/templates/harness/skills/task-execute-blueprint/scripts/validate-plan-blueprint.cjs +375 -0
  34. package/templates/harness/skills/task-execute-task/SKILL.md +195 -0
  35. package/templates/harness/skills/task-execute-task/scripts/check-task-dependencies.cjs +437 -0
  36. package/templates/harness/skills/task-execute-task/scripts/find-task-manager-root.cjs +116 -0
  37. package/templates/harness/skills/task-execute-task/scripts/validate-plan-blueprint.cjs +375 -0
  38. package/templates/harness/skills/task-full-workflow/SKILL.md +378 -0
  39. package/templates/harness/skills/task-full-workflow/scripts/create-feature-branch.cjs +376 -0
  40. package/templates/harness/skills/task-full-workflow/scripts/find-task-manager-root.cjs +116 -0
  41. package/templates/harness/skills/task-full-workflow/scripts/get-next-plan-id.cjs +214 -0
  42. package/templates/harness/skills/task-full-workflow/scripts/get-next-task-id.cjs +312 -0
  43. package/templates/harness/skills/task-full-workflow/scripts/validate-plan-blueprint.cjs +375 -0
  44. package/templates/harness/skills/task-generate-tasks/SKILL.md +244 -0
  45. package/templates/harness/skills/task-generate-tasks/scripts/find-task-manager-root.cjs +116 -0
  46. package/templates/harness/skills/task-generate-tasks/scripts/get-next-task-id.cjs +312 -0
  47. package/templates/harness/skills/task-generate-tasks/scripts/validate-plan-blueprint.cjs +375 -0
  48. package/templates/harness/skills/task-refine-plan/SKILL.md +205 -0
  49. package/templates/harness/skills/task-refine-plan/scripts/find-task-manager-root.cjs +116 -0
  50. package/templates/harness/skills/task-refine-plan/scripts/validate-plan-blueprint.cjs +375 -0
  51. package/dist/exec.d.ts +0 -13
  52. package/dist/exec.d.ts.map +0 -1
  53. package/dist/exec.js +0 -261
  54. package/dist/exec.js.map +0 -1
  55. package/templates/ai-task-manager/config/scripts/check-task-dependencies.cjs +0 -240
  56. package/templates/ai-task-manager/config/scripts/compose-prompt.cjs +0 -234
  57. package/templates/ai-task-manager/config/scripts/create-feature-branch.cjs +0 -204
  58. package/templates/ai-task-manager/config/scripts/extract-task-skills.cjs +0 -84
  59. package/templates/ai-task-manager/config/scripts/find-root.cjs +0 -10
  60. package/templates/ai-task-manager/config/scripts/get-next-plan-id.cjs +0 -49
  61. package/templates/ai-task-manager/config/scripts/get-next-task-id.cjs +0 -81
  62. package/templates/ai-task-manager/config/scripts/shared-utils.cjs +0 -418
  63. package/templates/ai-task-manager/config/scripts/validate-plan-blueprint.cjs +0 -138
  64. package/templates/assistant/commands/tasks/create-plan-auto.md +0 -174
  65. package/templates/assistant/commands/tasks/create-plan.md +0 -175
  66. package/templates/assistant/commands/tasks/execute-blueprint.md +0 -233
  67. package/templates/assistant/commands/tasks/execute-task.md +0 -351
  68. package/templates/assistant/commands/tasks/fix-broken-tests.md +0 -44
  69. package/templates/assistant/commands/tasks/full-workflow.md +0 -849
  70. package/templates/assistant/commands/tasks/generate-tasks.md +0 -348
  71. package/templates/assistant/commands/tasks/refine-plan-auto.md +0 -172
  72. package/templates/assistant/commands/tasks/refine-plan.md +0 -163
@@ -0,0 +1,437 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/skill-scripts/check-task-dependencies.ts
31
+ var check_task_dependencies_exports = {};
32
+ __export(check_task_dependencies_exports, {
33
+ _main: () => _main
34
+ });
35
+ module.exports = __toCommonJS(check_task_dependencies_exports);
36
+ var fs4 = __toESM(require("fs"));
37
+ var path4 = __toESM(require("path"));
38
+
39
+ // src/skill-scripts/shared/plan-resolve.ts
40
+ var fs3 = __toESM(require("fs"));
41
+ var path3 = __toESM(require("path"));
42
+
43
+ // src/skill-scripts/shared/root.ts
44
+ var fs = __toESM(require("fs"));
45
+ var path = __toESM(require("path"));
46
+ var EXPECTED_SCHEMA = true ? 1 : 1;
47
+ var isValidTaskManagerRoot = (taskManagerPath) => {
48
+ try {
49
+ if (!fs.existsSync(taskManagerPath)) return false;
50
+ if (!fs.lstatSync(taskManagerPath).isDirectory()) return false;
51
+ const metadataPath = path.join(taskManagerPath, ".init-metadata.json");
52
+ if (!fs.existsSync(metadataPath)) return false;
53
+ const metadata = JSON.parse(fs.readFileSync(metadataPath, "utf8"));
54
+ return metadata && typeof metadata === "object" && "version" in metadata;
55
+ } catch (_err) {
56
+ return false;
57
+ }
58
+ };
59
+ var getTaskManagerAt = (directory) => {
60
+ const taskManagerPath = path.join(directory, ".ai", "task-manager");
61
+ return isValidTaskManagerRoot(taskManagerPath) ? taskManagerPath : null;
62
+ };
63
+ var getParentPaths = (currentPath, acc = []) => {
64
+ const absolutePath = path.resolve(currentPath);
65
+ const nextAcc = [...acc, absolutePath];
66
+ const parentPath = path.dirname(absolutePath);
67
+ if (parentPath === absolutePath) return nextAcc;
68
+ return getParentPaths(parentPath, nextAcc);
69
+ };
70
+ var checkWorkspaceSchema = (metadataPath) => {
71
+ let metadata;
72
+ try {
73
+ metadata = JSON.parse(fs.readFileSync(metadataPath, "utf8"));
74
+ } catch {
75
+ return;
76
+ }
77
+ const actual = typeof metadata.workspaceSchemaVersion === "number" ? metadata.workspaceSchemaVersion : 1;
78
+ if (actual === EXPECTED_SCHEMA) return;
79
+ if (actual < EXPECTED_SCHEMA) {
80
+ process.stderr.write(
81
+ `Workspace schema v${actual} is older than this skill requires (v${EXPECTED_SCHEMA}). Re-run \`npx @e0ipso/ai-task-manager init\` with the latest CLI to update.
82
+ `
83
+ );
84
+ } else {
85
+ process.stderr.write(
86
+ `This skill (built for workspace schema v${EXPECTED_SCHEMA}) is older than the workspace (v${actual}). Re-run \`npx skills add e0ipso/ai-task-manager\` to update skills.
87
+ `
88
+ );
89
+ }
90
+ process.exit(1);
91
+ };
92
+ var findTaskManagerRoot = (startPath = process.cwd()) => {
93
+ const paths = getParentPaths(startPath);
94
+ const found = paths.find((p) => getTaskManagerAt(p));
95
+ if (!found) return null;
96
+ const root = getTaskManagerAt(found);
97
+ if (root) checkWorkspaceSchema(path.join(root, ".init-metadata.json"));
98
+ return root;
99
+ };
100
+
101
+ // src/skill-scripts/shared/plan-scan.ts
102
+ var fs2 = __toESM(require("fs"));
103
+ var path2 = __toESM(require("path"));
104
+
105
+ // src/skill-scripts/shared/frontmatter.ts
106
+ var ID_PATTERNS = [
107
+ /^\s*["']?id["']?\s*:\s*["']?([+-]?\d+)["']?\s*(?:#.*)?$/im,
108
+ /^\s*id\s*:\s*([+-]?\d+)\s*(?:#.*)?$/im,
109
+ /^\s*["']?id["']?\s*:\s*"([+-]?\d+)"\s*(?:#.*)?$/im,
110
+ /^\s*["']?id["']?\s*:\s*'([+-]?\d+)'\s*(?:#.*)?$/im,
111
+ /^\s*["']id["']\s*:\s*([+-]?\d+)\s*(?:#.*)?$/im,
112
+ /^\s*id\s*:\s*[|>]\s*([+-]?\d+)\s*$/im
113
+ ];
114
+ var validateId = (rawId) => {
115
+ const id = parseInt(rawId, 10);
116
+ if (Number.isNaN(id) || id < 0 || id > Number.MAX_SAFE_INTEGER) return null;
117
+ return id;
118
+ };
119
+ var extractIdFromMarkdown = (content) => {
120
+ const frontmatterMatch = content.match(/^---\s*\r?\n([\s\S]*?)\r?\n---/);
121
+ if (!frontmatterMatch || !frontmatterMatch[1]) return null;
122
+ const block = frontmatterMatch[1];
123
+ for (const pattern of ID_PATTERNS) {
124
+ const match = block.match(pattern);
125
+ if (match && match[1]) {
126
+ const id = validateId(match[1]);
127
+ if (id !== null) return id;
128
+ }
129
+ }
130
+ return null;
131
+ };
132
+ var extractIdFromHtml = (content) => {
133
+ const headMatch = content.match(/<head[^>]*>([\s\S]*?)<\/head>/i);
134
+ const scope = headMatch && headMatch[1] ? headMatch[1] : content;
135
+ const metaPatterns = [
136
+ /<meta\s+[^>]*name\s*=\s*["']id["'][^>]*content\s*=\s*["']([+-]?\d+)["'][^>]*\/?>/i,
137
+ /<meta\s+[^>]*content\s*=\s*["']([+-]?\d+)["'][^>]*name\s*=\s*["']id["'][^>]*\/?>/i
138
+ ];
139
+ for (const pattern of metaPatterns) {
140
+ const match = scope.match(pattern);
141
+ if (match && match[1]) {
142
+ const id = validateId(match[1]);
143
+ if (id !== null) return id;
144
+ }
145
+ }
146
+ return null;
147
+ };
148
+ var extractPlanId = (content, filePath) => {
149
+ if (filePath.toLowerCase().endsWith(".html")) return extractIdFromHtml(content);
150
+ return extractIdFromMarkdown(content);
151
+ };
152
+
153
+ // src/skill-scripts/shared/plan-scan.ts
154
+ var PLAN_EXTENSIONS = [".md", ".html"];
155
+ var scanPlanDir = (planDirPath, dirName, isArchive) => {
156
+ let entries;
157
+ try {
158
+ entries = fs2.readdirSync(planDirPath, { withFileTypes: true });
159
+ } catch (_err) {
160
+ return [];
161
+ }
162
+ return entries.filter((e) => e.isFile() && PLAN_EXTENSIONS.some((ext) => e.name.endsWith(ext))).flatMap((e) => {
163
+ const filePath = path2.join(planDirPath, e.name);
164
+ try {
165
+ const content = fs2.readFileSync(filePath, "utf8");
166
+ const id = extractPlanId(content, filePath);
167
+ if (id === null) return [];
168
+ return [{ id, file: filePath, dir: planDirPath, isArchive, name: dirName }];
169
+ } catch (_err) {
170
+ return [];
171
+ }
172
+ });
173
+ };
174
+ var getAllPlans = (taskManagerRoot) => {
175
+ const sources = [
176
+ { dir: path2.join(taskManagerRoot, "plans"), isArchive: false },
177
+ { dir: path2.join(taskManagerRoot, "archive"), isArchive: true }
178
+ ];
179
+ return sources.flatMap(({ dir, isArchive }) => {
180
+ if (!fs2.existsSync(dir)) return [];
181
+ let entries;
182
+ try {
183
+ entries = fs2.readdirSync(dir, { withFileTypes: true });
184
+ } catch (_err) {
185
+ return [];
186
+ }
187
+ return entries.filter((e) => e.isDirectory()).flatMap((e) => scanPlanDir(path2.join(dir, e.name), e.name, isArchive));
188
+ });
189
+ };
190
+
191
+ // src/skill-scripts/shared/plan-resolve.ts
192
+ var isValidRootDir = (taskManagerPath) => {
193
+ try {
194
+ if (!fs3.existsSync(taskManagerPath)) return false;
195
+ if (!fs3.lstatSync(taskManagerPath).isDirectory()) return false;
196
+ const metadataPath = path3.join(taskManagerPath, ".init-metadata.json");
197
+ if (!fs3.existsSync(metadataPath)) return false;
198
+ const metadata = JSON.parse(fs3.readFileSync(metadataPath, "utf8"));
199
+ return metadata && typeof metadata === "object" && "version" in metadata;
200
+ } catch (_err) {
201
+ return false;
202
+ }
203
+ };
204
+ var checkStandardRootShortcut = (filePath) => {
205
+ const planDir = path3.dirname(filePath);
206
+ const parentDir = path3.dirname(planDir);
207
+ const possibleRoot = path3.dirname(parentDir);
208
+ const parentBase = path3.basename(parentDir);
209
+ if (parentBase !== "plans" && parentBase !== "archive") return null;
210
+ if (path3.basename(possibleRoot) !== "task-manager") return null;
211
+ const dotAiDir = path3.dirname(possibleRoot);
212
+ if (path3.basename(dotAiDir) !== ".ai") return null;
213
+ return isValidRootDir(possibleRoot) ? possibleRoot : null;
214
+ };
215
+ var resolveByPath = (absolutePath) => {
216
+ let content;
217
+ try {
218
+ content = fs3.readFileSync(absolutePath, "utf8");
219
+ } catch (_err) {
220
+ return null;
221
+ }
222
+ const planId = extractPlanId(content, absolutePath);
223
+ if (planId === null) return null;
224
+ const tmRoot = checkStandardRootShortcut(absolutePath) || findTaskManagerRoot(path3.dirname(absolutePath));
225
+ if (!tmRoot) return null;
226
+ return {
227
+ planFile: absolutePath,
228
+ planDir: path3.dirname(absolutePath),
229
+ taskManagerRoot: tmRoot,
230
+ planId
231
+ };
232
+ };
233
+ var resolveByIdInAncestry = (planId, startPath, searched = /* @__PURE__ */ new Set()) => {
234
+ const tmRoot = findTaskManagerRoot(startPath);
235
+ if (!tmRoot) return null;
236
+ const normalized = path3.normalize(tmRoot);
237
+ if (searched.has(normalized)) return null;
238
+ searched.add(normalized);
239
+ const plans = getAllPlans(tmRoot);
240
+ const match = plans.find((p) => p.id === planId);
241
+ if (match) {
242
+ return {
243
+ planFile: match.file,
244
+ planDir: match.dir,
245
+ taskManagerRoot: tmRoot,
246
+ planId
247
+ };
248
+ }
249
+ const parentOfRoot = path3.dirname(path3.dirname(tmRoot));
250
+ if (parentOfRoot === tmRoot) return null;
251
+ return resolveByIdInAncestry(planId, parentOfRoot, searched);
252
+ };
253
+ var resolvePlan = (input, startPath = process.cwd()) => {
254
+ if (input === null || input === void 0 || input === "") return null;
255
+ const inputStr = String(input);
256
+ if (inputStr.startsWith("/")) {
257
+ return resolveByPath(inputStr);
258
+ }
259
+ const planId = parseInt(inputStr, 10);
260
+ if (Number.isNaN(planId)) return null;
261
+ return resolveByIdInAncestry(planId, startPath);
262
+ };
263
+
264
+ // src/skill-scripts/check-task-dependencies.ts
265
+ var _printError = (message) => {
266
+ console.error(`ERROR: ${message}`);
267
+ };
268
+ var _printSuccess = (message) => {
269
+ console.log(`\u2713 ${message}`);
270
+ };
271
+ var _printWarning = (message) => {
272
+ console.log(`\u26A0 ${message}`);
273
+ };
274
+ var _printInfo = (message) => {
275
+ console.log(message);
276
+ };
277
+ var _extractFrontmatter = (content) => {
278
+ const match = content.match(/^---\s*\r?\n([\s\S]*?)\r?\n---/);
279
+ return match && match[1] ? match[1] : null;
280
+ };
281
+ var _findTaskFile = (planDir, taskId) => {
282
+ const taskDir = path4.join(planDir, "tasks");
283
+ if (!fs4.existsSync(taskDir)) {
284
+ return null;
285
+ }
286
+ const variations = [taskId, taskId.padStart(2, "0"), taskId.replace(/^0+/, "") || "0"];
287
+ const uniqueVariations = [...new Set(variations)];
288
+ try {
289
+ const files = fs4.readdirSync(taskDir);
290
+ const found = uniqueVariations.reduce((acc, v) => {
291
+ if (acc) return acc;
292
+ const match = files.find((f) => f.startsWith(`${v}--`) && f.endsWith(".md"));
293
+ return match ? path4.join(taskDir, match) : null;
294
+ }, null);
295
+ return found;
296
+ } catch (_err) {
297
+ return null;
298
+ }
299
+ };
300
+ var _extractDependencies = (frontmatter) => {
301
+ const lines = frontmatter.split("\n");
302
+ const dependencies = [];
303
+ let inDependenciesSection = false;
304
+ for (const line of lines) {
305
+ if (line.match(/^dependencies:/)) {
306
+ inDependenciesSection = true;
307
+ const arrayMatch = line.match(/\[(.*)\]/);
308
+ if (arrayMatch && arrayMatch[1]) {
309
+ const deps = arrayMatch[1].split(",").map((dep) => dep.trim().replace(/['"]/g, "")).filter((dep) => dep.length > 0);
310
+ dependencies.push(...deps);
311
+ inDependenciesSection = false;
312
+ }
313
+ continue;
314
+ }
315
+ if (inDependenciesSection && line.match(/^[^ ]/) && !line.match(/^[ \t]*-/)) {
316
+ inDependenciesSection = false;
317
+ }
318
+ if (inDependenciesSection && line.match(/^[ \t]*-/)) {
319
+ const dep = line.replace(/^[ \t]*-[ \t]*/, "").replace(/[ \t]*$/, "").replace(/['"]/g, "");
320
+ if (dep.length > 0) {
321
+ dependencies.push(dep);
322
+ }
323
+ }
324
+ }
325
+ return dependencies;
326
+ };
327
+ var _extractStatus = (frontmatter) => {
328
+ const lines = frontmatter.split("\n");
329
+ for (const line of lines) {
330
+ if (line.match(/^status:/)) {
331
+ return line.replace(/^status:[ \t]*/, "").replace(/^["']/, "").replace(/["']$/, "").trim();
332
+ }
333
+ }
334
+ return null;
335
+ };
336
+ var _main = (startPath = process.cwd()) => {
337
+ if (process.argv.length !== 4) {
338
+ _printError("Invalid number of arguments");
339
+ console.log("Usage: node check-task-dependencies.cjs <plan-id-or-path> <task-id>");
340
+ console.log("Example: node check-task-dependencies.cjs 16 03");
341
+ process.exit(1);
342
+ }
343
+ const inputId = process.argv[2];
344
+ const taskId = process.argv[3];
345
+ if (!inputId || !taskId) {
346
+ _printError("Invalid arguments");
347
+ process.exit(1);
348
+ }
349
+ const resolved = resolvePlan(inputId, startPath);
350
+ if (!resolved) {
351
+ _printError(`Plan "${inputId}" not found or invalid`);
352
+ process.exit(1);
353
+ }
354
+ const { planDir, planId } = resolved;
355
+ _printInfo(`Found plan directory: ${planDir}`);
356
+ const taskFile = _findTaskFile(planDir, taskId);
357
+ if (!taskFile || !fs4.existsSync(taskFile)) {
358
+ _printError(`Task with ID ${taskId} not found in plan ${planId}`);
359
+ process.exit(1);
360
+ }
361
+ _printInfo(`Checking task: ${path4.basename(taskFile)}`);
362
+ console.log("");
363
+ const taskContent = fs4.readFileSync(taskFile, "utf8");
364
+ const frontmatter = _extractFrontmatter(taskContent);
365
+ if (!frontmatter) {
366
+ _printError("Could not extract frontmatter from task file");
367
+ process.exit(1);
368
+ }
369
+ const dependencies = _extractDependencies(frontmatter);
370
+ if (dependencies.length === 0) {
371
+ _printSuccess("Task has no dependencies - ready to execute!");
372
+ process.exit(0);
373
+ }
374
+ _printInfo("Task dependencies found:");
375
+ dependencies.forEach((dep) => {
376
+ console.log(` - Task ${dep}`);
377
+ });
378
+ console.log("");
379
+ let allResolved = true;
380
+ const unresolvedDeps = [];
381
+ let resolvedCount = 0;
382
+ const totalDeps = dependencies.length;
383
+ _printInfo("Checking dependency status...");
384
+ console.log("");
385
+ for (const depId of dependencies) {
386
+ const depFile = _findTaskFile(planDir, depId);
387
+ if (!depFile || !fs4.existsSync(depFile)) {
388
+ _printError(`Dependency task ${depId} not found`);
389
+ allResolved = false;
390
+ unresolvedDeps.push(`${depId} (not found)`);
391
+ continue;
392
+ }
393
+ const depContent = fs4.readFileSync(depFile, "utf8");
394
+ const depFrontmatter = _extractFrontmatter(depContent);
395
+ if (!depFrontmatter) {
396
+ _printError(`Could not extract frontmatter from dependency task ${depId}`);
397
+ allResolved = false;
398
+ unresolvedDeps.push(`${depId} (no frontmatter)`);
399
+ continue;
400
+ }
401
+ const status = _extractStatus(depFrontmatter);
402
+ if (status === "completed") {
403
+ _printSuccess(`Task ${depId} - Status: completed \u2713`);
404
+ resolvedCount++;
405
+ } else {
406
+ _printWarning(`Task ${depId} - Status: ${status || "unknown"} \u2717`);
407
+ allResolved = false;
408
+ unresolvedDeps.push(`${depId} (${status || "unknown"})`);
409
+ }
410
+ }
411
+ console.log("");
412
+ _printInfo("=========================================");
413
+ _printInfo("Dependency Check Summary");
414
+ _printInfo("=========================================");
415
+ _printInfo(`Total dependencies: ${totalDeps}`);
416
+ _printInfo(`Resolved: ${resolvedCount}`);
417
+ _printInfo(`Unresolved: ${totalDeps - resolvedCount}`);
418
+ console.log("");
419
+ if (allResolved) {
420
+ _printSuccess(`All dependencies are resolved! Task ${taskId} is ready to execute.`);
421
+ process.exit(0);
422
+ } else {
423
+ _printError(`Task ${taskId} has unresolved dependencies:`);
424
+ unresolvedDeps.forEach((dep) => {
425
+ console.log(dep);
426
+ });
427
+ _printInfo("Please complete the dependencies before executing this task.");
428
+ process.exit(1);
429
+ }
430
+ };
431
+ if (require.main === module) {
432
+ _main();
433
+ }
434
+ // Annotate the CommonJS export names for ESM import in node:
435
+ 0 && (module.exports = {
436
+ _main
437
+ });
@@ -0,0 +1,116 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/skill-scripts/find-task-manager-root.ts
31
+ var find_task_manager_root_exports = {};
32
+ __export(find_task_manager_root_exports, {
33
+ main: () => main
34
+ });
35
+ module.exports = __toCommonJS(find_task_manager_root_exports);
36
+
37
+ // src/skill-scripts/shared/root.ts
38
+ var fs = __toESM(require("fs"));
39
+ var path = __toESM(require("path"));
40
+ var EXPECTED_SCHEMA = true ? 1 : 1;
41
+ var isValidTaskManagerRoot = (taskManagerPath) => {
42
+ try {
43
+ if (!fs.existsSync(taskManagerPath)) return false;
44
+ if (!fs.lstatSync(taskManagerPath).isDirectory()) return false;
45
+ const metadataPath = path.join(taskManagerPath, ".init-metadata.json");
46
+ if (!fs.existsSync(metadataPath)) return false;
47
+ const metadata = JSON.parse(fs.readFileSync(metadataPath, "utf8"));
48
+ return metadata && typeof metadata === "object" && "version" in metadata;
49
+ } catch (_err) {
50
+ return false;
51
+ }
52
+ };
53
+ var getTaskManagerAt = (directory) => {
54
+ const taskManagerPath = path.join(directory, ".ai", "task-manager");
55
+ return isValidTaskManagerRoot(taskManagerPath) ? taskManagerPath : null;
56
+ };
57
+ var getParentPaths = (currentPath, acc = []) => {
58
+ const absolutePath = path.resolve(currentPath);
59
+ const nextAcc = [...acc, absolutePath];
60
+ const parentPath = path.dirname(absolutePath);
61
+ if (parentPath === absolutePath) return nextAcc;
62
+ return getParentPaths(parentPath, nextAcc);
63
+ };
64
+ var checkWorkspaceSchema = (metadataPath) => {
65
+ let metadata;
66
+ try {
67
+ metadata = JSON.parse(fs.readFileSync(metadataPath, "utf8"));
68
+ } catch {
69
+ return;
70
+ }
71
+ const actual = typeof metadata.workspaceSchemaVersion === "number" ? metadata.workspaceSchemaVersion : 1;
72
+ if (actual === EXPECTED_SCHEMA) return;
73
+ if (actual < EXPECTED_SCHEMA) {
74
+ process.stderr.write(
75
+ `Workspace schema v${actual} is older than this skill requires (v${EXPECTED_SCHEMA}). Re-run \`npx @e0ipso/ai-task-manager init\` with the latest CLI to update.
76
+ `
77
+ );
78
+ } else {
79
+ process.stderr.write(
80
+ `This skill (built for workspace schema v${EXPECTED_SCHEMA}) is older than the workspace (v${actual}). Re-run \`npx skills add e0ipso/ai-task-manager\` to update skills.
81
+ `
82
+ );
83
+ }
84
+ process.exit(1);
85
+ };
86
+ var findTaskManagerRoot = (startPath = process.cwd()) => {
87
+ const paths = getParentPaths(startPath);
88
+ const found = paths.find((p) => getTaskManagerAt(p));
89
+ if (!found) return null;
90
+ const root = getTaskManagerAt(found);
91
+ if (root) checkWorkspaceSchema(path.join(root, ".init-metadata.json"));
92
+ return root;
93
+ };
94
+
95
+ // src/skill-scripts/find-task-manager-root.ts
96
+ var main = () => {
97
+ const startPath = process.argv[2] || process.cwd();
98
+ const root = findTaskManagerRoot(startPath);
99
+ if (!root) {
100
+ process.stderr.write(
101
+ `Could not find .ai/task-manager root from ${startPath} or any parent directory.
102
+ `
103
+ );
104
+ process.exit(1);
105
+ }
106
+ process.stdout.write(`${root}
107
+ `);
108
+ process.exit(0);
109
+ };
110
+ if (require.main === module) {
111
+ main();
112
+ }
113
+ // Annotate the CommonJS export names for ESM import in node:
114
+ 0 && (module.exports = {
115
+ main
116
+ });