copilot-agent 0.3.0 → 0.5.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/dist/index.js CHANGED
@@ -133,6 +133,7 @@ function findLatestIncomplete() {
133
133
 
134
134
  // src/lib/process.ts
135
135
  import { execSync as execSync2, spawn } from "child_process";
136
+ import { resolve as resolve2 } from "path";
136
137
 
137
138
  // src/lib/logger.ts
138
139
  import { appendFileSync, mkdirSync } from "fs";
@@ -241,11 +242,19 @@ function findCopilotProcesses() {
241
242
  if (pid === myPid || pid === parentPid) continue;
242
243
  const cmd = match[2];
243
244
  const sidMatch = cmd.match(/resume[= ]+([a-f0-9-]{36})/);
244
- results.push({
245
- pid,
246
- command: cmd,
247
- sessionId: sidMatch?.[1]
248
- });
245
+ let cwd;
246
+ try {
247
+ cwd = execSync2(`lsof -p ${pid} -Fn 2>/dev/null | grep '^n/' | head -1`, {
248
+ encoding: "utf-8",
249
+ stdio: ["pipe", "pipe", "pipe"]
250
+ }).trim().slice(1) || void 0;
251
+ } catch {
252
+ }
253
+ const sid = sidMatch?.[1];
254
+ if (!cwd && sid) {
255
+ cwd = getSessionCwd(sid) || void 0;
256
+ }
257
+ results.push({ pid, command: cmd, sessionId: sid, cwd });
249
258
  }
250
259
  }
251
260
  }
@@ -259,22 +268,27 @@ function findPidForSession(sid) {
259
268
  const matching = procs.filter((p) => p.command.includes(sid)).sort((a, b) => b.pid - a.pid);
260
269
  return matching[0]?.pid ?? null;
261
270
  }
