@cardor/agent-harness-kit 0.1.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 (111) hide show
  1. package/README.md +218 -0
  2. package/bin/ahk.js +2 -0
  3. package/dist/cli.d.ts +2 -0
  4. package/dist/cli.d.ts.map +1 -0
  5. package/dist/cli.js +113 -0
  6. package/dist/cli.js.map +1 -0
  7. package/dist/commands/build.d.ts +6 -0
  8. package/dist/commands/build.d.ts.map +1 -0
  9. package/dist/commands/build.js +39 -0
  10. package/dist/commands/build.js.map +1 -0
  11. package/dist/commands/export.d.ts +8 -0
  12. package/dist/commands/export.d.ts.map +1 -0
  13. package/dist/commands/export.js +33 -0
  14. package/dist/commands/export.js.map +1 -0
  15. package/dist/commands/health.d.ts +2 -0
  16. package/dist/commands/health.d.ts.map +1 -0
  17. package/dist/commands/health.js +38 -0
  18. package/dist/commands/health.js.map +1 -0
  19. package/dist/commands/init-helpers.d.ts +9 -0
  20. package/dist/commands/init-helpers.d.ts.map +1 -0
  21. package/dist/commands/init-helpers.js +40 -0
  22. package/dist/commands/init-helpers.js.map +1 -0
  23. package/dist/commands/init.d.ts +9 -0
  24. package/dist/commands/init.d.ts.map +1 -0
  25. package/dist/commands/init.js +202 -0
  26. package/dist/commands/init.js.map +1 -0
  27. package/dist/commands/migrate.d.ts +6 -0
  28. package/dist/commands/migrate.d.ts.map +1 -0
  29. package/dist/commands/migrate.js +45 -0
  30. package/dist/commands/migrate.js.map +1 -0
  31. package/dist/commands/serve.d.ts +6 -0
  32. package/dist/commands/serve.d.ts.map +1 -0
  33. package/dist/commands/serve.js +13 -0
  34. package/dist/commands/serve.js.map +1 -0
  35. package/dist/commands/status.d.ts +6 -0
  36. package/dist/commands/status.d.ts.map +1 -0
  37. package/dist/commands/status.js +71 -0
  38. package/dist/commands/status.js.map +1 -0
  39. package/dist/commands/sync.d.ts +7 -0
  40. package/dist/commands/sync.d.ts.map +1 -0
  41. package/dist/commands/sync.js +57 -0
  42. package/dist/commands/sync.js.map +1 -0
  43. package/dist/commands/task/add.d.ts +2 -0
  44. package/dist/commands/task/add.d.ts.map +1 -0
  45. package/dist/commands/task/add.js +59 -0
  46. package/dist/commands/task/add.js.map +1 -0
  47. package/dist/commands/task/done.d.ts +2 -0
  48. package/dist/commands/task/done.d.ts.map +1 -0
  49. package/dist/commands/task/done.js +45 -0
  50. package/dist/commands/task/done.js.map +1 -0
  51. package/dist/commands/task/index.d.ts +4 -0
  52. package/dist/commands/task/index.d.ts.map +1 -0
  53. package/dist/commands/task/index.js +4 -0
  54. package/dist/commands/task/index.js.map +1 -0
  55. package/dist/commands/task/list.d.ts +7 -0
  56. package/dist/commands/task/list.d.ts.map +1 -0
  57. package/dist/commands/task/list.js +42 -0
  58. package/dist/commands/task/list.js.map +1 -0
  59. package/dist/core/config.d.ts +5 -0
  60. package/dist/core/config.d.ts.map +1 -0
  61. package/dist/core/config.js +77 -0
  62. package/dist/core/config.js.map +1 -0
  63. package/dist/core/db.d.ts +56 -0
  64. package/dist/core/db.d.ts.map +1 -0
  65. package/dist/core/db.js +344 -0
  66. package/dist/core/db.js.map +1 -0
  67. package/dist/core/materializer/claude-code.d.ts +8 -0
  68. package/dist/core/materializer/claude-code.d.ts.map +1 -0
  69. package/dist/core/materializer/claude-code.js +83 -0
  70. package/dist/core/materializer/claude-code.js.map +1 -0
  71. package/dist/core/materializer/index.d.ts +8 -0
  72. package/dist/core/materializer/index.d.ts.map +1 -0
  73. package/dist/core/materializer/index.js +13 -0
  74. package/dist/core/materializer/index.js.map +1 -0
  75. package/dist/core/materializer/opencode.d.ts +8 -0
  76. package/dist/core/materializer/opencode.d.ts.map +1 -0
  77. package/dist/core/materializer/opencode.js +76 -0
  78. package/dist/core/materializer/opencode.js.map +1 -0
  79. package/dist/core/materializer/templates.d.ts +25 -0
  80. package/dist/core/materializer/templates.d.ts.map +1 -0
  81. package/dist/core/materializer/templates.js +319 -0
  82. package/dist/core/materializer/templates.js.map +1 -0
  83. package/dist/core/mcp-server.d.ts +3 -0
  84. package/dist/core/mcp-server.d.ts.map +1 -0
  85. package/dist/core/mcp-server.js +264 -0
  86. package/dist/core/mcp-server.js.map +1 -0
  87. package/dist/core/sqlite-adapter.d.ts +14 -0
  88. package/dist/core/sqlite-adapter.d.ts.map +1 -0
  89. package/dist/core/sqlite-adapter.js +20 -0
  90. package/dist/core/sqlite-adapter.js.map +1 -0
  91. package/dist/index.d.ts +3 -0
  92. package/dist/index.d.ts.map +1 -0
  93. package/dist/index.js +2 -0
  94. package/dist/index.js.map +1 -0
  95. package/dist/tests/db.test.d.ts +2 -0
  96. package/dist/tests/db.test.d.ts.map +1 -0
  97. package/dist/tests/db.test.js +106 -0
  98. package/dist/tests/db.test.js.map +1 -0
  99. package/dist/tests/slugify.test.d.ts +2 -0
  100. package/dist/tests/slugify.test.d.ts.map +1 -0
  101. package/dist/tests/slugify.test.js +26 -0
  102. package/dist/tests/slugify.test.js.map +1 -0
  103. package/dist/tests/templates.test.d.ts +2 -0
  104. package/dist/tests/templates.test.d.ts.map +1 -0
  105. package/dist/tests/templates.test.js +64 -0
  106. package/dist/tests/templates.test.js.map +1 -0
  107. package/dist/types.d.ts +141 -0
  108. package/dist/types.d.ts.map +1 -0
  109. package/dist/types.js +3 -0
  110. package/dist/types.js.map +1 -0
  111. package/package.json +56 -0