262
- async function waitForAllCopilotToFinish(timeoutMs = 144e5, pollMs = 1e4) {
271
+ async function waitForCopilotInDir(dir, timeoutMs = 144e5, pollMs = 1e4) {
272
+ const targetDir = resolve2(dir);
263
273
  const start = Date.now();
264
274
  let warned = false;
265
275
  while (Date.now() - start < timeoutMs) {
266
276
  const procs = findCopilotProcesses();
267
- if (procs.length === 0) return;
277
+ const conflicting = procs.filter((p) => {
278
+ if (!p.cwd) return false;
279
+ return resolve2(p.cwd) === targetDir;
280
+ });
281
+ if (conflicting.length === 0) return;
268
282
  if (!warned) {
269
- warn(`Waiting for ${procs.length} copilot process(es) to finish before starting...`);
270
- for (const p of procs) {
283
+ warn(`Waiting for copilot in ${targetDir} to finish...`);
284
+ for (const p of conflicting) {
271
285
  log(` PID ${p.pid}: ${p.command.slice(0, 80)}`);
272
286
  }
273
287
  warned = true;
274
288
  }
275
289
  await sleep(pollMs);
276
290
  }
277
- warn("Timeout waiting for copilot processes to finish");
291
+ warn("Timeout waiting for copilot to finish in directory");
278
292
  }
279
293
  function assertSessionNotRunning(sid) {
280
294
  const pid = findPidForSession(sid);
@@ -296,8 +310,12 @@ async function waitForExit(pid, timeoutMs = 144e5) {
296
310
  return false;
297
311
  }
298
312
  async function runCopilot(args, options) {
299
- await waitForAllCopilotToFinish();
300
- return new Promise((resolve4) => {
313
+ const dir = options?.cwd ?? process.cwd();
314
+ if (options?.useWorktree) {
315
+ } else {
316
+ await waitForCopilotInDir(dir);
317
+ }
318
+ return new Promise((resolve6) => {
301
319
  const child = spawn("copilot", args, {
302
320
  cwd: options?.cwd,
303
321
  stdio: "inherit",
@@ -307,14 +325,14 @@ async function runCopilot(args, options) {
307
325
  await sleep(3e3);
308
326
  const sid = getLatestSessionId();
309
327
  const premium = sid ? getSessionPremium(sid) : 0;
310
- resolve4({
328
+ resolve6({
311
329
  exitCode: code ?? 1,
312
330
  sessionId: sid,
313
331
  premium
314
332
  });
315
333
  });
316
334
  child.on("error", () => {
317
- resolve4({ exitCode: 1, sessionId: null, premium: 0 });
335
+ resolve6({ exitCode: 1, sessionId: null, premium: 0 });
318
336
  });
319
337
  });
320
338
  }
@@ -331,7 +349,7 @@ function runCopilotResume(sid, steps, message, cwd) {
331
349
  if (message) args.push("-p", message);
332
350
  return runCopilot(args, { cwd });
333
351
  }
334
- function runCopilotTask(prompt, steps, cwd) {
352
+ function runCopilotTask(prompt, steps, cwd, useWorktree) {
335
353
  return runCopilot([
336
354
  "-p",
337
355
  prompt,
@@ -340,7 +358,7 @@ function runCopilotTask(prompt, steps, cwd) {
340
358
  "--max-autopilot-continues",
341
359
  String(steps),
342
360
  "--no-ask-user"
343
- ], { cwd });
361
+ ], { cwd, useWorktree });
344
362
  }
345
363
  function sleep(ms) {
346
364
  return new Promise((r) => setTimeout(r, ms));
@@ -480,7 +498,7 @@ function sleep2(ms) {
480
498
 
481
499
  // src/lib/detect.ts
482
500
  import { existsSync as existsSync2, readFileSync as readFileSync2, readdirSync as readdirSync2 } from "fs";
483
- import { join as join2, basename, resolve as resolve2 } from "path";
501
+ import { join as join2, basename, resolve as resolve3 } from "path";
484
502
  import { execSync as execSync3 } from "child_process";
485
503
  function detectProjectType(dir) {
486
504
  const exists = (f) => existsSync2(join2(dir, f));
@@ -525,7 +543,7 @@ function detectProjectName(dir) {
525
543
  if (pkg.name) return pkg.name;
526
544
  } catch {
527
545
  }
528
- return basename(resolve2(dir));
546
+ return basename(resolve3(dir));
529
547
  }
530
548
  function detectMainBranch(dir) {
531
549
  try {
@@ -703,7 +721,7 @@ async function withLock(name, fn) {
703
721
 
704
722
  // src/lib/git.ts
705
723
  import { existsSync as existsSync4 } from "fs";
706
- import { join as join4 } from "path";
724
+ import { join as join4, resolve as resolve4 } from "path";
707
725
  import { execSync as execSync4 } from "child_process";
708
726
  function gitExec(dir, cmd) {
709
727
  try {
@@ -739,16 +757,34 @@ function gitCountCommits(dir, from, to) {
739
757
  function gitStatus(dir) {
740
758
  return gitExec(dir, "git status --porcelain") ?? "";
741
759
  }
760
+ function createWorktree(repoDir, branch) {
761
+ const safeBranch = branch.replace(/[^a-zA-Z0-9._/-]/g, "-");
762
+ const worktreePath = resolve4(repoDir, "..", `${resolve4(repoDir).split("/").pop()}-wt-${safeBranch}`);
763
+ if (existsSync4(worktreePath)) {
764
+ return worktreePath;
765
+ }
766
+ const branchExists = gitExec(repoDir, `git rev-parse --verify ${safeBranch}`) !== null;
767
+ const cmd = branchExists ? `git worktree add "${worktreePath}" ${safeBranch}` : `git worktree add -b ${safeBranch} "${worktreePath}"`;
768
+ if (gitExec(repoDir, cmd) !== null) {
769
+ return worktreePath;
770
+ }
771
+ return null;
772
+ }
773
+ function removeWorktree(repoDir, worktreePath) {
774
+ const result = gitExec(repoDir, `git worktree remove "${worktreePath}" --force`);
775
+ return result !== null;
776
+ }
742
777
 
743
778
  // src/commands/run.ts
744
779
  function registerRunCommand(program2) {
745
- program2.command("run [dir]").description("Discover and fix issues in a project").option("-s, --steps <n>", "Max autopilot continues per task", "30").option("-t, --max-tasks <n>", "Max number of tasks to run", "5").option("-p, --max-premium <n>", "Max total premium requests", "50").option("--dry-run", "Show tasks without executing").action(async (dir, opts) => {
780
+ program2.command("run [dir]").description("Discover and fix issues in a project").option("-s, --steps <n>", "Max autopilot continues per task", "30").option("-t, --max-tasks <n>", "Max number of tasks to run", "5").option("-p, --max-premium <n>", "Max total premium requests", "50").option("--dry-run", "Show tasks without executing").option("--worktree", "Use git worktree for parallel execution (default: wait for idle)").action(async (dir, opts) => {
746
781
  try {
747
782
  await runCommand(dir ?? process.cwd(), {
748
783
  steps: parseInt(opts.steps, 10),
749
784
  maxTasks: parseInt(opts.maxTasks, 10),
750
785
  maxPremium: parseInt(opts.maxPremium, 10),
751
- dryRun: opts.dryRun ?? false
786
+ dryRun: opts.dryRun ?? false,
787
+ useWorktree: opts.worktree ?? false
752
788
  });
753
789
  } catch (err) {
754
790
  fail(`Run error: ${err instanceof Error ? err.message : err}`);
@@ -799,15 +835,35 @@ ${"\u2550".repeat(60)}`);
799
835
  }
800
836
  }
801
837
  info(`Running: ${task.title}\u2026`);
838
+ let taskDir = dir;
839
+ let worktreeCreated = false;
840
+ if (opts.useWorktree && isGitRepo(dir)) {
841
+ try {
842
+ taskDir = createWorktree(dir, branchName, mainBranch ?? void 0);
843
+ worktreeCreated = true;
844
+ info(`Created worktree: ${taskDir}`);
845
+ } catch (err) {
846
+ warn(`Worktree creation failed, falling back to main dir: ${err}`);
847
+ taskDir = dir;
848
+ }
849
+ }
802
850
  const result = await withLock(
803
851
  "copilot-run",
804
- () => runCopilotTask(task.prompt, opts.steps, dir)
852
+ () => runCopilotTask(task.prompt, opts.steps, taskDir, opts.useWorktree)
805
853
  );
806
- const commits = mainBranch ? gitCountCommits(dir, mainBranch, "HEAD") : 0;
854
+ const commitRef = worktreeCreated ? taskDir : dir;
855
+ const commits = mainBranch ? gitCountCommits(commitRef, mainBranch, "HEAD") : 0;
807
856
  premiumTotal += result.premium;
808
857
  completed++;
809
858
  ok(`${task.title} \u2014 ${commits} commit(s), ${result.premium} premium`);
810
- if (originalBranch && isGitRepo(dir)) {
859
+ if (worktreeCreated) {
860
+ try {
861
+ removeWorktree(dir, taskDir);
862
+ } catch (err) {
863
+ warn(`Worktree cleanup failed: ${err}`);
864
+ }
865
+ }
866
+ if (!worktreeCreated && originalBranch && isGitRepo(dir)) {
811
867
  gitCheckout(dir, mainBranch ?? originalBranch);
812
868
  }
813
869
  }
@@ -821,14 +877,15 @@ ${BOLD}\u2550\u2550\u2550 Run Summary \u2550\u2550\u2550${RESET}`);
821
877
  import { join as join5 } from "path";
822
878
  import { homedir as homedir3 } from "os";
823
879
  function registerOvernightCommand(program2) {
824
- program2.command("overnight [dir]").description("Run tasks continuously until a deadline").option("-u, --until <HH>", "Stop at this hour (24h format)", "07").option("-s, --steps <n>", "Max autopilot continues per task", "50").option("-c, --cooldown <n>", "Seconds between tasks", "15").option("-p, --max-premium <n>", "Max premium requests budget", "300").option("--dry-run", "Show plan without executing").action(async (dir, opts) => {
880
+ program2.command("overnight [dir]").description("Run tasks continuously until a deadline").option("-u, --until <HH>", "Stop at this hour (24h format)", "07").option("-s, --steps <n>", "Max autopilot continues per task", "50").option("-c, --cooldown <n>", "Seconds between tasks", "15").option("-p, --max-premium <n>", "Max premium requests budget", "300").option("--dry-run", "Show plan without executing").option("--worktree", "Use git worktree for parallel execution (default: wait for idle)").action(async (dir, opts) => {
825
881
  try {
826
882
  await overnightCommand(dir ?? process.cwd(), {
827
883
  until: parseInt(opts.until, 10),
828
884
  steps: parseInt(opts.steps, 10),
829
885
  cooldown: parseInt(opts.cooldown, 10),
830
886
  maxPremium: parseInt(opts.maxPremium, 10),
831
- dryRun: opts.dryRun ?? false
887
+ dryRun: opts.dryRun ?? false,
888
+ useWorktree: opts.worktree ?? false
832
889
  });
833
890
  } catch (err) {
834
891
  fail(`Overnight error: ${err instanceof Error ? err.message : err}`);
@@ -903,12 +960,25 @@ ${"\u2550".repeat(60)}`);
903
960
  gitCreateBranch(dir, branchName);
904
961
  }
905
962
  info(`Running: ${task.title}\u2026`);
963
+ let taskDir = dir;
964
+ let worktreeCreated = false;
965
+ if (opts.useWorktree && isGitRepo(dir)) {
966
+ try {
967
+ taskDir = createWorktree(dir, branchName, mainBranch ?? void 0);
968
+ worktreeCreated = true;
969
+ info(`Created worktree: ${taskDir}`);
970
+ } catch (err) {
971
+ warn(`Worktree creation failed, falling back to main dir: ${err}`);
972
+ taskDir = dir;
973
+ }
974
+ }
906
975
  try {
907
976
  const result = await withLock(
908
977
  "copilot-overnight",
909
- () => runCopilotTask(task.prompt, opts.steps, dir)
978
+ () => runCopilotTask(task.prompt, opts.steps, taskDir, opts.useWorktree)
910
979
  );
911
- const commits = mainBranch ? gitCountCommits(dir, mainBranch, "HEAD") : 0;
980
+ const commitRef = worktreeCreated ? taskDir : dir;
981
+ const commits = mainBranch ? gitCountCommits(commitRef, mainBranch, "HEAD") : 0;
912
982
  totalPremium += result.premium;
913
983
  totalCommits += commits;
914
984
  if (commits > 0) {
@@ -919,7 +989,15 @@ ${"\u2550".repeat(60)}`);
919
989
  } catch (err) {
920
990
  fail(`Task failed: ${err}`);
921
991
  }
922
- if (mainBranch && isGitRepo(dir)) {
992
+ if (worktreeCreated) {
993
+ try {
994
+ removeWorktree(dir, taskDir);
995
+ info(`Removed worktree: ${taskDir}`);
996
+ } catch (err) {
997
+ warn(`Worktree cleanup failed: ${err}`);
998
+ }
999
+ }
1000
+ if (!worktreeCreated && mainBranch && isGitRepo(dir)) {
923
1001
  gitCheckout(dir, mainBranch);
924
1002
  }
925
1003
  if (!isPastDeadline(opts.until)) {
@@ -940,7 +1018,7 @@ function sleep3(ms) {
940
1018
 
941
1019
  // src/commands/research.ts
942
1020
  import { existsSync as existsSync5, copyFileSync, mkdirSync as mkdirSync3 } from "fs";
943
- import { join as join6, resolve as resolve3 } from "path";
1021
+ import { join as join6, resolve as resolve5 } from "path";
944
1022
  import { homedir as homedir4 } from "os";
945
1023
  function registerResearchCommand(program2) {
946
1024
  program2.command("research [project]").description("Research improvements or a specific topic").option("-s, --steps <n>", "Max autopilot continues", "50").action(async (project, opts) => {
@@ -976,7 +1054,7 @@ Write RESEARCH-PROPOSALS.md in the project root.`;
976
1054
  }
977
1055
  async function researchCommand(dir, opts) {
978
1056
  assertCopilot();
979
- const projectDir = resolve3(dir);
1057
+ const projectDir = resolve5(dir);
980
1058
  const projectType = detectProjectType(projectDir);
981
1059
  const projectName = detectProjectName(projectDir);
982
1060
  info(`Researching: ${CYAN}${projectName}${RESET} (${projectType})`);
@@ -1003,7 +1081,7 @@ async function researchCommand(dir, opts) {
1003
1081
 
1004
1082
  // src/index.ts
1005
1083
  var program = new Command();
1006
- program.name("copilot-agent").version("0.3.0").description("Autonomous GitHub Copilot CLI agent \u2014 auto-resume, task discovery, overnight runs");
1084
+ program.name("copilot-agent").version("0.5.0").description("Autonomous GitHub Copilot CLI agent \u2014 auto-resume, task discovery, overnight runs");
1007
1085
  registerStatusCommand(program);
1008
1086
  registerWatchCommand(program);
1009
1087
  registerRunCommand(program);
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/lib/session.ts","../src/lib/process.ts","../src/lib/logger.ts","../src/lib/colors.ts","../src/commands/status.ts","../src/commands/watch.ts","../src/lib/detect.ts","../src/lib/tasks.ts","../src/lib/lock.ts","../src/lib/git.ts","../src/commands/run.ts","../src/commands/overnight.ts","../src/commands/research.ts"],"sourcesContent":["import { Command } from 'commander';\nimport { registerStatusCommand } from './commands/status.js';\nimport { registerWatchCommand } from './commands/watch.js';\nimport { registerRunCommand } from './commands/run.js';\nimport { registerOvernightCommand } from './commands/overnight.js';\nimport { registerResearchCommand } from './commands/research.js';\n\nconst program = new Command();\n\nprogram\n .name('copilot-agent')\n .version('0.3.0')\n .description('Autonomous GitHub Copilot CLI agent — auto-resume, task discovery, overnight runs');\n\nregisterStatusCommand(program);\nregisterWatchCommand(program);\nregisterRunCommand(program);\nregisterOvernightCommand(program);\nregisterResearchCommand(program);\n\nprogram.parse();\n","import {\n existsSync,\n readdirSync,\n readFileSync,\n statSync,\n} from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { homedir } from 'node:os';\n\nexport interface Session {\n id: string;\n dir: string;\n mtime: number;\n lastEvent: string;\n premiumRequests: number;\n summary: string;\n cwd: string;\n complete: boolean;\n}\n\nconst SESSION_DIR = join(homedir(), '.copilot', 'session-state');\n\nexport function getSessionDir(): string {\n return SESSION_DIR;\n}\n\nexport function validateSession(sid: string): boolean {\n const events = join(SESSION_DIR, sid, 'events.jsonl');\n try {\n return existsSync(events) && statSync(events).size > 0;\n } catch {\n return false;\n }\n}\n\nexport function listSessions(limit = 20): Session[] {\n if (!existsSync(SESSION_DIR)) return [];\n\n const entries = readdirSync(SESSION_DIR, { withFileTypes: true })\n .filter(d => d.isDirectory());\n\n const dirs: { id: string; dir: string; mtime: number }[] = [];\n for (const entry of entries) {\n const dirPath = join(SESSION_DIR, entry.name);\n if (!existsSync(join(dirPath, 'events.jsonl'))) continue;\n try {\n const stat = statSync(dirPath);\n dirs.push({ id: entry.name, dir: dirPath, mtime: stat.mtimeMs });\n } catch { /* skip */ }\n }\n\n dirs.sort((a, b) => b.mtime - a.mtime);\n\n return dirs.slice(0, limit).map(s => ({\n id: s.id,\n dir: s.dir,\n mtime: s.mtime,\n lastEvent: getLastEvent(s.id),\n premiumRequests: getSessionPremium(s.id),\n summary: getSessionSummary(s.id),\n cwd: getSessionCwd(s.id),\n complete: hasTaskComplete(s.id),\n }));\n}\n\nexport function getLatestSessionId(): string | null {\n if (!existsSync(SESSION_DIR)) return null;\n\n const entries = readdirSync(SESSION_DIR, { withFileTypes: true })\n .filter(d => d.isDirectory());\n\n let latest: { id: string; mtime: number } | null = null;\n for (const entry of entries) {\n try {\n const stat = statSync(join(SESSION_DIR, entry.name));\n if (!latest || stat.mtimeMs > latest.mtime) {\n latest = { id: entry.name, mtime: stat.mtimeMs };\n }\n } catch { /* skip */ }\n }\n return latest?.id ?? null;\n}\n\nexport function hasTaskComplete(sid: string): boolean {\n if (!validateSession(sid)) return false;\n try {\n const content = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8');\n return content.includes('\"session.task_complete\"');\n } catch {\n return false;\n }\n}\n\nexport function getLastEvent(sid: string): string {\n if (!validateSession(sid)) return 'invalid';\n try {\n const lines = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8')\n .trimEnd()\n .split('\\n');\n const last = JSON.parse(lines[lines.length - 1]);\n return last.type ?? 'unknown';\n } catch {\n return 'corrupted';\n }\n}\n\nexport function getSessionPremium(sid: string): number {\n if (!validateSession(sid)) return 0;\n try {\n const content = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8');\n const lines = content.trimEnd().split('\\n');\n for (let i = lines.length - 1; i >= 0; i--) {\n try {\n const event = JSON.parse(lines[i]);\n if (event.type === 'session.shutdown' && event.data?.totalPremiumRequests != null) {\n return event.data.totalPremiumRequests;\n }\n } catch { /* skip malformed line */ }\n }\n return 0;\n } catch {\n return 0;\n }\n}\n\nfunction parseSimpleYaml(content: string): Record<string, string> {\n const result: Record<string, string> = {};\n for (const line of content.split('\\n')) {\n const idx = line.indexOf(': ');\n if (idx === -1) continue;\n const key = line.substring(0, idx).trim();\n const value = line.substring(idx + 2).trim();\n if (key) result[key] = value;\n }\n return result;\n}\n\nfunction readWorkspace(sid: string): Record<string, string> {\n const wsPath = join(SESSION_DIR, sid, 'workspace.yaml');\n if (!existsSync(wsPath)) return {};\n try {\n return parseSimpleYaml(readFileSync(wsPath, 'utf-8'));\n } catch {\n return {};\n }\n}\n\nexport function getSessionSummary(sid: string): string {\n return readWorkspace(sid).summary ?? '';\n}\n\nexport function getSessionCwd(sid: string): string {\n return readWorkspace(sid).cwd ?? '';\n}\n\nexport function findSessionForProject(projectPath: string): string | null {\n const resolved = resolve(projectPath);\n const sessions = listSessions(50);\n for (const s of sessions) {\n if (s.cwd && resolve(s.cwd) === resolved) return s.id;\n }\n return null;\n}\n\nexport function findLatestIncomplete(): string | null {\n const sessions = listSessions(50);\n for (const s of sessions) {\n if (!s.complete) return s.id;\n }\n return null;\n}\n","import { execSync, spawn } from 'node:child_process';\nimport { getLatestSessionId, getSessionPremium } from './session.js';\nimport { log, warn, fail } from './logger.js';\n\nexport interface CopilotProcess {\n pid: number;\n command: string;\n sessionId?: string;\n}\n\nexport interface CopilotResult {\n exitCode: number;\n sessionId: string | null;\n premium: number;\n}\n\nexport function isCopilotInstalled(): boolean {\n try {\n execSync('which copilot', { stdio: 'pipe', encoding: 'utf-8' });\n return true;\n } catch {\n return false;\n }\n}\n\nexport function assertCopilot(): void {\n if (!isCopilotInstalled()) {\n fail('copilot CLI not found. Install with: npm i -g @githubnext/copilot');\n process.exit(1);\n }\n}\n\nexport function findCopilotProcesses(): CopilotProcess[] {\n try {\n const output = execSync('ps -eo pid,command', { encoding: 'utf-8' });\n const results: CopilotProcess[] = [];\n const myPid = process.pid;\n const parentPid = process.ppid;\n for (const line of output.split('\\n')) {\n const trimmed = line.trim();\n if (!trimmed) continue;\n if (\n (trimmed.includes('copilot') || trimmed.includes('@githubnext/copilot')) &&\n !trimmed.includes('ps -eo') &&\n !trimmed.includes('copilot-agent') &&\n !trimmed.includes('grep')\n ) {\n const match = trimmed.match(/^(\\d+)\\s+(.+)$/);\n if (match) {\n const pid = parseInt(match[1], 10);\n // Exclude our own process tree\n if (pid === myPid || pid === parentPid) continue;\n const cmd = match[2];\n const sidMatch = cmd.match(/resume[= ]+([a-f0-9-]{36})/);\n results.push({\n pid,\n command: cmd,\n sessionId: sidMatch?.[1],\n });\n }\n }\n }\n return results;\n } catch {\n return [];\n }\n}\n\nexport function findPidForSession(sid: string): number | null {\n const procs = findCopilotProcesses();\n const matching = procs\n .filter(p => p.command.includes(sid))\n .sort((a, b) => b.pid - a.pid);\n return matching[0]?.pid ?? null;\n}\n\n/**\n * SAFETY: Wait until no other copilot processes are running.\n * Prevents race conditions from concurrent copilot instances.\n */\nexport async function waitForAllCopilotToFinish(\n timeoutMs = 14_400_000,\n pollMs = 10_000,\n): Promise<void> {\n const start = Date.now();\n let warned = false;\n while (Date.now() - start < timeoutMs) {\n const procs = findCopilotProcesses();\n if (procs.length === 0) return;\n if (!warned) {\n warn(`Waiting for ${procs.length} copilot process(es) to finish before starting...`);\n for (const p of procs) {\n log(` PID ${p.pid}: ${p.command.slice(0, 80)}`);\n }\n warned = true;\n }\n await sleep(pollMs);\n }\n warn('Timeout waiting for copilot processes to finish');\n}\n\n/**\n * SAFETY: Check if a session already has a running copilot process.\n * If so, refuse to spawn another one to prevent corruption.\n */\nexport function assertSessionNotRunning(sid: string): void {\n const pid = findPidForSession(sid);\n if (pid) {\n fail(`Session ${sid.slice(0, 8)}… already has copilot running (PID ${pid}). Cannot resume — would corrupt the session.`);\n process.exit(1);\n }\n}\n\nexport async function waitForExit(pid: number, timeoutMs = 14_400_000): Promise<boolean> {\n const start = Date.now();\n while (Date.now() - start < timeoutMs) {\n try {\n process.kill(pid, 0);\n await sleep(5000);\n } catch {\n return true; // process exited\n }\n }\n return false; // timeout\n}\n\nexport async function runCopilot(\n args: string[],\n options?: { cwd?: string },\n): Promise<CopilotResult> {\n // SAFETY: Wait for all existing copilot processes to finish first\n await waitForAllCopilotToFinish();\n\n return new Promise((resolve) => {\n const child = spawn('copilot', args, {\n cwd: options?.cwd,\n stdio: 'inherit',\n env: { ...process.env },\n });\n\n child.on('close', async (code) => {\n await sleep(3000); // let events flush\n const sid = getLatestSessionId();\n const premium = sid ? getSessionPremium(sid) : 0;\n resolve({\n exitCode: code ?? 1,\n sessionId: sid,\n premium,\n });\n });\n\n child.on('error', () => {\n resolve({ exitCode: 1, sessionId: null, premium: 0 });\n });\n });\n}\n\nexport function runCopilotResume(\n sid: string,\n steps: number,\n message?: string,\n cwd?: string,\n): Promise<CopilotResult> {\n // SAFETY: Refuse if session already running\n assertSessionNotRunning(sid);\n\n const args = [\n `--resume=${sid}`,\n '--autopilot',\n '--allow-all',\n '--max-autopilot-continues',\n String(steps),\n '--no-ask-user',\n ];\n if (message) args.push('-p', message);\n return runCopilot(args, { cwd });\n}\n\nexport function runCopilotTask(\n prompt: string,\n steps: number,\n cwd?: string,\n): Promise<CopilotResult> {\n return runCopilot([\n '-p', prompt,\n '--autopilot',\n '--allow-all',\n '--max-autopilot-continues', String(steps),\n '--no-ask-user',\n ], { cwd });\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import { appendFileSync, mkdirSync } from 'node:fs';\nimport { dirname } from 'node:path';\nimport { execSync } from 'node:child_process';\nimport { RED, GREEN, YELLOW, CYAN, DIM, RESET } from './colors.js';\n\nlet logFilePath: string | null = null;\n\nconst ANSI_RE =\n /[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g;\n\nfunction stripAnsi(s: string): string {\n return s.replace(ANSI_RE, '');\n}\n\nfunction writeToFile(msg: string): void {\n if (!logFilePath) return;\n try {\n appendFileSync(logFilePath, stripAnsi(msg) + '\\n');\n } catch { /* ignore file write errors */ }\n}\n\nexport function setLogFile(path: string): void {\n mkdirSync(dirname(path), { recursive: true });\n logFilePath = path;\n}\n\nexport function log(msg: string): void {\n console.log(msg);\n writeToFile(msg);\n}\n\nexport function warn(msg: string): void {\n const out = `${YELLOW}⚠ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`⚠ ${msg}`);\n}\n\nexport function ok(msg: string): void {\n const out = `${GREEN}✔ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`✔ ${msg}`);\n}\n\nexport function fail(msg: string): void {\n const out = `${RED}✖ ${msg}${RESET}`;\n console.error(out);\n writeToFile(`✖ ${msg}`);\n}\n\nexport function info(msg: string): void {\n const out = `${CYAN}ℹ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`ℹ ${msg}`);\n}\n\nexport function dim(msg: string): void {\n const out = `${DIM}${msg}${RESET}`;\n console.log(out);\n writeToFile(msg);\n}\n\nexport function notify(message: string, title = 'copilot-agent'): void {\n try {\n if (process.platform === 'darwin') {\n execSync(\n `osascript -e 'display notification \"${message.replace(/\"/g, '\\\\\"')}\" with title \"${title.replace(/\"/g, '\\\\\"')}\"'`,\n { stdio: 'ignore' },\n );\n } else {\n try {\n execSync('which notify-send', { stdio: 'pipe' });\n execSync(\n `notify-send \"${title}\" \"${message.replace(/\"/g, '\\\\\"')}\"`,\n { stdio: 'ignore' },\n );\n } catch { /* notify-send not available */ }\n }\n } catch { /* notification not available */ }\n}\n","export const RED = '\\x1b[31m';\nexport const GREEN = '\\x1b[32m';\nexport const YELLOW = '\\x1b[33m';\nexport const BLUE = '\\x1b[34m';\nexport const CYAN = '\\x1b[36m';\nexport const DIM = '\\x1b[2m';\nexport const BOLD = '\\x1b[1m';\nexport const RESET = '\\x1b[0m';\n","import type { Command } from 'commander';\nimport {\n listSessions,\n hasTaskComplete,\n getLastEvent,\n getSessionPremium,\n} from '../lib/session.js';\nimport { findCopilotProcesses } from '../lib/process.js';\nimport { log } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, GREEN, YELLOW, RESET } from '../lib/colors.js';\n\nexport function registerStatusCommand(program: Command): void {\n program\n .command('status')\n .description('Show copilot session status')\n .option('-l, --limit <n>', 'Number of sessions to show', '10')\n .option('-a, --active', 'Show only active (running) processes')\n .option('-i, --incomplete', 'Only show incomplete sessions')\n .action((opts) => {\n if (opts.active) {\n showActive();\n } else {\n showRecent(parseInt(opts.limit, 10), opts.incomplete ?? false);\n }\n });\n}\n\nfunction showActive(): void {\n const procs = findCopilotProcesses();\n if (procs.length === 0) {\n log(`${DIM}No active copilot processes.${RESET}`);\n return;\n }\n\n log(`\\n${BOLD}${'PID'.padEnd(8)} ${'Session'.padEnd(40)} Command${RESET}`);\n log('─'.repeat(108));\n\n for (const p of procs) {\n log(\n `${CYAN}${String(p.pid).padEnd(8)}${RESET} ${(p.sessionId ?? '—').padEnd(40)} ${truncate(p.command, 58)}`,\n );\n }\n log('');\n}\n\nfunction showRecent(limit: number, incompleteOnly: boolean): void {\n let sessions = listSessions(limit);\n if (incompleteOnly) {\n sessions = sessions.filter(s => !s.complete);\n }\n\n if (sessions.length === 0) {\n log(`${DIM}No sessions found.${RESET}`);\n return;\n }\n\n log(\n `\\n${BOLD}${'Status'.padEnd(10)} ${'Premium'.padEnd(10)} ${'Last Event'.padEnd(25)} ${'Summary'.padEnd(40)} ID${RESET}`,\n );\n log('─'.repeat(120));\n\n for (const s of sessions) {\n const status = s.complete\n ? `${GREEN}✔ done${RESET}`\n : `${YELLOW}⏸ stop${RESET}`;\n const premium = String(s.premiumRequests);\n const summary = truncate(s.summary || '—', 38);\n\n log(\n `${status.padEnd(10 + 9)} ${premium.padEnd(10)} ${s.lastEvent.padEnd(25)} ${summary.padEnd(40)} ${DIM}${s.id}${RESET}`,\n );\n }\n log(`\\n${DIM}Total: ${sessions.length} session(s)${RESET}`);\n}\n\nfunction truncate(s: string, max: number): string {\n if (s.length <= max) return s;\n return s.substring(0, max - 1) + '…';\n}\n","import type { Command } from 'commander';\nimport {\n validateSession,\n hasTaskComplete,\n getSessionSummary,\n getLastEvent,\n findLatestIncomplete,\n getSessionCwd,\n} from '../lib/session.js';\nimport {\n findPidForSession,\n waitForExit,\n runCopilotResume,\n assertCopilot,\n} from '../lib/process.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { CYAN, RESET } from '../lib/colors.js';\n\nexport function registerWatchCommand(program: Command): void {\n program\n .command('watch [session-id]')\n .description('Watch a session and auto-resume when it stops')\n .option('-s, --steps <n>', 'Max autopilot continues per resume', '30')\n .option('-r, --max-resumes <n>', 'Max number of resumes', '10')\n .option('-c, --cooldown <n>', 'Seconds between resumes', '10')\n .option('-m, --message <msg>', 'Message to send on resume')\n .action(async (sid: string | undefined, opts) => {\n try {\n await watchCommand(sid, {\n steps: parseInt(opts.steps, 10),\n maxResumes: parseInt(opts.maxResumes, 10),\n cooldown: parseInt(opts.cooldown, 10),\n message: opts.message,\n });\n } catch (err) {\n fail(`Watch error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface WatchOptions {\n steps: number;\n maxResumes: number;\n cooldown: number;\n message?: string;\n}\n\nasync function watchCommand(sid: string | undefined, opts: WatchOptions): Promise<void> {\n assertCopilot();\n\n if (!sid) {\n sid = findLatestIncomplete() ?? undefined;\n if (!sid) {\n fail('No incomplete session found.');\n process.exit(1);\n }\n info(`Auto-detected incomplete session: ${CYAN}${sid}${RESET}`);\n }\n\n if (!validateSession(sid)) {\n fail(`Invalid session: ${sid}`);\n process.exit(1);\n }\n\n if (hasTaskComplete(sid)) {\n ok(`Session ${sid} already completed.`);\n return;\n }\n\n let resumes = 0;\n\n while (resumes < opts.maxResumes) {\n const pid = findPidForSession(sid);\n\n if (pid) {\n info(`Watching PID ${pid} for session ${CYAN}${sid.slice(0, 8)}${RESET}…`);\n const exited = await waitForExit(pid);\n\n if (!exited) {\n warn('Timeout waiting for process exit.');\n break;\n }\n }\n\n // Small delay for events to flush\n await sleep(3000);\n\n if (hasTaskComplete(sid)) {\n ok(`Task complete! Summary: ${getSessionSummary(sid) || 'none'}`);\n notify('Task completed!', `Session ${sid.slice(0, 8)}`);\n return;\n }\n\n // Interrupted — resume\n resumes++;\n log(`Session interrupted (${getLastEvent(sid)}). Resume ${resumes}/${opts.maxResumes}…`);\n\n if (opts.cooldown > 0 && resumes > 1) {\n info(`Cooldown ${opts.cooldown}s...`);\n await sleep(opts.cooldown * 1000);\n }\n\n const cwd = getSessionCwd(sid) || undefined;\n const result = await runCopilotResume(\n sid,\n opts.steps,\n opts.message ?? 'Continue remaining work. Pick up where you left off and complete the task.',\n cwd,\n );\n\n if (result.sessionId && result.sessionId !== sid) {\n info(`New session created: ${CYAN}${result.sessionId}${RESET}`);\n sid = result.sessionId;\n }\n }\n\n warn(`Max resumes (${opts.maxResumes}) reached.`);\n notify('Max resumes reached', `Session ${sid.slice(0, 8)}`);\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import { existsSync, readFileSync, readdirSync } from 'node:fs';\nimport { join, basename, resolve } from 'node:path';\nimport { execSync } from 'node:child_process';\n\nexport type ProjectType =\n | 'kmp' | 'kotlin' | 'java'\n | 'node' | 'typescript' | 'react' | 'next'\n | 'python' | 'rust' | 'swift' | 'go' | 'flutter'\n | 'unknown';\n\nexport function detectProjectType(dir: string): ProjectType {\n const exists = (f: string) => existsSync(join(dir, f));\n\n if (exists('build.gradle.kts') || exists('build.gradle')) {\n if (exists('composeApp') || exists('gradle.properties')) {\n try {\n const gradle = readFileSync(join(dir, 'build.gradle.kts'), 'utf-8');\n if (gradle.includes('multiplatform') || gradle.includes('KotlinMultiplatform')) return 'kmp';\n } catch { /* ignore */ }\n }\n if (exists('pom.xml')) return 'java';\n return 'kotlin';\n }\n if (exists('pubspec.yaml')) return 'flutter';\n if (exists('Package.swift')) return 'swift';\n try {\n const entries = readdirSync(dir);\n if (entries.some(e => e.endsWith('.xcodeproj'))) return 'swift';\n } catch { /* ignore */ }\n if (exists('Cargo.toml')) return 'rust';\n if (exists('go.mod')) return 'go';\n if (exists('pyproject.toml') || exists('setup.py') || exists('requirements.txt')) return 'python';\n if (exists('package.json')) {\n try {\n const pkg = JSON.parse(readFileSync(join(dir, 'package.json'), 'utf-8'));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n if (allDeps['next']) return 'next';\n if (allDeps['react']) return 'react';\n if (allDeps['typescript'] || exists('tsconfig.json')) return 'typescript';\n } catch { /* ignore */ }\n return 'node';\n }\n if (exists('pom.xml')) return 'java';\n return 'unknown';\n}\n\nexport function detectProjectName(dir: string): string {\n try {\n const pkg = JSON.parse(readFileSync(join(dir, 'package.json'), 'utf-8'));\n if (pkg.name) return pkg.name;\n } catch { /* ignore */ }\n return basename(resolve(dir));\n}\n\nexport function detectMainBranch(dir: string): string {\n try {\n const ref = execSync('git symbolic-ref refs/remotes/origin/HEAD', {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n return ref.split('/').pop() ?? 'main';\n } catch { /* ignore */ }\n\n try {\n const branch = execSync('git branch --show-current', {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n if (branch) return branch;\n } catch { /* ignore */ }\n\n return 'main';\n}\n","import type { ProjectType } from \"./detect.js\";\n\ninterface TaskPrompt {\n title: string;\n prompt: string;\n priority: number;\n}\n\nconst COMMON_TASKS: TaskPrompt[] = [\n {\n title: \"Fix TODOs\",\n prompt:\n \"Scan for TODO, FIXME, HACK comments. Fix the most impactful ones. Run tests to verify.\",\n priority: 1,\n },\n {\n title: \"Update dependencies\",\n prompt:\n \"Check for outdated dependencies. Update patch/minor versions that are safe. Run tests after updating.\",\n priority: 2,\n },\n {\n title: \"Improve test coverage\",\n prompt:\n \"Find untested public functions. Write tests for the most critical ones. Target 80%+ coverage.\",\n priority: 3,\n },\n {\n title: \"Fix lint warnings\",\n prompt:\n \"Run the project linter. Fix all warnings without changing behavior. Run tests.\",\n priority: 4,\n },\n {\n title: \"Improve documentation\",\n prompt:\n \"Review README and code docs. Add missing JSDoc/KDoc for public APIs. Update outdated sections.\",\n priority: 5,\n },\n {\n title: \"Security audit\",\n prompt:\n \"Check for common security issues: hardcoded secrets, SQL injection, XSS, insecure defaults. Fix any found.\",\n priority: 6,\n },\n];\n\nconst TYPE_TASKS: Partial<Record<ProjectType, TaskPrompt[]>> = {\n kmp: [\n {\n title: \"KMP: Optimize Compose\",\n prompt:\n \"Review Compose UI code for recomposition issues. Add @Stable/@Immutable where needed. Check remember usage.\",\n priority: 2,\n },\n {\n title: \"KMP: Check expect/actual\",\n prompt:\n \"Review expect/actual declarations. Ensure all platforms have proper implementations. Check for missing iOS/Desktop actuals.\",\n priority: 3,\n },\n {\n title: \"KMP: Room migrations\",\n prompt:\n \"Check Room database schema. Ensure migrations are defined for schema changes. Add missing migration tests.\",\n priority: 4,\n },\n ],\n typescript: [\n {\n title: \"TS: Strict type safety\",\n prompt:\n \"Find `any` types and loose assertions. Replace with proper types. Enable stricter tsconfig options if safe.\",\n priority: 2,\n },\n ],\n react: [\n {\n title: \"React: Performance\",\n prompt:\n \"Find unnecessary re-renders. Add React.memo, useMemo, useCallback where beneficial. Check bundle size.\",\n priority: 2,\n },\n ],\n python: [\n {\n title: \"Python: Type hints\",\n prompt:\n \"Add type hints to public functions. Run mypy to check type safety. Fix any type errors.\",\n priority: 2,\n },\n ],\n node: [\n {\n title: \"Node: Error handling\",\n prompt:\n \"Review async error handling. Add try/catch for unhandled promises. Check for missing error middleware.\",\n priority: 2,\n },\n ],\n};\n\nexport function getTasksForProject(type: ProjectType): TaskPrompt[] {\n const specific = TYPE_TASKS[type] ?? [];\n return [...specific, ...COMMON_TASKS].sort(\n (a, b) => a.priority - b.priority,\n );\n}\n","import { existsSync, mkdirSync, readFileSync, rmSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nconst LOCK_BASE = join(homedir(), '.copilot', 'locks');\n\nfunction lockDir(name: string): string {\n return join(LOCK_BASE, `${name}.lock`);\n}\n\nfunction isPidAlive(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function acquireLock(name: string, timeoutMs = 30_000): boolean {\n mkdirSync(LOCK_BASE, { recursive: true });\n const dir = lockDir(name);\n const deadline = Date.now() + timeoutMs;\n\n while (Date.now() < deadline) {\n try {\n mkdirSync(dir);\n // Lock acquired — write metadata\n writeFileSync(join(dir, 'pid'), String(process.pid));\n writeFileSync(join(dir, 'acquired'), new Date().toISOString());\n return true;\n } catch {\n // Lock dir exists — check if holder is still alive\n try {\n const holderPid = parseInt(readFileSync(join(dir, 'pid'), 'utf-8').trim(), 10);\n if (!isPidAlive(holderPid)) {\n // Stale lock — break it\n rmSync(dir, { recursive: true, force: true });\n continue;\n }\n } catch {\n // Can't read pid file — try breaking\n rmSync(dir, { recursive: true, force: true });\n continue;\n }\n // Holder is alive — wait and retry\n const waitMs = Math.min(500, deadline - Date.now());\n if (waitMs > 0) {\n const start = Date.now();\n while (Date.now() - start < waitMs) { /* spin wait */ }\n }\n }\n }\n return false;\n}\n\nexport function releaseLock(name: string): void {\n const dir = lockDir(name);\n try {\n rmSync(dir, { recursive: true, force: true });\n } catch { /* already released */ }\n}\n\nexport async function withLock<T>(name: string, fn: () => T | Promise<T>): Promise<T> {\n if (!acquireLock(name)) {\n throw new Error(`Failed to acquire lock: ${name}`);\n }\n try {\n return await fn();\n } finally {\n releaseLock(name);\n }\n}\n","import { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { execSync } from 'node:child_process';\n\nfunction gitExec(dir: string, cmd: string): string | null {\n try {\n return execSync(cmd, {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n } catch {\n return null;\n }\n}\n\nexport function isGitRepo(dir: string): boolean {\n return existsSync(join(dir, '.git'));\n}\n\nexport function gitCurrentBranch(dir: string): string | null {\n return gitExec(dir, 'git branch --show-current');\n}\n\nexport function gitStash(dir: string): boolean {\n return gitExec(dir, 'git stash -q') !== null;\n}\n\nexport function gitStashPop(dir: string): boolean {\n return gitExec(dir, 'git stash pop -q') !== null;\n}\n\nexport function gitCheckout(dir: string, branch: string): boolean {\n return gitExec(dir, `git checkout ${branch} -q`) !== null;\n}\n\nexport function gitCreateBranch(dir: string, branch: string): boolean {\n return gitExec(dir, `git checkout -b ${branch}`) !== null;\n}\n\nexport function gitCountCommits(dir: string, from: string, to: string): number {\n const result = gitExec(dir, `git log ${from}..${to} --oneline`);\n if (!result) return 0;\n return result.split('\\n').filter(l => l.trim()).length;\n}\n\nexport function gitStatus(dir: string): string {\n return gitExec(dir, 'git status --porcelain') ?? '';\n}\n","import type { Command } from 'commander';\nimport { detectProjectType, detectProjectName, detectMainBranch } from '../lib/detect.js';\nimport { getTasksForProject } from '../lib/tasks.js';\nimport { runCopilotTask, assertCopilot } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { isGitRepo, gitCurrentBranch, gitStatus, gitStash, gitCheckout, gitCreateBranch, gitCountCommits } from '../lib/git.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, GREEN, RESET, YELLOW } from '../lib/colors.js';\n\nexport function registerRunCommand(program: Command): void {\n program\n .command('run [dir]')\n .description('Discover and fix issues in a project')\n .option('-s, --steps <n>', 'Max autopilot continues per task', '30')\n .option('-t, --max-tasks <n>', 'Max number of tasks to run', '5')\n .option('-p, --max-premium <n>', 'Max total premium requests', '50')\n .option('--dry-run', 'Show tasks without executing')\n .action(async (dir: string | undefined, opts) => {\n try {\n await runCommand(dir ?? process.cwd(), {\n steps: parseInt(opts.steps, 10),\n maxTasks: parseInt(opts.maxTasks, 10),\n maxPremium: parseInt(opts.maxPremium, 10),\n dryRun: opts.dryRun ?? false,\n });\n } catch (err) {\n fail(`Run error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface RunOptions {\n steps: number;\n maxTasks: number;\n maxPremium: number;\n dryRun: boolean;\n}\n\nasync function runCommand(dir: string, opts: RunOptions): Promise<void> {\n assertCopilot();\n\n const projectType = detectProjectType(dir);\n const name = detectProjectName(dir);\n const mainBranch = isGitRepo(dir) ? detectMainBranch(dir) : null;\n\n info(`Project: ${CYAN}${name}${RESET} (${projectType})`);\n if (mainBranch) info(`Main branch: ${mainBranch}`);\n\n const tasks = getTasksForProject(projectType).slice(0, opts.maxTasks);\n\n if (tasks.length === 0) {\n warn('No tasks found for this project type.');\n return;\n }\n\n log(`Found ${tasks.length} tasks:`);\n for (const t of tasks) {\n log(` ${DIM}•${RESET} ${t.title}`);\n }\n\n if (opts.dryRun) {\n log(`${DIM}(dry-run — not executing)${RESET}`);\n return;\n }\n\n const originalBranch = isGitRepo(dir) ? gitCurrentBranch(dir) : null;\n let completed = 0;\n let premiumTotal = 0;\n\n for (const task of tasks) {\n if (premiumTotal >= opts.maxPremium) {\n warn(`Premium request limit reached (${premiumTotal}/${opts.maxPremium}).`);\n break;\n }\n\n log(`\\n${'═'.repeat(60)}`);\n log(`${BOLD}${CYAN}Task: ${task.title}${RESET}`);\n log(`${'═'.repeat(60)}`);\n\n const timestamp = Date.now().toString(36);\n const random = Math.random().toString(36).substring(2, 6);\n const branchName = `agent/fix-${completed + 1}-${timestamp}-${random}`;\n\n if (mainBranch && isGitRepo(dir)) {\n if (gitStatus(dir)) gitStash(dir);\n gitCheckout(dir, mainBranch);\n if (!gitCreateBranch(dir, branchName)) {\n warn(`Could not create branch ${branchName}, continuing on current.`);\n }\n }\n\n info(`Running: ${task.title}…`);\n\n const result = await withLock('copilot-run', () =>\n runCopilotTask(task.prompt, opts.steps, dir),\n );\n\n const commits = mainBranch ? gitCountCommits(dir, mainBranch, 'HEAD') : 0;\n premiumTotal += result.premium;\n completed++;\n ok(`${task.title} — ${commits} commit(s), ${result.premium} premium`);\n\n if (originalBranch && isGitRepo(dir)) {\n gitCheckout(dir, mainBranch ?? originalBranch);\n }\n }\n\n log(`\\n${BOLD}═══ Run Summary ═══${RESET}`);\n log(`Completed ${completed}/${tasks.length} tasks. Total premium: ${premiumTotal}`);\n notify(`Completed ${completed} tasks`, name);\n}\n","import type { Command } from 'commander';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\nimport { detectProjectType, detectProjectName, detectMainBranch } from '../lib/detect.js';\nimport { getTasksForProject } from '../lib/tasks.js';\nimport { runCopilotTask, assertCopilot, findPidForSession, waitForExit, runCopilotResume } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { isGitRepo, gitCurrentBranch, gitStash, gitCheckout, gitCreateBranch, gitCountCommits } from '../lib/git.js';\nimport { findLatestIncomplete, validateSession, hasTaskComplete, getSessionCwd } from '../lib/session.js';\nimport { log, ok, warn, fail, info, setLogFile, notify } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, RESET } from '../lib/colors.js';\n\nexport function registerOvernightCommand(program: Command): void {\n program\n .command('overnight [dir]')\n .description('Run tasks continuously until a deadline')\n .option('-u, --until <HH>', 'Stop at this hour (24h format)', '07')\n .option('-s, --steps <n>', 'Max autopilot continues per task', '50')\n .option('-c, --cooldown <n>', 'Seconds between tasks', '15')\n .option('-p, --max-premium <n>', 'Max premium requests budget', '300')\n .option('--dry-run', 'Show plan without executing')\n .action(async (dir: string | undefined, opts) => {\n try {\n await overnightCommand(dir ?? process.cwd(), {\n until: parseInt(opts.until, 10),\n steps: parseInt(opts.steps, 10),\n cooldown: parseInt(opts.cooldown, 10),\n maxPremium: parseInt(opts.maxPremium, 10),\n dryRun: opts.dryRun ?? false,\n });\n } catch (err) {\n fail(`Overnight error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface OvernightOptions {\n until: number;\n steps: number;\n cooldown: number;\n maxPremium: number;\n dryRun: boolean;\n}\n\nfunction isPastDeadline(untilHour: number): boolean {\n const hour = new Date().getHours();\n return hour >= untilHour && hour < 20;\n}\n\nasync function overnightCommand(dir: string, opts: OvernightOptions): Promise<void> {\n assertCopilot();\n\n const ts = new Date().toISOString().replace(/[:.]/g, '').slice(0, 15);\n const logPath = join(homedir(), '.copilot', 'auto-resume-logs', `overnight-${ts}.log`);\n setLogFile(logPath);\n\n const name = detectProjectName(dir);\n const projectType = detectProjectType(dir);\n const mainBranch = isGitRepo(dir) ? detectMainBranch(dir) : null;\n\n info(`Overnight runner for ${CYAN}${name}${RESET} (${projectType})`);\n info(`Deadline: ${String(opts.until).padStart(2, '0')}:00`);\n info(`Max premium: ${opts.maxPremium}, Steps: ${opts.steps}`);\n info(`Log: ${logPath}`);\n\n const tasks = getTasksForProject(projectType);\n\n if (opts.dryRun) {\n log(`\\nWould run ${tasks.length} tasks:`);\n for (const t of tasks) log(` ${DIM}•${RESET} ${t.title}`);\n return;\n }\n\n // Phase 1: Resume existing incomplete session\n const existingSession = findLatestIncomplete();\n if (existingSession && validateSession(existingSession)) {\n info(`Found incomplete session: ${existingSession}`);\n const pid = findPidForSession(existingSession);\n if (pid) {\n info(`Waiting for running copilot (PID ${pid})...`);\n await waitForExit(pid);\n }\n\n if (!hasTaskComplete(existingSession) && !isPastDeadline(opts.until)) {\n info('Resuming incomplete session...');\n const cwd = getSessionCwd(existingSession) || dir;\n await runCopilotResume(\n existingSession,\n opts.steps,\n 'Continue remaining work. Complete the task.',\n cwd,\n );\n }\n }\n\n // Phase 2: Loop tasks until deadline\n const originalBranch = isGitRepo(dir) ? gitCurrentBranch(dir) : null;\n let taskIdx = 0;\n let totalPremium = 0;\n let totalCommits = 0;\n\n while (!isPastDeadline(opts.until) && taskIdx < tasks.length) {\n if (totalPremium >= opts.maxPremium) {\n warn(`Premium budget exhausted: ${totalPremium}/${opts.maxPremium}`);\n break;\n }\n\n const task = tasks[taskIdx % tasks.length];\n taskIdx++;\n\n log(`\\n${'═'.repeat(60)}`);\n log(`${BOLD}${CYAN}[${new Date().toLocaleTimeString()}] Task ${taskIdx}: ${task.title}${RESET}`);\n log(`${DIM}Premium: ${totalPremium}/${opts.maxPremium}${RESET}`);\n log(`${'═'.repeat(60)}`);\n\n const timestamp = Date.now().toString(36);\n const random = Math.random().toString(36).substring(2, 6);\n const branchName = `agent/overnight-${taskIdx}-${timestamp}-${random}`;\n\n if (mainBranch && isGitRepo(dir)) {\n gitStash(dir);\n gitCheckout(dir, mainBranch);\n gitCreateBranch(dir, branchName);\n }\n\n info(`Running: ${task.title}…`);\n\n try {\n const result = await withLock('copilot-overnight', () =>\n runCopilotTask(task.prompt, opts.steps, dir),\n );\n\n const commits = mainBranch ? gitCountCommits(dir, mainBranch, 'HEAD') : 0;\n totalPremium += result.premium;\n totalCommits += commits;\n\n if (commits > 0) {\n ok(`${commits} commit(s) on ${branchName}`);\n } else {\n log(`${DIM}No commits on ${branchName}${RESET}`);\n }\n } catch (err) {\n fail(`Task failed: ${err}`);\n }\n\n if (mainBranch && isGitRepo(dir)) {\n gitCheckout(dir, mainBranch);\n }\n\n if (!isPastDeadline(opts.until)) {\n info(`Cooldown ${opts.cooldown}s…`);\n await sleep(opts.cooldown * 1000);\n }\n }\n\n if (originalBranch && isGitRepo(dir)) {\n gitCheckout(dir, originalBranch);\n }\n\n const summary = `Overnight done — ${taskIdx} tasks, ${totalCommits} commits, ${totalPremium} premium.`;\n ok(summary);\n notify(summary, name);\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import type { Command } from 'commander';\nimport { existsSync, copyFileSync, mkdirSync } from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { detectProjectType, detectProjectName } from '../lib/detect.js';\nimport { runCopilotTask, assertCopilot } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { CYAN, RESET } from '../lib/colors.js';\n\nexport function registerResearchCommand(program: Command): void {\n program\n .command('research [project]')\n .description('Research improvements or a specific topic')\n .option('-s, --steps <n>', 'Max autopilot continues', '50')\n .action(async (project: string | undefined, opts) => {\n try {\n await researchCommand(project ?? process.cwd(), {\n steps: parseInt(opts.steps, 10),\n });\n } catch (err) {\n fail(`Research error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface ResearchOptions {\n steps: number;\n}\n\nfunction buildResearchPrompt(projectType: string, projectName: string): string {\n return `You are a senior software architect. Analyze this ${projectType} project \"${projectName}\" thoroughly.\n\nResearch and produce a file called RESEARCH-PROPOSALS.md with:\n\n1. **Architecture Assessment** — Current architecture, patterns used, strengths and weaknesses\n2. **Code Quality Report** — Common issues, anti-patterns, technical debt areas\n3. **Security Audit** — Potential vulnerabilities, dependency risks, configuration issues\n4. **Performance Analysis** — Bottlenecks, optimization opportunities, resource usage\n5. **Testing Gap Analysis** — Untested areas, test quality, coverage recommendations\n6. **Improvement Proposals** — Prioritized list of actionable improvements with effort estimates\n\nFor each proposal, include:\n- Priority (P0/P1/P2)\n- Estimated effort (hours)\n- Impact description\n- Suggested implementation approach\n\nWrite RESEARCH-PROPOSALS.md in the project root.`;\n}\n\nasync function researchCommand(dir: string, opts: ResearchOptions): Promise<void> {\n assertCopilot();\n\n const projectDir = resolve(dir);\n const projectType = detectProjectType(projectDir);\n const projectName = detectProjectName(projectDir);\n\n info(`Researching: ${CYAN}${projectName}${RESET} (${projectType})`);\n\n const prompt = buildResearchPrompt(projectType, projectName);\n\n const result = await withLock('copilot-research', () =>\n runCopilotTask(prompt, opts.steps, projectDir),\n );\n\n log(`Copilot exited with code ${result.exitCode}`);\n\n // Check for output file\n const proposalsFile = join(projectDir, 'RESEARCH-PROPOSALS.md');\n if (existsSync(proposalsFile)) {\n ok('RESEARCH-PROPOSALS.md generated.');\n\n // Backup to ~/.copilot/research-reports/\n const backupDir = join(homedir(), '.copilot', 'research-reports');\n mkdirSync(backupDir, { recursive: true });\n const timestamp = new Date().toISOString().replace(/[:.]/g, '-');\n const backupFile = join(backupDir, `${projectName}-${timestamp}.md`);\n copyFileSync(proposalsFile, backupFile);\n ok(`Backup saved: ${backupFile}`);\n } else {\n warn('RESEARCH-PROPOSALS.md was not generated. Check copilot output.');\n }\n\n notify('Research complete', projectName);\n}\n"],"mappings":"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","names":["execSync","execSync","resolve","program","program","sleep","existsSync","readFileSync","readdirSync","join","resolve","execSync","mkdirSync","readFileSync","join","homedir","existsSync","join","execSync","program","join","homedir","program","join","homedir","sleep","existsSync","mkdirSync","join","resolve","homedir","program","resolve","join","existsSync","homedir","mkdirSync"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/lib/session.ts","../src/lib/process.ts","../src/lib/logger.ts","../src/lib/colors.ts","../src/commands/status.ts","../src/commands/watch.ts","../src/lib/detect.ts","../src/lib/tasks.ts","../src/lib/lock.ts","../src/lib/git.ts","../src/commands/run.ts","../src/commands/overnight.ts","../src/commands/research.ts"],"sourcesContent":["import { Command } from 'commander';\nimport { registerStatusCommand } from './commands/status.js';\nimport { registerWatchCommand } from './commands/watch.js';\nimport { registerRunCommand } from './commands/run.js';\nimport { registerOvernightCommand } from './commands/overnight.js';\nimport { registerResearchCommand } from './commands/research.js';\n\nconst program = new Command();\n\nprogram\n .name('copilot-agent')\n .version('0.5.0')\n .description('Autonomous GitHub Copilot CLI agent — auto-resume, task discovery, overnight runs');\n\nregisterStatusCommand(program);\nregisterWatchCommand(program);\nregisterRunCommand(program);\nregisterOvernightCommand(program);\nregisterResearchCommand(program);\n\nprogram.parse();\n","import {\n existsSync,\n readdirSync,\n readFileSync,\n statSync,\n} from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { homedir } from 'node:os';\n\nexport interface Session {\n id: string;\n dir: string;\n mtime: number;\n lastEvent: string;\n premiumRequests: number;\n summary: string;\n cwd: string;\n complete: boolean;\n}\n\nconst SESSION_DIR = join(homedir(), '.copilot', 'session-state');\n\nexport function getSessionDir(): string {\n return SESSION_DIR;\n}\n\nexport function validateSession(sid: string): boolean {\n const events = join(SESSION_DIR, sid, 'events.jsonl');\n try {\n return existsSync(events) && statSync(events).size > 0;\n } catch {\n return false;\n }\n}\n\nexport function listSessions(limit = 20): Session[] {\n if (!existsSync(SESSION_DIR)) return [];\n\n const entries = readdirSync(SESSION_DIR, { withFileTypes: true })\n .filter(d => d.isDirectory());\n\n const dirs: { id: string; dir: string; mtime: number }[] = [];\n for (const entry of entries) {\n const dirPath = join(SESSION_DIR, entry.name);\n if (!existsSync(join(dirPath, 'events.jsonl'))) continue;\n try {\n const stat = statSync(dirPath);\n dirs.push({ id: entry.name, dir: dirPath, mtime: stat.mtimeMs });\n } catch { /* skip */ }\n }\n\n dirs.sort((a, b) => b.mtime - a.mtime);\n\n return dirs.slice(0, limit).map(s => ({\n id: s.id,\n dir: s.dir,\n mtime: s.mtime,\n lastEvent: getLastEvent(s.id),\n premiumRequests: getSessionPremium(s.id),\n summary: getSessionSummary(s.id),\n cwd: getSessionCwd(s.id),\n complete: hasTaskComplete(s.id),\n }));\n}\n\nexport function getLatestSessionId(): string | null {\n if (!existsSync(SESSION_DIR)) return null;\n\n const entries = readdirSync(SESSION_DIR, { withFileTypes: true })\n .filter(d => d.isDirectory());\n\n let latest: { id: string; mtime: number } | null = null;\n for (const entry of entries) {\n try {\n const stat = statSync(join(SESSION_DIR, entry.name));\n if (!latest || stat.mtimeMs > latest.mtime) {\n latest = { id: entry.name, mtime: stat.mtimeMs };\n }\n } catch { /* skip */ }\n }\n return latest?.id ?? null;\n}\n\nexport function hasTaskComplete(sid: string): boolean {\n if (!validateSession(sid)) return false;\n try {\n const content = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8');\n return content.includes('\"session.task_complete\"');\n } catch {\n return false;\n }\n}\n\nexport function getLastEvent(sid: string): string {\n if (!validateSession(sid)) return 'invalid';\n try {\n const lines = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8')\n .trimEnd()\n .split('\\n');\n const last = JSON.parse(lines[lines.length - 1]);\n return last.type ?? 'unknown';\n } catch {\n return 'corrupted';\n }\n}\n\nexport function getSessionPremium(sid: string): number {\n if (!validateSession(sid)) return 0;\n try {\n const content = readFileSync(join(SESSION_DIR, sid, 'events.jsonl'), 'utf-8');\n const lines = content.trimEnd().split('\\n');\n for (let i = lines.length - 1; i >= 0; i--) {\n try {\n const event = JSON.parse(lines[i]);\n if (event.type === 'session.shutdown' && event.data?.totalPremiumRequests != null) {\n return event.data.totalPremiumRequests;\n }\n } catch { /* skip malformed line */ }\n }\n return 0;\n } catch {\n return 0;\n }\n}\n\nfunction parseSimpleYaml(content: string): Record<string, string> {\n const result: Record<string, string> = {};\n for (const line of content.split('\\n')) {\n const idx = line.indexOf(': ');\n if (idx === -1) continue;\n const key = line.substring(0, idx).trim();\n const value = line.substring(idx + 2).trim();\n if (key) result[key] = value;\n }\n return result;\n}\n\nfunction readWorkspace(sid: string): Record<string, string> {\n const wsPath = join(SESSION_DIR, sid, 'workspace.yaml');\n if (!existsSync(wsPath)) return {};\n try {\n return parseSimpleYaml(readFileSync(wsPath, 'utf-8'));\n } catch {\n return {};\n }\n}\n\nexport function getSessionSummary(sid: string): string {\n return readWorkspace(sid).summary ?? '';\n}\n\nexport function getSessionCwd(sid: string): string {\n return readWorkspace(sid).cwd ?? '';\n}\n\nexport function findSessionForProject(projectPath: string): string | null {\n const resolved = resolve(projectPath);\n const sessions = listSessions(50);\n for (const s of sessions) {\n if (s.cwd && resolve(s.cwd) === resolved) return s.id;\n }\n return null;\n}\n\nexport function findLatestIncomplete(): string | null {\n const sessions = listSessions(50);\n for (const s of sessions) {\n if (!s.complete) return s.id;\n }\n return null;\n}\n","import { execSync, spawn } from 'node:child_process';\nimport { resolve } from 'node:path';\nimport { getLatestSessionId, getSessionPremium, getSessionCwd } from './session.js';\nimport { log, warn, fail } from './logger.js';\n\nexport interface CopilotProcess {\n pid: number;\n command: string;\n sessionId?: string;\n cwd?: string;\n}\n\nexport interface CopilotResult {\n exitCode: number;\n sessionId: string | null;\n premium: number;\n}\n\nexport function isCopilotInstalled(): boolean {\n try {\n execSync('which copilot', { stdio: 'pipe', encoding: 'utf-8' });\n return true;\n } catch {\n return false;\n }\n}\n\nexport function assertCopilot(): void {\n if (!isCopilotInstalled()) {\n fail('copilot CLI not found. Install with: npm i -g @githubnext/copilot');\n process.exit(1);\n }\n}\n\nexport function findCopilotProcesses(): CopilotProcess[] {\n try {\n const output = execSync('ps -eo pid,command', { encoding: 'utf-8' });\n const results: CopilotProcess[] = [];\n const myPid = process.pid;\n const parentPid = process.ppid;\n for (const line of output.split('\\n')) {\n const trimmed = line.trim();\n if (!trimmed) continue;\n if (\n (trimmed.includes('copilot') || trimmed.includes('@githubnext/copilot')) &&\n !trimmed.includes('ps -eo') &&\n !trimmed.includes('copilot-agent') &&\n !trimmed.includes('grep')\n ) {\n const match = trimmed.match(/^(\\d+)\\s+(.+)$/);\n if (match) {\n const pid = parseInt(match[1], 10);\n // Exclude our own process tree\n if (pid === myPid || pid === parentPid) continue;\n const cmd = match[2];\n const sidMatch = cmd.match(/resume[= ]+([a-f0-9-]{36})/);\n // Try to get cwd of the process\n let cwd: string | undefined;\n try {\n cwd = execSync(`lsof -p ${pid} -Fn 2>/dev/null | grep '^n/' | head -1`, {\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim().slice(1) || undefined;\n } catch { /* best effort */ }\n // Fallback: get cwd from session if we know the session\n const sid = sidMatch?.[1];\n if (!cwd && sid) {\n cwd = getSessionCwd(sid) || undefined;\n }\n results.push({ pid, command: cmd, sessionId: sid, cwd });\n }\n }\n }\n return results;\n } catch {\n return [];\n }\n}\n\nexport function findPidForSession(sid: string): number | null {\n const procs = findCopilotProcesses();\n const matching = procs\n .filter(p => p.command.includes(sid))\n .sort((a, b) => b.pid - a.pid);\n return matching[0]?.pid ?? null;\n}\n\n/**\n * SAFETY: Wait until no copilot is running in the SAME directory.\n * Copilot in different directories/worktrees can run in parallel.\n */\nexport async function waitForCopilotInDir(\n dir: string,\n timeoutMs = 14_400_000,\n pollMs = 10_000,\n): Promise<void> {\n const targetDir = resolve(dir);\n const start = Date.now();\n let warned = false;\n while (Date.now() - start < timeoutMs) {\n const procs = findCopilotProcesses();\n const conflicting = procs.filter(p => {\n if (!p.cwd) return false;\n return resolve(p.cwd) === targetDir;\n });\n if (conflicting.length === 0) return;\n if (!warned) {\n warn(`Waiting for copilot in ${targetDir} to finish...`);\n for (const p of conflicting) {\n log(` PID ${p.pid}: ${p.command.slice(0, 80)}`);\n }\n warned = true;\n }\n await sleep(pollMs);\n }\n warn('Timeout waiting for copilot to finish in directory');\n}\n\n/**\n * SAFETY: Check if a session already has a running copilot process.\n * If so, refuse to spawn another one to prevent corruption.\n */\nexport function assertSessionNotRunning(sid: string): void {\n const pid = findPidForSession(sid);\n if (pid) {\n fail(`Session ${sid.slice(0, 8)}… already has copilot running (PID ${pid}). Cannot resume — would corrupt the session.`);\n process.exit(1);\n }\n}\n\nexport async function waitForExit(pid: number, timeoutMs = 14_400_000): Promise<boolean> {\n const start = Date.now();\n while (Date.now() - start < timeoutMs) {\n try {\n process.kill(pid, 0);\n await sleep(5000);\n } catch {\n return true; // process exited\n }\n }\n return false; // timeout\n}\n\nexport async function runCopilot(\n args: string[],\n options?: { cwd?: string; useWorktree?: boolean },\n): Promise<CopilotResult> {\n const dir = options?.cwd ?? process.cwd();\n\n if (options?.useWorktree) {\n // Worktree mode: create separate worktree, no waiting needed\n // (caller is responsible for creating worktree and passing its path)\n } else {\n // Default: wait for copilot in same directory to finish\n await waitForCopilotInDir(dir);\n }\n\n return new Promise((resolve) => {\n const child = spawn('copilot', args, {\n cwd: options?.cwd,\n stdio: 'inherit',\n env: { ...process.env },\n });\n\n child.on('close', async (code) => {\n await sleep(3000); // let events flush\n const sid = getLatestSessionId();\n const premium = sid ? getSessionPremium(sid) : 0;\n resolve({\n exitCode: code ?? 1,\n sessionId: sid,\n premium,\n });\n });\n\n child.on('error', () => {\n resolve({ exitCode: 1, sessionId: null, premium: 0 });\n });\n });\n}\n\nexport function runCopilotResume(\n sid: string,\n steps: number,\n message?: string,\n cwd?: string,\n): Promise<CopilotResult> {\n // SAFETY: Refuse if session already running\n assertSessionNotRunning(sid);\n\n const args = [\n `--resume=${sid}`,\n '--autopilot',\n '--allow-all',\n '--max-autopilot-continues',\n String(steps),\n '--no-ask-user',\n ];\n if (message) args.push('-p', message);\n return runCopilot(args, { cwd });\n}\n\nexport function runCopilotTask(\n prompt: string,\n steps: number,\n cwd?: string,\n useWorktree?: boolean,\n): Promise<CopilotResult> {\n return runCopilot([\n '-p', prompt,\n '--autopilot',\n '--allow-all',\n '--max-autopilot-continues', String(steps),\n '--no-ask-user',\n ], { cwd, useWorktree });\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import { appendFileSync, mkdirSync } from 'node:fs';\nimport { dirname } from 'node:path';\nimport { execSync } from 'node:child_process';\nimport { RED, GREEN, YELLOW, CYAN, DIM, RESET } from './colors.js';\n\nlet logFilePath: string | null = null;\n\nconst ANSI_RE =\n /[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g;\n\nfunction stripAnsi(s: string): string {\n return s.replace(ANSI_RE, '');\n}\n\nfunction writeToFile(msg: string): void {\n if (!logFilePath) return;\n try {\n appendFileSync(logFilePath, stripAnsi(msg) + '\\n');\n } catch { /* ignore file write errors */ }\n}\n\nexport function setLogFile(path: string): void {\n mkdirSync(dirname(path), { recursive: true });\n logFilePath = path;\n}\n\nexport function log(msg: string): void {\n console.log(msg);\n writeToFile(msg);\n}\n\nexport function warn(msg: string): void {\n const out = `${YELLOW}⚠ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`⚠ ${msg}`);\n}\n\nexport function ok(msg: string): void {\n const out = `${GREEN}✔ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`✔ ${msg}`);\n}\n\nexport function fail(msg: string): void {\n const out = `${RED}✖ ${msg}${RESET}`;\n console.error(out);\n writeToFile(`✖ ${msg}`);\n}\n\nexport function info(msg: string): void {\n const out = `${CYAN}ℹ ${msg}${RESET}`;\n console.log(out);\n writeToFile(`ℹ ${msg}`);\n}\n\nexport function dim(msg: string): void {\n const out = `${DIM}${msg}${RESET}`;\n console.log(out);\n writeToFile(msg);\n}\n\nexport function notify(message: string, title = 'copilot-agent'): void {\n try {\n if (process.platform === 'darwin') {\n execSync(\n `osascript -e 'display notification \"${message.replace(/\"/g, '\\\\\"')}\" with title \"${title.replace(/\"/g, '\\\\\"')}\"'`,\n { stdio: 'ignore' },\n );\n } else {\n try {\n execSync('which notify-send', { stdio: 'pipe' });\n execSync(\n `notify-send \"${title}\" \"${message.replace(/\"/g, '\\\\\"')}\"`,\n { stdio: 'ignore' },\n );\n } catch { /* notify-send not available */ }\n }\n } catch { /* notification not available */ }\n}\n","export const RED = '\\x1b[31m';\nexport const GREEN = '\\x1b[32m';\nexport const YELLOW = '\\x1b[33m';\nexport const BLUE = '\\x1b[34m';\nexport const CYAN = '\\x1b[36m';\nexport const DIM = '\\x1b[2m';\nexport const BOLD = '\\x1b[1m';\nexport const RESET = '\\x1b[0m';\n","import type { Command } from 'commander';\nimport {\n listSessions,\n hasTaskComplete,\n getLastEvent,\n getSessionPremium,\n} from '../lib/session.js';\nimport { findCopilotProcesses } from '../lib/process.js';\nimport { log } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, GREEN, YELLOW, RESET } from '../lib/colors.js';\n\nexport function registerStatusCommand(program: Command): void {\n program\n .command('status')\n .description('Show copilot session status')\n .option('-l, --limit <n>', 'Number of sessions to show', '10')\n .option('-a, --active', 'Show only active (running) processes')\n .option('-i, --incomplete', 'Only show incomplete sessions')\n .action((opts) => {\n if (opts.active) {\n showActive();\n } else {\n showRecent(parseInt(opts.limit, 10), opts.incomplete ?? false);\n }\n });\n}\n\nfunction showActive(): void {\n const procs = findCopilotProcesses();\n if (procs.length === 0) {\n log(`${DIM}No active copilot processes.${RESET}`);\n return;\n }\n\n log(`\\n${BOLD}${'PID'.padEnd(8)} ${'Session'.padEnd(40)} Command${RESET}`);\n log('─'.repeat(108));\n\n for (const p of procs) {\n log(\n `${CYAN}${String(p.pid).padEnd(8)}${RESET} ${(p.sessionId ?? '—').padEnd(40)} ${truncate(p.command, 58)}`,\n );\n }\n log('');\n}\n\nfunction showRecent(limit: number, incompleteOnly: boolean): void {\n let sessions = listSessions(limit);\n if (incompleteOnly) {\n sessions = sessions.filter(s => !s.complete);\n }\n\n if (sessions.length === 0) {\n log(`${DIM}No sessions found.${RESET}`);\n return;\n }\n\n log(\n `\\n${BOLD}${'Status'.padEnd(10)} ${'Premium'.padEnd(10)} ${'Last Event'.padEnd(25)} ${'Summary'.padEnd(40)} ID${RESET}`,\n );\n log('─'.repeat(120));\n\n for (const s of sessions) {\n const status = s.complete\n ? `${GREEN}✔ done${RESET}`\n : `${YELLOW}⏸ stop${RESET}`;\n const premium = String(s.premiumRequests);\n const summary = truncate(s.summary || '—', 38);\n\n log(\n `${status.padEnd(10 + 9)} ${premium.padEnd(10)} ${s.lastEvent.padEnd(25)} ${summary.padEnd(40)} ${DIM}${s.id}${RESET}`,\n );\n }\n log(`\\n${DIM}Total: ${sessions.length} session(s)${RESET}`);\n}\n\nfunction truncate(s: string, max: number): string {\n if (s.length <= max) return s;\n return s.substring(0, max - 1) + '…';\n}\n","import type { Command } from 'commander';\nimport {\n validateSession,\n hasTaskComplete,\n getSessionSummary,\n getLastEvent,\n findLatestIncomplete,\n getSessionCwd,\n} from '../lib/session.js';\nimport {\n findPidForSession,\n waitForExit,\n runCopilotResume,\n assertCopilot,\n} from '../lib/process.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { CYAN, RESET } from '../lib/colors.js';\n\nexport function registerWatchCommand(program: Command): void {\n program\n .command('watch [session-id]')\n .description('Watch a session and auto-resume when it stops')\n .option('-s, --steps <n>', 'Max autopilot continues per resume', '30')\n .option('-r, --max-resumes <n>', 'Max number of resumes', '10')\n .option('-c, --cooldown <n>', 'Seconds between resumes', '10')\n .option('-m, --message <msg>', 'Message to send on resume')\n .action(async (sid: string | undefined, opts) => {\n try {\n await watchCommand(sid, {\n steps: parseInt(opts.steps, 10),\n maxResumes: parseInt(opts.maxResumes, 10),\n cooldown: parseInt(opts.cooldown, 10),\n message: opts.message,\n });\n } catch (err) {\n fail(`Watch error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface WatchOptions {\n steps: number;\n maxResumes: number;\n cooldown: number;\n message?: string;\n}\n\nasync function watchCommand(sid: string | undefined, opts: WatchOptions): Promise<void> {\n assertCopilot();\n\n if (!sid) {\n sid = findLatestIncomplete() ?? undefined;\n if (!sid) {\n fail('No incomplete session found.');\n process.exit(1);\n }\n info(`Auto-detected incomplete session: ${CYAN}${sid}${RESET}`);\n }\n\n if (!validateSession(sid)) {\n fail(`Invalid session: ${sid}`);\n process.exit(1);\n }\n\n if (hasTaskComplete(sid)) {\n ok(`Session ${sid} already completed.`);\n return;\n }\n\n let resumes = 0;\n\n while (resumes < opts.maxResumes) {\n const pid = findPidForSession(sid);\n\n if (pid) {\n info(`Watching PID ${pid} for session ${CYAN}${sid.slice(0, 8)}${RESET}…`);\n const exited = await waitForExit(pid);\n\n if (!exited) {\n warn('Timeout waiting for process exit.');\n break;\n }\n }\n\n // Small delay for events to flush\n await sleep(3000);\n\n if (hasTaskComplete(sid)) {\n ok(`Task complete! Summary: ${getSessionSummary(sid) || 'none'}`);\n notify('Task completed!', `Session ${sid.slice(0, 8)}`);\n return;\n }\n\n // Interrupted — resume\n resumes++;\n log(`Session interrupted (${getLastEvent(sid)}). Resume ${resumes}/${opts.maxResumes}…`);\n\n if (opts.cooldown > 0 && resumes > 1) {\n info(`Cooldown ${opts.cooldown}s...`);\n await sleep(opts.cooldown * 1000);\n }\n\n const cwd = getSessionCwd(sid) || undefined;\n const result = await runCopilotResume(\n sid,\n opts.steps,\n opts.message ?? 'Continue remaining work. Pick up where you left off and complete the task.',\n cwd,\n );\n\n if (result.sessionId && result.sessionId !== sid) {\n info(`New session created: ${CYAN}${result.sessionId}${RESET}`);\n sid = result.sessionId;\n }\n }\n\n warn(`Max resumes (${opts.maxResumes}) reached.`);\n notify('Max resumes reached', `Session ${sid.slice(0, 8)}`);\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import { existsSync, readFileSync, readdirSync } from 'node:fs';\nimport { join, basename, resolve } from 'node:path';\nimport { execSync } from 'node:child_process';\n\nexport type ProjectType =\n | 'kmp' | 'kotlin' | 'java'\n | 'node' | 'typescript' | 'react' | 'next'\n | 'python' | 'rust' | 'swift' | 'go' | 'flutter'\n | 'unknown';\n\nexport function detectProjectType(dir: string): ProjectType {\n const exists = (f: string) => existsSync(join(dir, f));\n\n if (exists('build.gradle.kts') || exists('build.gradle')) {\n if (exists('composeApp') || exists('gradle.properties')) {\n try {\n const gradle = readFileSync(join(dir, 'build.gradle.kts'), 'utf-8');\n if (gradle.includes('multiplatform') || gradle.includes('KotlinMultiplatform')) return 'kmp';\n } catch { /* ignore */ }\n }\n if (exists('pom.xml')) return 'java';\n return 'kotlin';\n }\n if (exists('pubspec.yaml')) return 'flutter';\n if (exists('Package.swift')) return 'swift';\n try {\n const entries = readdirSync(dir);\n if (entries.some(e => e.endsWith('.xcodeproj'))) return 'swift';\n } catch { /* ignore */ }\n if (exists('Cargo.toml')) return 'rust';\n if (exists('go.mod')) return 'go';\n if (exists('pyproject.toml') || exists('setup.py') || exists('requirements.txt')) return 'python';\n if (exists('package.json')) {\n try {\n const pkg = JSON.parse(readFileSync(join(dir, 'package.json'), 'utf-8'));\n const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };\n if (allDeps['next']) return 'next';\n if (allDeps['react']) return 'react';\n if (allDeps['typescript'] || exists('tsconfig.json')) return 'typescript';\n } catch { /* ignore */ }\n return 'node';\n }\n if (exists('pom.xml')) return 'java';\n return 'unknown';\n}\n\nexport function detectProjectName(dir: string): string {\n try {\n const pkg = JSON.parse(readFileSync(join(dir, 'package.json'), 'utf-8'));\n if (pkg.name) return pkg.name;\n } catch { /* ignore */ }\n return basename(resolve(dir));\n}\n\nexport function detectMainBranch(dir: string): string {\n try {\n const ref = execSync('git symbolic-ref refs/remotes/origin/HEAD', {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n return ref.split('/').pop() ?? 'main';\n } catch { /* ignore */ }\n\n try {\n const branch = execSync('git branch --show-current', {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n if (branch) return branch;\n } catch { /* ignore */ }\n\n return 'main';\n}\n","import type { ProjectType } from \"./detect.js\";\n\ninterface TaskPrompt {\n title: string;\n prompt: string;\n priority: number;\n}\n\nconst COMMON_TASKS: TaskPrompt[] = [\n {\n title: \"Fix TODOs\",\n prompt:\n \"Scan for TODO, FIXME, HACK comments. Fix the most impactful ones. Run tests to verify.\",\n priority: 1,\n },\n {\n title: \"Update dependencies\",\n prompt:\n \"Check for outdated dependencies. Update patch/minor versions that are safe. Run tests after updating.\",\n priority: 2,\n },\n {\n title: \"Improve test coverage\",\n prompt:\n \"Find untested public functions. Write tests for the most critical ones. Target 80%+ coverage.\",\n priority: 3,\n },\n {\n title: \"Fix lint warnings\",\n prompt:\n \"Run the project linter. Fix all warnings without changing behavior. Run tests.\",\n priority: 4,\n },\n {\n title: \"Improve documentation\",\n prompt:\n \"Review README and code docs. Add missing JSDoc/KDoc for public APIs. Update outdated sections.\",\n priority: 5,\n },\n {\n title: \"Security audit\",\n prompt:\n \"Check for common security issues: hardcoded secrets, SQL injection, XSS, insecure defaults. Fix any found.\",\n priority: 6,\n },\n];\n\nconst TYPE_TASKS: Partial<Record<ProjectType, TaskPrompt[]>> = {\n kmp: [\n {\n title: \"KMP: Optimize Compose\",\n prompt:\n \"Review Compose UI code for recomposition issues. Add @Stable/@Immutable where needed. Check remember usage.\",\n priority: 2,\n },\n {\n title: \"KMP: Check expect/actual\",\n prompt:\n \"Review expect/actual declarations. Ensure all platforms have proper implementations. Check for missing iOS/Desktop actuals.\",\n priority: 3,\n },\n {\n title: \"KMP: Room migrations\",\n prompt:\n \"Check Room database schema. Ensure migrations are defined for schema changes. Add missing migration tests.\",\n priority: 4,\n },\n ],\n typescript: [\n {\n title: \"TS: Strict type safety\",\n prompt:\n \"Find `any` types and loose assertions. Replace with proper types. Enable stricter tsconfig options if safe.\",\n priority: 2,\n },\n ],\n react: [\n {\n title: \"React: Performance\",\n prompt:\n \"Find unnecessary re-renders. Add React.memo, useMemo, useCallback where beneficial. Check bundle size.\",\n priority: 2,\n },\n ],\n python: [\n {\n title: \"Python: Type hints\",\n prompt:\n \"Add type hints to public functions. Run mypy to check type safety. Fix any type errors.\",\n priority: 2,\n },\n ],\n node: [\n {\n title: \"Node: Error handling\",\n prompt:\n \"Review async error handling. Add try/catch for unhandled promises. Check for missing error middleware.\",\n priority: 2,\n },\n ],\n};\n\nexport function getTasksForProject(type: ProjectType): TaskPrompt[] {\n const specific = TYPE_TASKS[type] ?? [];\n return [...specific, ...COMMON_TASKS].sort(\n (a, b) => a.priority - b.priority,\n );\n}\n","import { existsSync, mkdirSync, readFileSync, rmSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\n\nconst LOCK_BASE = join(homedir(), '.copilot', 'locks');\n\nfunction lockDir(name: string): string {\n return join(LOCK_BASE, `${name}.lock`);\n}\n\nfunction isPidAlive(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function acquireLock(name: string, timeoutMs = 30_000): boolean {\n mkdirSync(LOCK_BASE, { recursive: true });\n const dir = lockDir(name);\n const deadline = Date.now() + timeoutMs;\n\n while (Date.now() < deadline) {\n try {\n mkdirSync(dir);\n // Lock acquired — write metadata\n writeFileSync(join(dir, 'pid'), String(process.pid));\n writeFileSync(join(dir, 'acquired'), new Date().toISOString());\n return true;\n } catch {\n // Lock dir exists — check if holder is still alive\n try {\n const holderPid = parseInt(readFileSync(join(dir, 'pid'), 'utf-8').trim(), 10);\n if (!isPidAlive(holderPid)) {\n // Stale lock — break it\n rmSync(dir, { recursive: true, force: true });\n continue;\n }\n } catch {\n // Can't read pid file — try breaking\n rmSync(dir, { recursive: true, force: true });\n continue;\n }\n // Holder is alive — wait and retry\n const waitMs = Math.min(500, deadline - Date.now());\n if (waitMs > 0) {\n const start = Date.now();\n while (Date.now() - start < waitMs) { /* spin wait */ }\n }\n }\n }\n return false;\n}\n\nexport function releaseLock(name: string): void {\n const dir = lockDir(name);\n try {\n rmSync(dir, { recursive: true, force: true });\n } catch { /* already released */ }\n}\n\nexport async function withLock<T>(name: string, fn: () => T | Promise<T>): Promise<T> {\n if (!acquireLock(name)) {\n throw new Error(`Failed to acquire lock: ${name}`);\n }\n try {\n return await fn();\n } finally {\n releaseLock(name);\n }\n}\n","import { existsSync, rmSync } from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { execSync } from 'node:child_process';\n\nfunction gitExec(dir: string, cmd: string): string | null {\n try {\n return execSync(cmd, {\n cwd: dir,\n encoding: 'utf-8',\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n } catch {\n return null;\n }\n}\n\nexport function isGitRepo(dir: string): boolean {\n return existsSync(join(dir, '.git'));\n}\n\nexport function gitCurrentBranch(dir: string): string | null {\n return gitExec(dir, 'git branch --show-current');\n}\n\nexport function gitStash(dir: string): boolean {\n return gitExec(dir, 'git stash -q') !== null;\n}\n\nexport function gitStashPop(dir: string): boolean {\n return gitExec(dir, 'git stash pop -q') !== null;\n}\n\nexport function gitCheckout(dir: string, branch: string): boolean {\n return gitExec(dir, `git checkout ${branch} -q`) !== null;\n}\n\nexport function gitCreateBranch(dir: string, branch: string): boolean {\n return gitExec(dir, `git checkout -b ${branch}`) !== null;\n}\n\nexport function gitCountCommits(dir: string, from: string, to: string): number {\n const result = gitExec(dir, `git log ${from}..${to} --oneline`);\n if (!result) return 0;\n return result.split('\\n').filter(l => l.trim()).length;\n}\n\nexport function gitStatus(dir: string): string {\n return gitExec(dir, 'git status --porcelain') ?? '';\n}\n\nexport function gitRoot(dir: string): string | null {\n return gitExec(dir, 'git rev-parse --show-toplevel');\n}\n\n// ── Worktree support ──\n\nexport function listWorktrees(dir: string): { path: string; branch: string; bare: boolean }[] {\n const raw = gitExec(dir, 'git worktree list --porcelain');\n if (!raw) return [];\n const trees: { path: string; branch: string; bare: boolean }[] = [];\n let current: { path: string; branch: string; bare: boolean } = { path: '', branch: '', bare: false };\n for (const line of raw.split('\\n')) {\n if (line.startsWith('worktree ')) {\n if (current.path) trees.push(current);\n current = { path: line.slice(9), branch: '', bare: false };\n } else if (line.startsWith('branch ')) {\n current.branch = line.slice(7).replace('refs/heads/', '');\n } else if (line === 'bare') {\n current.bare = true;\n }\n }\n if (current.path) trees.push(current);\n return trees;\n}\n\n/**\n * Create a git worktree for parallel copilot work.\n * Returns the worktree path or null on failure.\n */\nexport function createWorktree(repoDir: string, branch: string): string | null {\n const safeBranch = branch.replace(/[^a-zA-Z0-9._/-]/g, '-');\n const worktreePath = resolve(repoDir, '..', `${resolve(repoDir).split('/').pop()}-wt-${safeBranch}`);\n\n if (existsSync(worktreePath)) {\n return worktreePath; // already exists\n }\n\n // Create branch if it doesn't exist, then add worktree\n const branchExists = gitExec(repoDir, `git rev-parse --verify ${safeBranch}`) !== null;\n const cmd = branchExists\n ? `git worktree add \"${worktreePath}\" ${safeBranch}`\n : `git worktree add -b ${safeBranch} \"${worktreePath}\"`;\n\n if (gitExec(repoDir, cmd) !== null) {\n return worktreePath;\n }\n return null;\n}\n\n/**\n * Remove a worktree (prune).\n */\nexport function removeWorktree(repoDir: string, worktreePath: string): boolean {\n const result = gitExec(repoDir, `git worktree remove \"${worktreePath}\" --force`);\n return result !== null;\n}\n\n/**\n * Clean up all copilot-agent worktrees.\n */\nexport function cleanupWorktrees(repoDir: string): number {\n const trees = listWorktrees(repoDir);\n let cleaned = 0;\n for (const t of trees) {\n if (t.path.includes('-wt-')) {\n if (removeWorktree(repoDir, t.path)) cleaned++;\n }\n }\n gitExec(repoDir, 'git worktree prune');\n return cleaned;\n}\n","import type { Command } from 'commander';\nimport { detectProjectType, detectProjectName, detectMainBranch } from '../lib/detect.js';\nimport { getTasksForProject } from '../lib/tasks.js';\nimport { runCopilotTask, assertCopilot } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { isGitRepo, gitCurrentBranch, gitStatus, gitStash, gitCheckout, gitCreateBranch, gitCountCommits, createWorktree, removeWorktree } from '../lib/git.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, GREEN, RESET, YELLOW } from '../lib/colors.js';\n\nexport function registerRunCommand(program: Command): void {\n program\n .command('run [dir]')\n .description('Discover and fix issues in a project')\n .option('-s, --steps <n>', 'Max autopilot continues per task', '30')\n .option('-t, --max-tasks <n>', 'Max number of tasks to run', '5')\n .option('-p, --max-premium <n>', 'Max total premium requests', '50')\n .option('--dry-run', 'Show tasks without executing')\n .option('--worktree', 'Use git worktree for parallel execution (default: wait for idle)')\n .action(async (dir: string | undefined, opts) => {\n try {\n await runCommand(dir ?? process.cwd(), {\n steps: parseInt(opts.steps, 10),\n maxTasks: parseInt(opts.maxTasks, 10),\n maxPremium: parseInt(opts.maxPremium, 10),\n dryRun: opts.dryRun ?? false,\n useWorktree: opts.worktree ?? false,\n });\n } catch (err) {\n fail(`Run error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface RunOptions {\n steps: number;\n maxTasks: number;\n maxPremium: number;\n dryRun: boolean;\n useWorktree: boolean;\n}\n\nasync function runCommand(dir: string, opts: RunOptions): Promise<void> {\n assertCopilot();\n\n const projectType = detectProjectType(dir);\n const name = detectProjectName(dir);\n const mainBranch = isGitRepo(dir) ? detectMainBranch(dir) : null;\n\n info(`Project: ${CYAN}${name}${RESET} (${projectType})`);\n if (mainBranch) info(`Main branch: ${mainBranch}`);\n\n const tasks = getTasksForProject(projectType).slice(0, opts.maxTasks);\n\n if (tasks.length === 0) {\n warn('No tasks found for this project type.');\n return;\n }\n\n log(`Found ${tasks.length} tasks:`);\n for (const t of tasks) {\n log(` ${DIM}•${RESET} ${t.title}`);\n }\n\n if (opts.dryRun) {\n log(`${DIM}(dry-run — not executing)${RESET}`);\n return;\n }\n\n const originalBranch = isGitRepo(dir) ? gitCurrentBranch(dir) : null;\n let completed = 0;\n let premiumTotal = 0;\n\n for (const task of tasks) {\n if (premiumTotal >= opts.maxPremium) {\n warn(`Premium request limit reached (${premiumTotal}/${opts.maxPremium}).`);\n break;\n }\n\n log(`\\n${'═'.repeat(60)}`);\n log(`${BOLD}${CYAN}Task: ${task.title}${RESET}`);\n log(`${'═'.repeat(60)}`);\n\n const timestamp = Date.now().toString(36);\n const random = Math.random().toString(36).substring(2, 6);\n const branchName = `agent/fix-${completed + 1}-${timestamp}-${random}`;\n\n if (mainBranch && isGitRepo(dir)) {\n if (gitStatus(dir)) gitStash(dir);\n gitCheckout(dir, mainBranch);\n if (!gitCreateBranch(dir, branchName)) {\n warn(`Could not create branch ${branchName}, continuing on current.`);\n }\n }\n\n info(`Running: ${task.title}…`);\n\n let taskDir = dir;\n let worktreeCreated = false;\n\n if (opts.useWorktree && isGitRepo(dir)) {\n try {\n taskDir = createWorktree(dir, branchName, mainBranch ?? undefined);\n worktreeCreated = true;\n info(`Created worktree: ${taskDir}`);\n } catch (err) {\n warn(`Worktree creation failed, falling back to main dir: ${err}`);\n taskDir = dir;\n }\n }\n\n const result = await withLock('copilot-run', () =>\n runCopilotTask(task.prompt, opts.steps, taskDir, opts.useWorktree),\n );\n\n const commitRef = worktreeCreated ? taskDir : dir;\n const commits = mainBranch ? gitCountCommits(commitRef, mainBranch, 'HEAD') : 0;\n premiumTotal += result.premium;\n completed++;\n ok(`${task.title} — ${commits} commit(s), ${result.premium} premium`);\n\n if (worktreeCreated) {\n try {\n removeWorktree(dir, taskDir);\n } catch (err) {\n warn(`Worktree cleanup failed: ${err}`);\n }\n }\n\n if (!worktreeCreated && originalBranch && isGitRepo(dir)) {\n gitCheckout(dir, mainBranch ?? originalBranch);\n }\n }\n\n log(`\\n${BOLD}═══ Run Summary ═══${RESET}`);\n log(`Completed ${completed}/${tasks.length} tasks. Total premium: ${premiumTotal}`);\n notify(`Completed ${completed} tasks`, name);\n}\n","import type { Command } from 'commander';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\nimport { detectProjectType, detectProjectName, detectMainBranch } from '../lib/detect.js';\nimport { getTasksForProject } from '../lib/tasks.js';\nimport { runCopilotTask, assertCopilot, findPidForSession, findCopilotProcesses, waitForExit, waitForCopilotInDir, runCopilotResume } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { isGitRepo, gitCurrentBranch, gitStash, gitCheckout, gitCreateBranch, gitCountCommits, createWorktree, removeWorktree } from '../lib/git.js';\nimport { findLatestIncomplete, validateSession, hasTaskComplete, getSessionCwd } from '../lib/session.js';\nimport { log, ok, warn, fail, info, setLogFile, notify } from '../lib/logger.js';\nimport { BOLD, CYAN, DIM, RESET } from '../lib/colors.js';\n\nexport function registerOvernightCommand(program: Command): void {\n program\n .command('overnight [dir]')\n .description('Run tasks continuously until a deadline')\n .option('-u, --until <HH>', 'Stop at this hour (24h format)', '07')\n .option('-s, --steps <n>', 'Max autopilot continues per task', '50')\n .option('-c, --cooldown <n>', 'Seconds between tasks', '15')\n .option('-p, --max-premium <n>', 'Max premium requests budget', '300')\n .option('--dry-run', 'Show plan without executing')\n .option('--worktree', 'Use git worktree for parallel execution (default: wait for idle)')\n .action(async (dir: string | undefined, opts) => {\n try {\n await overnightCommand(dir ?? process.cwd(), {\n until: parseInt(opts.until, 10),\n steps: parseInt(opts.steps, 10),\n cooldown: parseInt(opts.cooldown, 10),\n maxPremium: parseInt(opts.maxPremium, 10),\n dryRun: opts.dryRun ?? false,\n useWorktree: opts.worktree ?? false,\n });\n } catch (err) {\n fail(`Overnight error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface OvernightOptions {\n until: number;\n steps: number;\n cooldown: number;\n maxPremium: number;\n dryRun: boolean;\n useWorktree: boolean;\n}\n\nfunction isPastDeadline(untilHour: number): boolean {\n const hour = new Date().getHours();\n return hour >= untilHour && hour < 20;\n}\n\nasync function overnightCommand(dir: string, opts: OvernightOptions): Promise<void> {\n assertCopilot();\n\n const ts = new Date().toISOString().replace(/[:.]/g, '').slice(0, 15);\n const logPath = join(homedir(), '.copilot', 'auto-resume-logs', `overnight-${ts}.log`);\n setLogFile(logPath);\n\n const name = detectProjectName(dir);\n const projectType = detectProjectType(dir);\n const mainBranch = isGitRepo(dir) ? detectMainBranch(dir) : null;\n\n info(`Overnight runner for ${CYAN}${name}${RESET} (${projectType})`);\n info(`Deadline: ${String(opts.until).padStart(2, '0')}:00`);\n info(`Max premium: ${opts.maxPremium}, Steps: ${opts.steps}`);\n info(`Log: ${logPath}`);\n\n const tasks = getTasksForProject(projectType);\n\n if (opts.dryRun) {\n log(`\\nWould run ${tasks.length} tasks:`);\n for (const t of tasks) log(` ${DIM}•${RESET} ${t.title}`);\n return;\n }\n\n // Phase 1: Resume existing incomplete session\n const existingSession = findLatestIncomplete();\n if (existingSession && validateSession(existingSession)) {\n info(`Found incomplete session: ${existingSession}`);\n const pid = findPidForSession(existingSession);\n if (pid) {\n info(`Waiting for running copilot (PID ${pid})...`);\n await waitForExit(pid);\n }\n\n if (!hasTaskComplete(existingSession) && !isPastDeadline(opts.until)) {\n info('Resuming incomplete session...');\n const cwd = getSessionCwd(existingSession) || dir;\n await runCopilotResume(\n existingSession,\n opts.steps,\n 'Continue remaining work. Complete the task.',\n cwd,\n );\n }\n }\n\n // Phase 2: Loop tasks until deadline\n const originalBranch = isGitRepo(dir) ? gitCurrentBranch(dir) : null;\n let taskIdx = 0;\n let totalPremium = 0;\n let totalCommits = 0;\n\n while (!isPastDeadline(opts.until) && taskIdx < tasks.length) {\n if (totalPremium >= opts.maxPremium) {\n warn(`Premium budget exhausted: ${totalPremium}/${opts.maxPremium}`);\n break;\n }\n\n const task = tasks[taskIdx % tasks.length];\n taskIdx++;\n\n log(`\\n${'═'.repeat(60)}`);\n log(`${BOLD}${CYAN}[${new Date().toLocaleTimeString()}] Task ${taskIdx}: ${task.title}${RESET}`);\n log(`${DIM}Premium: ${totalPremium}/${opts.maxPremium}${RESET}`);\n log(`${'═'.repeat(60)}`);\n\n const timestamp = Date.now().toString(36);\n const random = Math.random().toString(36).substring(2, 6);\n const branchName = `agent/overnight-${taskIdx}-${timestamp}-${random}`;\n\n if (mainBranch && isGitRepo(dir)) {\n gitStash(dir);\n gitCheckout(dir, mainBranch);\n gitCreateBranch(dir, branchName);\n }\n\n info(`Running: ${task.title}…`);\n\n let taskDir = dir;\n let worktreeCreated = false;\n\n if (opts.useWorktree && isGitRepo(dir)) {\n try {\n taskDir = createWorktree(dir, branchName, mainBranch ?? undefined);\n worktreeCreated = true;\n info(`Created worktree: ${taskDir}`);\n } catch (err) {\n warn(`Worktree creation failed, falling back to main dir: ${err}`);\n taskDir = dir;\n }\n }\n\n try {\n const result = await withLock('copilot-overnight', () =>\n runCopilotTask(task.prompt, opts.steps, taskDir, opts.useWorktree),\n );\n\n const commitRef = worktreeCreated ? taskDir : dir;\n const commits = mainBranch ? gitCountCommits(commitRef, mainBranch, 'HEAD') : 0;\n totalPremium += result.premium;\n totalCommits += commits;\n\n if (commits > 0) {\n ok(`${commits} commit(s) on ${branchName}`);\n } else {\n log(`${DIM}No commits on ${branchName}${RESET}`);\n }\n } catch (err) {\n fail(`Task failed: ${err}`);\n }\n\n // Cleanup worktree if we created one\n if (worktreeCreated) {\n try {\n removeWorktree(dir, taskDir);\n info(`Removed worktree: ${taskDir}`);\n } catch (err) {\n warn(`Worktree cleanup failed: ${err}`);\n }\n }\n\n if (!worktreeCreated && mainBranch && isGitRepo(dir)) {\n gitCheckout(dir, mainBranch);\n }\n\n if (!isPastDeadline(opts.until)) {\n info(`Cooldown ${opts.cooldown}s…`);\n await sleep(opts.cooldown * 1000);\n }\n }\n\n if (originalBranch && isGitRepo(dir)) {\n gitCheckout(dir, originalBranch);\n }\n\n const summary = `Overnight done — ${taskIdx} tasks, ${totalCommits} commits, ${totalPremium} premium.`;\n ok(summary);\n notify(summary, name);\n}\n\nfunction sleep(ms: number): Promise<void> {\n return new Promise(r => setTimeout(r, ms));\n}\n","import type { Command } from 'commander';\nimport { existsSync, copyFileSync, mkdirSync } from 'node:fs';\nimport { join, resolve } from 'node:path';\nimport { homedir } from 'node:os';\nimport { detectProjectType, detectProjectName } from '../lib/detect.js';\nimport { runCopilotTask, assertCopilot } from '../lib/process.js';\nimport { withLock } from '../lib/lock.js';\nimport { log, ok, warn, fail, info, notify } from '../lib/logger.js';\nimport { CYAN, RESET } from '../lib/colors.js';\n\nexport function registerResearchCommand(program: Command): void {\n program\n .command('research [project]')\n .description('Research improvements or a specific topic')\n .option('-s, --steps <n>', 'Max autopilot continues', '50')\n .action(async (project: string | undefined, opts) => {\n try {\n await researchCommand(project ?? process.cwd(), {\n steps: parseInt(opts.steps, 10),\n });\n } catch (err) {\n fail(`Research error: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n });\n}\n\ninterface ResearchOptions {\n steps: number;\n}\n\nfunction buildResearchPrompt(projectType: string, projectName: string): string {\n return `You are a senior software architect. Analyze this ${projectType} project \"${projectName}\" thoroughly.\n\nResearch and produce a file called RESEARCH-PROPOSALS.md with:\n\n1. **Architecture Assessment** — Current architecture, patterns used, strengths and weaknesses\n2. **Code Quality Report** — Common issues, anti-patterns, technical debt areas\n3. **Security Audit** — Potential vulnerabilities, dependency risks, configuration issues\n4. **Performance Analysis** — Bottlenecks, optimization opportunities, resource usage\n5. **Testing Gap Analysis** — Untested areas, test quality, coverage recommendations\n6. **Improvement Proposals** — Prioritized list of actionable improvements with effort estimates\n\nFor each proposal, include:\n- Priority (P0/P1/P2)\n- Estimated effort (hours)\n- Impact description\n- Suggested implementation approach\n\nWrite RESEARCH-PROPOSALS.md in the project root.`;\n}\n\nasync function researchCommand(dir: string, opts: ResearchOptions): Promise<void> {\n assertCopilot();\n\n const projectDir = resolve(dir);\n const projectType = detectProjectType(projectDir);\n const projectName = detectProjectName(projectDir);\n\n info(`Researching: ${CYAN}${projectName}${RESET} (${projectType})`);\n\n const prompt = buildResearchPrompt(projectType, projectName);\n\n const result = await withLock('copilot-research', () =>\n runCopilotTask(prompt, opts.steps, projectDir),\n );\n\n log(`Copilot exited with code ${result.exitCode}`);\n\n // Check for output file\n const proposalsFile = join(projectDir, 'RESEARCH-PROPOSALS.md');\n if (existsSync(proposalsFile)) {\n ok('RESEARCH-PROPOSALS.md generated.');\n\n // Backup to ~/.copilot/research-reports/\n const backupDir = join(homedir(), '.copilot', 'research-reports');\n mkdirSync(backupDir, { recursive: true });\n const timestamp = new Date().toISOString().replace(/[:.]/g, '-');\n const backupFile = join(backupDir, `${projectName}-${timestamp}.md`);\n copyFileSync(proposalsFile, backupFile);\n ok(`Backup saved: ${backupFile}`);\n } else {\n warn('RESEARCH-PROPOSALS.md was not generated. Check copilot output.');\n }\n\n notify('Research complete', projectName);\n}\n"],"mappings":"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","names":["execSync","resolve","execSync","resolve","program","program","sleep","existsSync","readFileSync","readdirSync","join","resolve","execSync","mkdirSync","readFileSync","join","homedir","existsSync","join","resolve","execSync","resolve","existsSync","program","join","homedir","program","join","homedir","sleep","existsSync","mkdirSync","join","resolve","homedir","program","resolve","join","existsSync","homedir","mkdirSync"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "copilot-agent",
3
- "version": "0.3.0",
3
+ "version": "0.5.0",
4
4
  "description": "Autonomous GitHub Copilot CLI agent — auto-resume, task discovery, overnight runs",
5
5
  "author": "magicpro97",
6
6
  "license": "MIT",