@@ -0,0 +1,202 @@
1
+ import * as p from '@clack/prompts';
2
+ import pc from 'picocolors';
3
+ import { mkdirSync, writeFileSync } from 'node:fs';
4
+ import { join } from 'node:path';
5
+ import { getMaterializer } from '../core/materializer/index.js';
6
+ import { openDB } from '../core/db.js';
7
+ import { configTs } from '../core/materializer/templates.js';
8
+ import { applyConfigDefaults } from './init-helpers.js';
9
+ export async function runInit(cwd, flags) {
10
+ p.intro(pc.bold('agent-harness-kit — harness scaffolding'));
11
+ // ─── Project name ────────────────────────────────────────────────────────
12
+ let name;
13
+ if (flags.name) {
14
+ name = flags.name;
15
+ }
16
+ else {
17
+ const val = await p.text({
18
+ message: 'Project name',
19
+ placeholder: 'my-app',
20
+ validate: (v) => (v.trim() ? undefined : 'Project name is required'),
21
+ });
22
+ if (p.isCancel(val)) {
23
+ p.cancel('Cancelled.');
24
+ process.exit(0);
25
+ }
26
+ name = val;
27
+ }
28
+ // ─── Description ─────────────────────────────────────────────────────────
29
+ const descVal = await p.text({
30
+ message: 'Short description (shown to agents as context)',
31
+ placeholder: 'A REST API for managing notes',
32
+ });
33
+ if (p.isCancel(descVal)) {
34
+ p.cancel('Cancelled.');
35
+ process.exit(0);
36
+ }
37
+ const description = descVal.trim() || name;
38
+ // ─── Provider ─────────────────────────────────────────────────────────────
39
+ let provider;
40
+ if (flags.provider && ['claude-code', 'opencode'].includes(flags.provider)) {
41
+ provider = flags.provider;
42
+ }
43
+ else {
44
+ const val = await p.select({
45
+ message: 'AI provider',
46
+ options: [
47
+ { value: 'claude-code', label: 'Claude Code' },
48
+ { value: 'opencode', label: 'OpenCode' },
49
+ ],
50
+ });
51
+ if (p.isCancel(val)) {
52
+ p.cancel('Cancelled.');
53
+ process.exit(0);
54
+ }
55
+ provider = val;
56
+ }
57
+ // ─── Docs path ────────────────────────────────────────────────────────────
58
+ let docsPath;
59
+ if (flags.docs) {
60
+ docsPath = flags.docs;
61
+ }
62
+ else {
63
+ const val = await p.text({
64
+ message: 'Docs folder path (agents will search here)',
65
+ initialValue: './docs',
66
+ });
67
+ if (p.isCancel(val)) {
68
+ p.cancel('Cancelled.');
69
+ process.exit(0);
70
+ }
71
+ docsPath = val.trim() || './docs';
72
+ }
73
+ // ─── Task adapter ─────────────────────────────────────────────────────────
74
+ let tasksAdapter;
75
+ if (flags.tasks && ['local', 'jira', 'linear'].includes(flags.tasks)) {
76
+ tasksAdapter = flags.tasks;
77
+ }
78
+ else {
79
+ const val = await p.select({
80
+ message: 'Task adapter',
81
+ options: [
82
+ { value: 'local', label: 'Local (feature_list.json)' },
83
+ { value: 'jira', label: 'Jira (coming soon)' },
84
+ { value: 'linear', label: 'Linear (coming soon)' },
85
+ ],
86
+ });
87
+ if (p.isCancel(val)) {
88
+ p.cancel('Cancelled.');
89
+ process.exit(0);
90
+ }
91
+ tasksAdapter = val;
92
+ }
93
+ // ─── Optional first task ──────────────────────────────────────────────────
94
+ const addFirstTask = await p.confirm({ message: 'Add your first task now?', initialValue: true });
95
+ if (p.isCancel(addFirstTask)) {
96
+ p.cancel('Cancelled.');
97
+ process.exit(0);
98
+ }
99
+ let firstTask;
100
+ if (addFirstTask) {
101
+ const titleVal = await p.text({
102
+ message: 'Task title',
103
+ validate: (v) => (v.trim() ? undefined : 'Title is required'),
104
+ });
105
+ if (p.isCancel(titleVal)) {
106
+ p.cancel('Cancelled.');
107
+ process.exit(0);
108
+ }
109
+ const taskTitle = titleVal.trim();
110
+ const taskDescVal = await p.text({
111
+ message: 'Task description',
112
+ placeholder: 'What and why',
113
+ });
114
+ if (p.isCancel(taskDescVal)) {
115
+ p.cancel('Cancelled.');
116
+ process.exit(0);
117
+ }
118
+ const taskDesc = taskDescVal.trim();
119
+ const acceptance = [];
120
+ p.log.info('Acceptance criteria — one per line, empty line to finish');
121
+ while (true) {
122
+ const criterionVal = await p.text({
123
+ message: '>',
124
+ placeholder: 'Criterion (or press Enter to finish)',
125
+ });
126
+ if (p.isCancel(criterionVal) || !criterionVal.trim())
127
+ break;
128
+ acceptance.push(criterionVal.trim());
129
+ }
130
+ firstTask = { title: taskTitle, description: taskDesc, acceptance };
131
+ }
132
+ // ─── Scaffold ─────────────────────────────────────────────────────────────
133
+ const spinner = p.spinner();
134
+ spinner.start('Scaffolding...');
135
+ try {
136
+ const config = applyConfigDefaults({ name, description, provider, docsPath, tasksAdapter });
137
+ const materializer = getMaterializer(provider);
138
+ // Write config file
139
+ const configContent = configTs({
140
+ name,
141
+ description,
142
+ provider,
143
+ docsPath,
144
+ tasksAdapter,
145
+ port: config.tools.mcp.port,
146
+ });
147
+ writeFileSync(join(cwd, 'agent-harness-kit.config.ts'), configContent, 'utf8');
148
+ // Create .harness dir
149
+ mkdirSync(join(cwd, config.storage.dir), { recursive: true });
150
+ // Initialize SQLite DB
151
+ const db = openDB(config, cwd);
152
+ // Scaffold provider-specific files
153
+ await materializer.scaffold(config, { cwd, firstTask });
154
+ // Seed first task into DB if provided
155
+ if (firstTask) {
156
+ const slug = slugify(firstTask.title);
157
+ db.addTask({
158
+ slug,
159
+ title: firstTask.title,
160
+ description: firstTask.description,
161
+ acceptance: firstTask.acceptance,
162
+ });
163
+ }
164
+ db.close();
165
+ spinner.stop('Done');
166
+ }
167
+ catch (err) {
168
+ spinner.stop('Failed');
169
+ p.log.error(err instanceof Error ? err.message : String(err));
170
+ process.exit(1);
171
+ }
172
+ // ─── Summary ──────────────────────────────────────────────────────────────
173
+ const agentsDir = provider === 'claude-code' ? '.claude/agents/' : '.opencode/agents/';
174
+ const mcpFile = provider === 'claude-code' ? '.claude/mcp.json' : 'opencode.json';
175
+ p.log.success(pc.green('agent-harness-kit.config.ts'));
176
+ p.log.success(pc.green('AGENTS.md'));
177
+ p.log.success(pc.green('health.sh') + pc.dim(' ← exits 1 until you implement it'));
178
+ p.log.success(pc.green(`.harness/feature_list.json`) + (firstTask ? pc.dim(' ← 1 task added') : ''));
179
+ p.log.success(pc.green('.harness/harness.db') + pc.dim(' ← SQLite schema initialized'));
180
+ p.log.success(pc.green('.harness/current.md'));
181
+ p.log.success(pc.green(`${agentsDir}lead.md`));
182
+ p.log.success(pc.green(`${agentsDir}explorer.md`));
183
+ p.log.success(pc.green(`${agentsDir}builder.md`));
184
+ p.log.success(pc.green(`${agentsDir}reviewer.md`));
185
+ p.log.success(pc.green(mcpFile));
186
+ p.log.success(pc.green('.gitignore entries added'));
187
+ p.log.warn(pc.yellow('health.sh exits 1 — implement it before agents start working.'));
188
+ p.outro([
189
+ pc.bold('Next steps:'),
190
+ ` → Edit ${pc.cyan('health.sh')} with your project's checks`,
191
+ ` → ${pc.cyan('ahk task add')} to add more tasks`,
192
+ ` → Open ${provider === 'claude-code' ? 'Claude Code' : 'OpenCode'} in this directory and let agents work`,
193
+ ].join('\n'));
194
+ }
195
+ function slugify(title) {
196
+ return title
197
+ .toLowerCase()
198
+ .replace(/[^a-z0-9]+/g, '-')
199
+ .replace(/^-+|-+$/g, '')
200
+ .slice(0, 64);
201
+ }
202
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ interface MigrateOptions {
2
+ to?: string;
3
+ }
4
+ export declare function runMigrate(cwd: string, opts: MigrateOptions): Promise<void>;
5
+ export {};
6
+ //# sourceMappingURL=migrate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../../src/commands/migrate.ts"],"names":[],"mappings":"AAMA,UAAU,cAAc;IACtB,EAAE,CAAC,EAAE,MAAM,CAAA;CACZ;AAED,wBAAsB,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAuCjF"}
@@ -0,0 +1,45 @@
1
+ import * as p from '@clack/prompts';
2
+ import pc from 'picocolors';
3
+ import { loadConfig } from '../core/config.js';
4
+ import { getMaterializer } from '../core/materializer/index.js';
5
+ export async function runMigrate(cwd, opts) {
6
+ const config = await loadConfig(cwd);
7
+ let target;
8
+ if (opts.to && ['claude-code', 'opencode'].includes(opts.to)) {
9
+ target = opts.to;
10
+ }
11
+ else {
12
+ const val = await p.select({
13
+ message: 'Migrate to provider',
14
+ options: [
15
+ { value: 'claude-code', label: 'Claude Code' },
16
+ { value: 'opencode', label: 'OpenCode' },
17
+ ],
18
+ });
19
+ if (p.isCancel(val)) {
20
+ p.cancel('Cancelled.');
21
+ process.exit(0);
22
+ }
23
+ target = val;
24
+ }
25
+ if (target === config.provider) {
26
+ console.log(pc.dim(`Already on ${target} — nothing to migrate.`));
27
+ return;
28
+ }
29
+ const spinner = p.spinner();
30
+ spinner.start(`Migrating from ${config.provider} to ${target}...`);
31
+ try {
32
+ // Scaffold the new provider's files
33
+ const targetMaterializer = getMaterializer(target);
34
+ await targetMaterializer.build(config, cwd);
35
+ spinner.stop(pc.green(`Migrated to ${target}`));
36
+ p.log.warn(`Update agent-harness-kit.config.ts: set provider: '${target}'`);
37
+ p.log.warn(`Then run: ahk build`);
38
+ }
39
+ catch (err) {
40
+ spinner.stop(pc.red('Migration failed'));
41
+ p.log.error(err instanceof Error ? err.message : String(err));
42
+ process.exit(1);
43
+ }
44
+ }
45
+ //# sourceMappingURL=migrate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../src/commands/migrate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,gBAAgB,CAAA;AACnC,OAAO,EAAE,MAAM,YAAY,CAAA;AAC3B,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAO/D,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,GAAW,EAAE,IAAoB;IAChE,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAA;IAEpC,IAAI,MAAgB,CAAA;IACpB,IAAI,IAAI,CAAC,EAAE,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;QAC7D,MAAM,GAAG,IAAI,CAAC,EAAc,CAAA;IAC9B,CAAC;SAAM,CAAC;QACN,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,MAAM,CAAC;YACzB,OAAO,EAAE,qBAAqB;YAC9B,OAAO,EAAE;gBACP,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE;gBAC9C,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE;aACzC;SACF,CAAC,CAAA;QACF,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAAC,CAAC;QAChE,MAAM,GAAG,GAAe,CAAA;IAC1B,CAAC;IAED,IAAI,MAAM,KAAK,MAAM,CAAC,QAAQ,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,MAAM,wBAAwB,CAAC,CAAC,CAAA;QACjE,OAAM;IACR,CAAC;IAED,MAAM,OAAO,GAAG,CAAC,CAAC,OAAO,EAAE,CAAA;IAC3B,OAAO,CAAC,KAAK,CAAC,kBAAkB,MAAM,CAAC,QAAQ,OAAO,MAAM,KAAK,CAAC,CAAA;IAElE,IAAI,CAAC;QACH,oCAAoC;QACpC,MAAM,kBAAkB,GAAG,eAAe,CAAC,MAAM,CAAC,CAAA;QAClD,MAAM,kBAAkB,CAAC,KAAK,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QAE3C,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe,MAAM,EAAE,CAAC,CAAC,CAAA;QAC/C,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,sDAAsD,MAAM,GAAG,CAAC,CAAA;QAC3E,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACnC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAA;QACxC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;QAC7D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC"}
@@ -0,0 +1,6 @@
1
+ interface ServeOptions {
2
+ port?: number;
3
+ }
4
+ export declare function runServe(cwd: string, opts: ServeOptions): Promise<void>;
5
+ export {};
6
+ //# sourceMappingURL=serve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serve.d.ts","sourceRoot":"","sources":["../../src/commands/serve.ts"],"names":[],"mappings":"AAGA,UAAU,YAAY;IACpB,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,wBAAsB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAY7E"}
@@ -0,0 +1,13 @@
1
+ import { loadConfig } from '../core/config.js';
2
+ import { startMcpServer } from '../core/mcp-server.js';
3
+ export async function runServe(cwd, opts) {
4
+ const config = await loadConfig(cwd);
5
+ if (opts.port) {
6
+ config.tools.mcp.port = opts.port;
7
+ }
8
+ // MCP server runs on stdio — do not write to stdout after this point.
9
+ // Stderr is used for diagnostics.
10
+ process.stderr.write(`[agent-harness-kit] MCP server starting (stdio)\n`);
11
+ await startMcpServer(config, cwd);
12
+ }
13
+ //# sourceMappingURL=serve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serve.js","sourceRoot":"","sources":["../../src/commands/serve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AAMtD,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,GAAW,EAAE,IAAkB;IAC5D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAA;IAEpC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAA;IACnC,CAAC;IAED,sEAAsE;IACtE,kCAAkC;IAClC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAA;IAEzE,MAAM,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;AACnC,CAAC"}
@@ -0,0 +1,6 @@
1
+ interface StatusOptions {
2
+ json?: boolean;
3
+ }
4
+ export declare function runStatus(cwd: string, opts: StatusOptions): Promise<void>;
5
+ export {};
6
+ //# sourceMappingURL=status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAKA,UAAU,aAAa;IACrB,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AASD,wBAAsB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAkE/E"}
@@ -0,0 +1,71 @@
1
+ import Table from 'cli-table3';
2
+ import pc from 'picocolors';
3
+ import { loadConfig } from '../core/config.js';
4
+ import { openDB } from '../core/db.js';
5
+ const STATUS_COLOR = {
6
+ pending: (s) => pc.dim(s),
7
+ in_progress: (s) => pc.cyan(s),
8
+ done: (s) => pc.green(s),
9
+ blocked: (s) => pc.red(s),
10
+ };
11
+ export async function runStatus(cwd, opts) {
12
+ const config = await loadConfig(cwd);
13
+ const db = openDB(config, cwd);
14
+ try {
15
+ const tasks = db.getTasks();
16
+ const summary = db.getStatusSummary();
17
+ if (opts.json) {
18
+ const actions = tasks.map((t) => ({
19
+ ...t,
20
+ actions: db.getActionsForTask(t.id),
21
+ acceptance: db.getTaskAcceptance(t.id),
22
+ }));
23
+ console.log(JSON.stringify({ tasks: actions, summary }, null, 2));
24
+ return;
25
+ }
26
+ if (tasks.length === 0) {
27
+ console.log(pc.dim('No tasks yet. Run: ahk task add'));
28
+ return;
29
+ }
30
+ const table = new Table({
31
+ head: ['ID', 'Slug', 'Title', 'Status', 'Assigned', 'Started'].map((h) => pc.bold(h)),
32
+ style: { head: [], border: [] },
33
+ });
34
+ for (const t of tasks) {
35
+ const colorFn = STATUS_COLOR[t.status] ?? ((s) => s);
36
+ table.push([
37
+ String(t.id),
38
+ t.slug,
39
+ t.title.slice(0, 40),
40
+ colorFn(t.status),
41
+ t.assigned_to ?? '—',
42
+ t.started_at ? t.started_at.slice(0, 10) : '—',
43
+ ]);
44
+ }
45
+ console.log(table.toString());
46
+ // Active actions
47
+ const inProgress = tasks.filter((t) => t.status === 'in_progress');
48
+ if (inProgress.length > 0) {
49
+ console.log('');
50
+ console.log(pc.bold('Active actions:'));
51
+ for (const t of inProgress) {
52
+ const actions = db.getActionsForTask(t.id);
53
+ const active = actions.filter((a) => a.status === 'in_progress');
54
+ for (const a of active) {
55
+ console.log(` ${pc.cyan(a.agent.padEnd(10))} → task #${t.id} ${t.slug}`);
56
+ }
57
+ }
58
+ }
59
+ // Summary line
60
+ console.log('');
61
+ const parts = summary.map((s) => {
62
+ const fn = STATUS_COLOR[s.status] ?? ((x) => x);
63
+ return `${fn(s.status)}: ${s.total}`;
64
+ });
65
+ console.log(pc.dim('Tasks — ') + parts.join(pc.dim(' | ')));
66
+ }
67
+ finally {
68
+ db.close();
69
+ }
70
+ }
71
+ //# sourceMappingURL=status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,YAAY,CAAA;AAC9B,OAAO,EAAE,MAAM,YAAY,CAAA;AAC3B,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AAMtC,MAAM,YAAY,GAA0C;IAC1D,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACzB,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9B,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IACxB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CAC1B,CAAA;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,GAAW,EAAE,IAAmB;IAC9D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAA;IACpC,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAE9B,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAA;QAC3B,MAAM,OAAO,GAAG,EAAE,CAAC,gBAAgB,EAAE,CAAA;QAErC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAChC,GAAG,CAAC;gBACJ,OAAO,EAAE,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;gBACnC,UAAU,EAAE,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;aACvC,CAAC,CAAC,CAAA;YACH,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YACjE,OAAM;QACR,CAAC;QAED,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC,CAAA;YACtD,OAAM;QACR,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC;YACtB,IAAI,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACrF,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE;SAChC,CAAC,CAAA;QAEF,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;YACtB,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAA;YAC5D,KAAK,CAAC,IAAI,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;gBACZ,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;gBACpB,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;gBACjB,CAAC,CAAC,WAAW,IAAI,GAAG;gBACpB,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG;aAC/C,CAAC,CAAA;QACJ,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;QAE7B,iBAAiB;QACjB,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,aAAa,CAAC,CAAA;QAClE,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;YACf,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAA;YACvC,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC;gBAC3B,MAAM,OAAO,GAAG,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;gBAC1C,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,aAAa,CAAC,CAAA;gBAChE,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;oBACvB,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAA;gBAC3E,CAAC;YACH,CAAC;QACH,CAAC;QAED,eAAe;QACf,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QACf,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAC9B,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAA;YACvD,OAAO,GAAG,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAA;QACtC,CAAC,CAAC,CAAA;QACF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IAC7D,CAAC;YAAS,CAAC;QACT,EAAE,CAAC,KAAK,EAAE,CAAA;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,7 @@
1
+ interface SyncOptions {
2
+ dryRun?: boolean;
3
+ direction?: 'in' | 'out' | 'both';
4
+ }
5
+ export declare function runSync(cwd: string, opts: SyncOptions): Promise<void>;
6
+ export {};
7
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/commands/sync.ts"],"names":[],"mappings":"AAOA,UAAU,WAAW;IACnB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,SAAS,CAAC,EAAE,IAAI,GAAG,KAAK,GAAG,MAAM,CAAA;CAClC;AAED,wBAAsB,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAkB3E"}
@@ -0,0 +1,57 @@
1
+ import pc from 'picocolors';
2
+ import { existsSync, readFileSync } from 'node:fs';
3
+ import { join, resolve } from 'node:path';
4
+ import { loadConfig } from '../core/config.js';
5
+ import { openDB } from '../core/db.js';
6
+ export async function runSync(cwd, opts) {
7
+ const config = await loadConfig(cwd);
8
+ const direction = opts.direction ?? 'both';
9
+ const featureListPath = resolve(join(cwd, config.storage.dir, 'feature_list.json'));
10
+ const db = openDB(config, cwd);
11
+ try {
12
+ if (direction === 'in' || direction === 'both') {
13
+ await syncIn(featureListPath, db, opts.dryRun ?? false);
14
+ }
15
+ if (direction === 'out' || direction === 'both') {
16
+ syncOut(db, cwd, opts.dryRun ?? false);
17
+ }
18
+ }
19
+ finally {
20
+ db.close();
21
+ }
22
+ }
23
+ async function syncIn(featureListPath, db, dryRun) {
24
+ if (!existsSync(featureListPath)) {
25
+ console.log(pc.dim(`feature_list.json not found at ${featureListPath} — skipping in-sync`));
26
+ return;
27
+ }
28
+ let seeds;
29
+ try {
30
+ seeds = JSON.parse(readFileSync(featureListPath, 'utf8'));
31
+ }
32
+ catch (err) {
33
+ console.error(pc.red(`Failed to parse feature_list.json: ${err}`));
34
+ process.exit(1);
35
+ }
36
+ if (dryRun) {
37
+ console.log(pc.bold('Dry run — in-sync (feature_list.json → SQLite):'));
38
+ for (const t of seeds) {
39
+ const existing = db.getTaskBySlug(t.slug);
40
+ console.log(` ${existing ? pc.dim('skip') : pc.green('add ')} ${t.slug}`);
41
+ }
42
+ return;
43
+ }
44
+ const result = db.syncFromFeatureList(seeds);
45
+ console.log(pc.green(`✓ In-sync: ${result.added} added, ${result.skipped} already existed`));
46
+ }
47
+ function syncOut(db, cwd, dryRun) {
48
+ if (dryRun) {
49
+ const tasks = db.getTasks();
50
+ console.log(pc.bold('Dry run — out-sync (SQLite → feature_list.json):'));
51
+ console.log(` ${tasks.length} tasks would be written`);
52
+ return;
53
+ }
54
+ db.writeFeatureList(cwd);
55
+ console.log(pc.green('✓ Out-sync: feature_list.json updated'));
56
+ }
57
+ //# sourceMappingURL=sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/commands/sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function runTaskAdd(cwd: string): Promise<void>;
2
+ //# sourceMappingURL=add.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add.d.ts","sourceRoot":"","sources":["../../../src/commands/task/add.ts"],"names":[],"mappings":"AAKA,wBAAsB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CA+C3D"}
@@ -0,0 +1,59 @@
1
+ import * as p from '@clack/prompts';
2
+ import pc from 'picocolors';
3
+ import { loadConfig } from '../../core/config.js';
4
+ import { openDB } from '../../core/db.js';
5
+ export async function runTaskAdd(cwd) {
6
+ p.intro(pc.bold('agent-harness-kit — add task'));
7
+ const titleVal = await p.text({
8
+ message: 'Task title',
9
+ validate: (v) => (v.trim() ? undefined : 'Title is required'),
10
+ });
11
+ if (p.isCancel(titleVal)) {
12
+ p.cancel('Cancelled.');
13
+ process.exit(0);
14
+ }
15
+ const title = titleVal.trim();
16
+ const descVal = await p.text({
17
+ message: 'Description (what and why)',
18
+ placeholder: 'Optional',
19
+ });
20
+ if (p.isCancel(descVal)) {
21
+ p.cancel('Cancelled.');
22
+ process.exit(0);
23
+ }
24
+ const description = descVal.trim();
25
+ const acceptance = [];
26
+ p.log.info('Acceptance criteria — one per line, empty line to finish');
27
+ while (true) {
28
+ const val = await p.text({ message: '>', placeholder: 'Criterion (or press Enter to finish)' });
29
+ if (p.isCancel(val) || !val.trim())
30
+ break;
31
+ acceptance.push(val.trim());
32
+ }
33
+ const spinner = p.spinner();
34
+ spinner.start('Saving...');
35
+ try {
36
+ const config = await loadConfig(cwd);
37
+ const db = openDB(config, cwd);
38
+ const slug = slugify(title);
39
+ const task = db.addTask({ slug, title, description: description || undefined, acceptance });
40
+ db.writeFeatureList(cwd);
41
+ db.close();
42
+ spinner.stop('');
43
+ p.outro(pc.green(`✓ Task #${task.id} added — ${task.slug} (pending)`) +
44
+ '\n → ' + pc.cyan('ahk status') + ' to see all tasks');
45
+ }
46
+ catch (err) {
47
+ spinner.stop(pc.red('Failed'));
48
+ p.log.error(err instanceof Error ? err.message : String(err));
49
+ process.exit(1);
50
+ }
51
+ }
52
+ function slugify(title) {
53
+ return title
54
+ .toLowerCase()
55
+ .replace(/[^a-z0-9]+/g, '-')
56
+ .replace(/^-+|-+$/g, '')
57
+ .slice(0, 64);
58
+ }
59
+ //# sourceMappingURL=add.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/commands/task/add.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function runTaskDone(cwd: string, idOrSlug: string): Promise<void>;
2
+ //# sourceMappingURL=done.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"done.d.ts","sourceRoot":"","sources":["../../../src/commands/task/done.ts"],"names":[],"mappings":"AAOA,wBAAsB,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAyC9E"}
@@ -0,0 +1,45 @@
1
+ import pc from 'picocolors';
2
+ import { spawnSync } from 'node:child_process';
3
+ import { existsSync } from 'node:fs';
4
+ import { resolve } from 'node:path';
5
+ import { loadConfig } from '../../core/config.js';
6
+ import { openDB } from '../../core/db.js';
7
+ export async function runTaskDone(cwd, idOrSlug) {
8
+ const config = await loadConfig(cwd);
9
+ // Run health check first if required
10
+ if (config.health.required) {
11
+ const scriptPath = resolve(cwd, config.health.scriptPath);
12
+ if (existsSync(scriptPath)) {
13
+ const result = spawnSync('bash', [scriptPath], { cwd, stdio: 'pipe', encoding: 'utf8' });
14
+ if (result.status !== 0) {
15
+ console.error(pc.red('✗ Health check failed — cannot mark task as done.'));
16
+ if (result.stdout)
17
+ console.error(result.stdout);
18
+ if (result.stderr)
19
+ console.error(result.stderr);
20
+ process.exit(1);
21
+ }
22
+ }
23
+ }
24
+ const db = openDB(config, cwd);
25
+ try {
26
+ const parsed = parseInt(idOrSlug, 10);
27
+ const isId = !isNaN(parsed);
28
+ const task = isId ? db.getTaskById(parsed) : db.getTaskBySlug(idOrSlug);
29
+ if (!task) {
30
+ console.error(pc.red(`Task not found: ${idOrSlug}`));
31
+ process.exit(1);
32
+ }
33
+ if (task.status === 'done') {
34
+ console.log(pc.dim(`Task #${task.id} is already done.`));
35
+ return;
36
+ }
37
+ db.updateTaskStatus(task.id, 'done');
38
+ db.writeFeatureList(cwd);
39
+ console.log(pc.green(`✓ Task #${task.id} — ${task.slug} marked as done`));
40
+ }
41
+ finally {
42
+ db.close();
43
+ }
44
+ }
45
+ //# sourceMappingURL=done.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"done.js","sourceRoot":"","sources":["../../../src/commands/task/done.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,YAAY,CAAA;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,GAAW,EAAE,QAAgB;IAC7D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAA;IAEpC,qCAAqC;IACrC,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAC3B,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;QACzD,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAA;YACxF,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACxB,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC,CAAA;gBAC1E,IAAI,MAAM,CAAC,MAAM;oBAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;gBAC/C,IAAI,MAAM,CAAC,MAAM;oBAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;gBAC/C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACjB,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAE9B,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAA;QACrC,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvE,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,mBAAmB,QAAQ,EAAE,CAAC,CAAC,CAAA;YACpD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAA;YACxD,OAAM;QACR,CAAC;QAED,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;QACpC,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAA;QAExB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,EAAE,MAAM,IAAI,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAA;IAC3E,CAAC;YAAS,CAAC;QACT,EAAE,CAAC,KAAK,EAAE,CAAA;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { runTaskAdd } from './add.js';
2
+ export { runTaskList } from './list.js';
3
+ export { runTaskDone } from './done.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA"}
@@ -0,0 +1,4 @@
1
+ export { runTaskAdd } from './add.js';
2
+ export { runTaskList } from './list.js';
3
+ export { runTaskDone } from './done.js';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/commands/task/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA"}