@rcrsr/claude-code-runner 0.4.0 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/README.md +104 -31
  2. package/dist/cli/args.d.ts +0 -3
  3. package/dist/cli/args.d.ts.map +1 -1
  4. package/dist/cli/args.js +51 -20
  5. package/dist/cli/args.js.map +1 -1
  6. package/dist/core/runner.d.ts +5 -2
  7. package/dist/core/runner.d.ts.map +1 -1
  8. package/dist/core/runner.js +27 -24
  9. package/dist/core/runner.js.map +1 -1
  10. package/dist/index.js +85 -42
  11. package/dist/index.js.map +1 -1
  12. package/dist/output/colors.d.ts +16 -12
  13. package/dist/output/colors.d.ts.map +1 -1
  14. package/dist/output/colors.js +27 -65
  15. package/dist/output/colors.js.map +1 -1
  16. package/dist/output/deaddrop-queue.d.ts +45 -0
  17. package/dist/output/deaddrop-queue.d.ts.map +1 -0
  18. package/dist/output/deaddrop-queue.js +82 -0
  19. package/dist/output/deaddrop-queue.js.map +1 -0
  20. package/dist/output/formatter.d.ts +23 -0
  21. package/dist/output/formatter.d.ts.map +1 -1
  22. package/dist/output/formatter.js +83 -42
  23. package/dist/output/formatter.js.map +1 -1
  24. package/dist/output/index.d.ts +1 -0
  25. package/dist/output/index.d.ts.map +1 -1
  26. package/dist/output/index.js +1 -0
  27. package/dist/output/index.js.map +1 -1
  28. package/dist/output/logger.js +2 -2
  29. package/dist/output/logger.js.map +1 -1
  30. package/dist/output/stats.d.ts +73 -0
  31. package/dist/output/stats.d.ts.map +1 -0
  32. package/dist/output/stats.js +154 -0
  33. package/dist/output/stats.js.map +1 -0
  34. package/dist/process/pty.d.ts.map +1 -1
  35. package/dist/process/pty.js +3 -2
  36. package/dist/process/pty.js.map +1 -1
  37. package/dist/script/index.d.ts +8 -0
  38. package/dist/script/index.d.ts.map +1 -0
  39. package/dist/script/index.js +10 -0
  40. package/dist/script/index.js.map +1 -0
  41. package/dist/script/loader.d.ts +13 -0
  42. package/dist/script/loader.d.ts.map +1 -0
  43. package/dist/script/loader.js +66 -0
  44. package/dist/script/loader.js.map +1 -0
  45. package/dist/script/parser.d.ts +63 -0
  46. package/dist/script/parser.d.ts.map +1 -0
  47. package/dist/script/parser.js +349 -0
  48. package/dist/script/parser.js.map +1 -0
  49. package/dist/script/types.d.ts +49 -0
  50. package/dist/script/types.d.ts.map +1 -0
  51. package/dist/script/types.js +5 -0
  52. package/dist/script/types.js.map +1 -0
  53. package/dist/script/variables.d.ts +27 -0
  54. package/dist/script/variables.d.ts.map +1 -0
  55. package/dist/script/variables.js +74 -0
  56. package/dist/script/variables.js.map +1 -0
  57. package/dist/templates/command.d.ts +18 -20
  58. package/dist/templates/command.d.ts.map +1 -1
  59. package/dist/templates/command.js +40 -61
  60. package/dist/templates/command.js.map +1 -1
  61. package/dist/types/claude.d.ts +12 -0
  62. package/dist/types/claude.d.ts.map +1 -1
  63. package/dist/types/claude.js.map +1 -1
  64. package/dist/types/index.d.ts +1 -0
  65. package/dist/types/index.d.ts.map +1 -1
  66. package/dist/types/index.js +1 -0
  67. package/dist/types/index.js.map +1 -1
  68. package/dist/types/runner.d.ts +12 -0
  69. package/dist/types/runner.d.ts.map +1 -1
  70. package/dist/types/runner.js +4 -3
  71. package/dist/types/runner.js.map +1 -1
  72. package/dist/types/tools.d.ts +64 -0
  73. package/dist/types/tools.d.ts.map +1 -0
  74. package/dist/types/tools.js +12 -0
  75. package/dist/types/tools.js.map +1 -0
  76. package/dist/utils/arguments.d.ts +19 -0
  77. package/dist/utils/arguments.d.ts.map +1 -0
  78. package/dist/utils/arguments.js +31 -0
  79. package/dist/utils/arguments.js.map +1 -0
  80. package/dist/utils/constants.d.ts +51 -0
  81. package/dist/utils/constants.d.ts.map +1 -0
  82. package/dist/utils/constants.js +56 -0
  83. package/dist/utils/constants.js.map +1 -0
  84. package/dist/utils/formatting.d.ts +10 -0
  85. package/dist/utils/formatting.d.ts.map +1 -0
  86. package/dist/utils/formatting.js +19 -0
  87. package/dist/utils/formatting.js.map +1 -0
  88. package/dist/utils/index.d.ts +7 -0
  89. package/dist/utils/index.d.ts.map +1 -0
  90. package/dist/utils/index.js +7 -0
  91. package/dist/utils/index.js.map +1 -0
  92. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -4,12 +4,14 @@
4
4
  * Shows intermediate tool calls and responses in real-time
5
5
  */
6
6
  import { randomBytes } from 'crypto';
7
- import { parseArgs, parseCommandLine } from './cli/args.js';
8
- import { runWithSignals } from './core/runner.js';
7
+ import { parseArgs } from './cli/args.js';
8
+ import { runWithSignals, } from './core/runner.js';
9
9
  import { createDeadDropClientFromEnv } from './deaddrop/index.js';
10
- import { colors, configureDeadDrop, flushDeadDrop, formatDuration, printRunner, printRunnerInfo, } from './output/colors.js';
11
- import { createFormatterState } from './output/formatter.js';
10
+ import { configureDeadDrop, flushDeadDrop, printRunner, printRunnerInfo, } from './output/colors.js';
11
+ import { createFormatterState, finalizeStepStats, getRunStatsSummary, resetFormatterState, } from './output/formatter.js';
12
12
  import { createLogger } from './output/logger.js';
13
+ import { captureOutput, createVariableStore, getSubstitutionList, loadScript, substituteVariables, } from './script/index.js';
14
+ import { loadCommandTemplate } from './templates/command.js';
13
15
  import { DEFAULT_CONFIG } from './types/runner.js';
14
16
  /**
15
17
  * Generate a short unique run ID (8 chars, uppercase)
@@ -17,6 +19,16 @@ import { DEFAULT_CONFIG } from './types/runner.js';
17
19
  function generateRunId() {
18
20
  return randomBytes(4).toString('hex').toUpperCase();
19
21
  }
22
+ /**
23
+ * Format variables used for "with X" clause
24
+ */
25
+ function formatVarsUsed(vars) {
26
+ if (vars.length === 0)
27
+ return '';
28
+ // Convert $_ to "last result", keep others as-is
29
+ const labels = vars.map((v) => (v === '$_' ? 'last result' : v));
30
+ return `with ${labels.join(', ')}: `;
31
+ }
20
32
  async function main() {
21
33
  const totalStart = Date.now();
22
34
  const args = process.argv.slice(2);
@@ -68,58 +80,89 @@ async function main() {
68
80
  printRunnerInfo(`Log: ${logger.filePath}`);
69
81
  }
70
82
  logger.log(`Started: ${new Date().toISOString()}`);
71
- if (parsed.scriptMode) {
72
- // Script mode: run each line
73
- await runScriptMode(parsed.scriptLines, context, totalStart);
83
+ // Build script lines - single prompt/command becomes a 1-step script
84
+ let lines;
85
+ let scriptArgs = [];
86
+ if (parsed.scriptMode && parsed.scriptFile) {
87
+ const script = loadScript(parsed.scriptFile, parsed.scriptArgs);
88
+ lines = script.lines;
89
+ scriptArgs = parsed.scriptArgs;
74
90
  }
75
91
  else {
76
- // Single command mode
77
- await runSingleMode(parsed.prompt, parsed.subcommand, parsed.displayCommand, context, totalStart);
92
+ // Single prompt or command becomes a 1-step script
93
+ lines = [{ type: 'prompt', text: parsed.prompt }];
78
94
  }
95
+ // Run the script
96
+ const success = await runScript(lines, scriptArgs, context, totalStart);
97
+ context.logger.close();
98
+ await flushDeadDrop();
99
+ process.exit(success ? 0 : 1);
79
100
  }
80
101
  /**
81
- * Run in single command mode (prompt or command)
102
+ * Build display string for a script line
82
103
  */
83
- async function runSingleMode(prompt, subcommand, displayCommand, context, startTime) {
84
- context.logger.log(`${subcommand}: ${displayCommand}\n`);
85
- const result = await runWithSignals(prompt, displayCommand, startTime, context);
86
- context.logger.close();
87
- await flushDeadDrop();
88
- process.exit(result === 'ok' ? 0 : 1);
104
+ function getDisplayLine(line) {
105
+ if (line.type === 'prompt') {
106
+ // Replace newlines with spaces for single-line display
107
+ const cleaned = line.text.replace(/[\r\n]+/g, ' ').trim();
108
+ const preview = cleaned.length > 50 ? cleaned.slice(0, 50) + '...' : cleaned;
109
+ return `"${preview}"`;
110
+ }
111
+ return `command("${line.name}")`;
89
112
  }
90
113
  /**
91
- * Run in script mode
114
+ * Run a script (unified execution for single prompts and multi-step scripts)
92
115
  */
93
- async function runScriptMode(scriptLines, context, startTime) {
94
- printRunner(`Running script: ${scriptLines.length} commands`);
95
- context.logger.log(`Script: ${scriptLines.length} commands\n`);
96
- for (const [i, line] of scriptLines.entries()) {
97
- context.logger.log(`\n=== [${i + 1}/${scriptLines.length}] ${line} ===\n`);
98
- let result;
99
- try {
100
- const parsed = parseCommandLine(line);
101
- result = await runWithSignals(parsed.prompt, line, startTime, context);
116
+ async function runScript(lines, scriptArgs, context, startTime) {
117
+ const store = createVariableStore();
118
+ for (const [i, line] of lines.entries()) {
119
+ const stepNum = i + 1;
120
+ const displayLine = getDisplayLine(line);
121
+ context.logger.log(`\n=== Step ${stepNum}: ${displayLine} ===\n`);
122
+ // Get the prompt text
123
+ let promptText;
124
+ if (line.type === 'prompt') {
125
+ promptText = line.text;
102
126
  }
103
- catch (err) {
104
- printRunner(`${colors.red}Parse error:${colors.reset} ${err.message}`);
105
- result = 'error';
127
+ else {
128
+ const template = loadCommandTemplate(line.name, line.args);
129
+ promptText = template.prompt;
106
130
  }
107
- if (result === 'blocked' || result === 'error') {
108
- const totalDuration = Date.now() - startTime;
109
- printRunner(`${colors.red}Script stopped${colors.reset} [${i + 1}/${scriptLines.length}] steps in ${formatDuration(totalDuration)}`);
110
- context.logger.log(`\nSCRIPT STOPPED at step ${i + 1}, ${Math.round(totalDuration / 1000)}s total`);
111
- context.logger.close();
112
- await flushDeadDrop();
113
- process.exit(1);
131
+ // Substitute variables
132
+ const varsUsed = getSubstitutionList(promptText, store);
133
+ const finalPrompt = substituteVariables(promptText, store, scriptArgs);
134
+ // Build display: show substituted prompt and what variables were used
135
+ const substitutedDisplay = getDisplayLine({
136
+ type: 'prompt',
137
+ text: finalPrompt,
138
+ });
139
+ const withClause = formatVarsUsed(varsUsed);
140
+ // Set step number and start time for formatter output
141
+ context.formatterState.currentStep = stepNum;
142
+ context.formatterState.stepStartTime = Date.now();
143
+ // Run via runWithSignals (handles iterations, signals, output)
144
+ const stepContext = { stepNum };
145
+ const result = await runWithSignals(finalPrompt, `${withClause}${substitutedDisplay}`, startTime, context, stepContext);
146
+ // Capture output for variable store
147
+ captureOutput(store, result.claudeText, line.capture);
148
+ // Finalize step stats and print completion
149
+ const stepDurationMs = context.formatterState.stepStartTime
150
+ ? Date.now() - context.formatterState.stepStartTime
151
+ : (context.formatterState.lastStepDurationMs ?? 0);
152
+ const stepSummary = finalizeStepStats(context.formatterState, stepDurationMs);
153
+ printRunner(`Step ${stepNum} complete: ${stepSummary}`);
154
+ // Handle failure (runWithSignals already printed the error)
155
+ if (result.status !== 'ok') {
156
+ return false;
114
157
  }
158
+ // Reset step stats for next step (preserves runStats)
159
+ resetFormatterState(context.formatterState);
115
160
  }
116
- // All commands completed
161
+ // Print run completion with overall stats
117
162
  const totalDuration = Date.now() - startTime;
118
- printRunner(`${colors.green}Script completed${colors.reset} [${scriptLines.length}] steps in ${formatDuration(totalDuration)}`);
119
- context.logger.log(`\nSCRIPT COMPLETE, ${scriptLines.length} commands, ${Math.round(totalDuration / 1000)}s total`);
120
- context.logger.close();
121
- await flushDeadDrop();
122
- process.exit(0);
163
+ const runSummary = getRunStatsSummary(context.formatterState, totalDuration);
164
+ printRunner(`Run ${context.runId} complete: ${runSummary}`);
165
+ return true;
123
166
  }
124
167
  // Run main
125
168
  main().catch((err) => {
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,8 @@
1
1
  /**
2
2
  * ANSI color codes for terminal output
3
3
  */
4
+ import { configureDeadDrop, flushDeadDrop } from './deaddrop-queue.js';
5
+ export { configureDeadDrop, flushDeadDrop };
4
6
  export declare const colors: {
5
7
  readonly reset: "\u001B[0m";
6
8
  readonly dim: "\u001B[2m";
@@ -14,6 +16,16 @@ export declare const colors: {
14
16
  };
15
17
  export type ColorName = keyof typeof colors;
16
18
  export declare function stripAnsi(str: string): string;
19
+ /**
20
+ * Strip carriage returns for cleaner terminal display
21
+ * Tool outputs sometimes contain CRs that cause display issues
22
+ */
23
+ export declare function stripCR(str: string): string;
24
+ /**
25
+ * Log to terminal with CR stripping for clean display
26
+ * Use this for all terminal output in the formatter
27
+ */
28
+ export declare function terminalLog(line: string): void;
17
29
  /**
18
30
  * Apply color to a string
19
31
  */
@@ -24,7 +36,7 @@ export declare function colorize(text: string, color: ColorName): string;
24
36
  export declare function truncate(str: string, len: number): string;
25
37
  /**
26
38
  * Format duration in human-readable form
27
- * Examples: 450ms, 2.5s, 1m30s, 1h2m3s
39
+ * Examples: 450ms, 2.5s, 1m 30s, 1h 2m 3s
28
40
  */
29
41
  export declare function formatDuration(ms: number): string;
30
42
  /**
@@ -47,16 +59,6 @@ export type DeadDropUser = 'Runner' | 'Claude Code';
47
59
  * Deaddrop send function type (to avoid circular imports)
48
60
  */
49
61
  export type DeadDropSender = (content: string, user: DeadDropUser) => Promise<void>;
50
- /**
51
- * Configure the deaddrop sender for all output functions
52
- * Call once at startup when --deaddrop is enabled
53
- */
54
- export declare function configureDeadDrop(sender: DeadDropSender | null): void;
55
- /**
56
- * Flush all pending deaddrop sends
57
- * Call before process.exit to ensure all messages are sent
58
- */
59
- export declare function flushDeadDrop(): Promise<void>;
60
62
  /**
61
63
  * Print a [RUNNER] operational message with timestamp
62
64
  * Automatically sends to Deaddrop if configured (without prefix)
@@ -70,6 +72,8 @@ export declare function printRunnerInfo(message: string): void;
70
72
  /**
71
73
  * Print a [CLAUDE] message with timestamp
72
74
  * Automatically sends to Deaddrop if configured (without prefix)
75
+ * @param message - Display message (may be truncated/formatted for console)
76
+ * @param rawForDeaddrop - Original unmodified text to send to deaddrop (preserves newlines)
73
77
  */
74
- export declare function printClaude(message: string): void;
78
+ export declare function printClaude(message: string, rawForDeaddrop?: string): void;
75
79
  //# sourceMappingURL=colors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../src/output/colors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,eAAO,MAAM,MAAM;;;;;;;;;;CAUT,CAAC;AAEX,MAAM,MAAM,SAAS,GAAG,MAAM,OAAO,MAAM,CAAC;AAQ5C,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAE7C;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,MAAM,CAE/D;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAKzD;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAejD;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAOpD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,GAAE,IAAiB,GAAG,MAAM,CAM/D;AAED;;GAEG;AACH,wBAAgB,eAAe,IAAI,MAAM,CAExC;AAED;;GAEG;AACH,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,aAAa,CAAC;AAEpD;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,CAC3B,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,YAAY,KACf,OAAO,CAAC,IAAI,CAAC,CAAC;AAkBnB;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI,CAErE;AAwBD;;;GAGG;AACH,wBAAsB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAUnD;AAYD;;;GAGG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAKjD;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAIrD;AAED;;;GAGG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAKjD"}
1
+ {"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../src/output/colors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,iBAAiB,EACjB,aAAa,EAEd,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,CAAC;AAE5C,eAAO,MAAM,MAAM;;;;;;;;;;CAUT,CAAC;AAEX,MAAM,MAAM,SAAS,GAAG,MAAM,OAAO,MAAM,CAAC;AAQ5C,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAE7C;AAED;;;GAGG;AACH,wBAAgB,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAE3C;AAED;;;GAGG;AACH,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAE9C;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,MAAM,CAE/D;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAKzD;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAejD;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAOpD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,GAAE,IAAiB,GAAG,MAAM,CAM/D;AAED;;GAEG;AACH,wBAAgB,eAAe,IAAI,MAAM,CAExC;AAED;;GAEG;AACH,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,aAAa,CAAC;AAEpD;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,CAC3B,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,YAAY,KACf,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnB;;;GAGG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAKjD;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAIrD;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAK1E"}
@@ -1,6 +1,9 @@
1
1
  /**
2
2
  * ANSI color codes for terminal output
3
3
  */
4
+ import { configureDeadDrop, flushDeadDrop, sendToDeadDrop, } from './deaddrop-queue.js';
5
+ // Re-export deaddrop functions for backward compatibility
6
+ export { configureDeadDrop, flushDeadDrop };
4
7
  export const colors = {
5
8
  reset: '\x1b[0m',
6
9
  dim: '\x1b[2m',
@@ -20,6 +23,20 @@ const ANSI_REGEX = /\x1b\[[0-9;]*[a-zA-Z]/g;
20
23
  export function stripAnsi(str) {
21
24
  return str.replace(ANSI_REGEX, '');
22
25
  }
26
+ /**
27
+ * Strip carriage returns for cleaner terminal display
28
+ * Tool outputs sometimes contain CRs that cause display issues
29
+ */
30
+ export function stripCR(str) {
31
+ return str.replace(/\r/g, '');
32
+ }
33
+ /**
34
+ * Log to terminal with CR stripping for clean display
35
+ * Use this for all terminal output in the formatter
36
+ */
37
+ export function terminalLog(line) {
38
+ console.log(stripCR(line));
39
+ }
23
40
  /**
24
41
  * Apply color to a string
25
42
  */
@@ -37,7 +54,7 @@ export function truncate(str, len) {
37
54
  }
38
55
  /**
39
56
  * Format duration in human-readable form
40
- * Examples: 450ms, 2.5s, 1m30s, 1h2m3s
57
+ * Examples: 450ms, 2.5s, 1m 30s, 1h 2m 3s
41
58
  */
42
59
  export function formatDuration(ms) {
43
60
  if (ms < 1000) {
@@ -51,9 +68,9 @@ export function formatDuration(ms) {
51
68
  const mins = Math.floor((totalSeconds % 3600) / 60);
52
69
  const secs = Math.round(totalSeconds % 60);
53
70
  if (hours > 0) {
54
- return `${hours}h${mins}m${secs}s`;
71
+ return `${hours}h ${mins}m ${secs}s`;
55
72
  }
56
- return `${mins}m${secs}s`;
73
+ return `${mins}m ${secs}s`;
57
74
  }
58
75
  /**
59
76
  * Shorten file paths by removing common prefixes
@@ -82,69 +99,12 @@ export function formatTimestamp(date = new Date()) {
82
99
  export function timestampPrefix() {
83
100
  return `${colors.dim}${formatTimestamp()}${colors.reset} `;
84
101
  }
85
- /**
86
- * Module-level deaddrop sender, configured once at startup
87
- */
88
- let deadDropSender = null;
89
- const messageQueue = [];
90
- let isProcessing = false;
91
- let flushResolve = null;
92
- /**
93
- * Configure the deaddrop sender for all output functions
94
- * Call once at startup when --deaddrop is enabled
95
- */
96
- export function configureDeadDrop(sender) {
97
- deadDropSender = sender;
98
- }
99
- /**
100
- * Process queued messages one at a time
101
- */
102
- async function processQueue() {
103
- if (isProcessing || !deadDropSender)
104
- return;
105
- isProcessing = true;
106
- let msg = messageQueue.shift();
107
- while (msg) {
108
- await deadDropSender(msg.content, msg.user);
109
- msg = messageQueue.shift();
110
- }
111
- isProcessing = false;
112
- // Resolve flush promise if waiting
113
- if (flushResolve && messageQueue.length === 0) {
114
- flushResolve();
115
- flushResolve = null;
116
- }
117
- }
118
- /**
119
- * Flush all pending deaddrop sends
120
- * Call before process.exit to ensure all messages are sent
121
- */
122
- export async function flushDeadDrop() {
123
- if (messageQueue.length === 0 && !isProcessing)
124
- return;
125
- return new Promise((resolve) => {
126
- flushResolve = resolve;
127
- // If not already processing, start
128
- if (!isProcessing) {
129
- void processQueue();
130
- }
131
- });
132
- }
133
- /**
134
- * Send a message to deaddrop if configured
135
- */
136
- function sendToDeadDrop(message, user) {
137
- if (deadDropSender) {
138
- messageQueue.push({ content: message, user });
139
- void processQueue();
140
- }
141
- }
142
102
  /**
143
103
  * Print a [RUNNER] operational message with timestamp
144
104
  * Automatically sends to Deaddrop if configured (without prefix)
145
105
  */
146
106
  export function printRunner(message) {
147
- console.log(`${timestampPrefix()}${colors.magenta}[RUNNER]${colors.reset} ${message}`);
107
+ terminalLog(`${timestampPrefix()}${colors.magenta}[RUNNER]${colors.reset} ${message}`);
148
108
  sendToDeadDrop(stripAnsi(message), 'Runner');
149
109
  }
150
110
  /**
@@ -152,14 +112,16 @@ export function printRunner(message) {
152
112
  * Does NOT send to Deaddrop (used for startup config, debug info)
153
113
  */
154
114
  export function printRunnerInfo(message) {
155
- console.log(`${timestampPrefix()}${colors.magenta}[RUNNER]${colors.reset} ${message}`);
115
+ terminalLog(`${timestampPrefix()}${colors.magenta}[RUNNER]${colors.reset} ${message}`);
156
116
  }
157
117
  /**
158
118
  * Print a [CLAUDE] message with timestamp
159
119
  * Automatically sends to Deaddrop if configured (without prefix)
120
+ * @param message - Display message (may be truncated/formatted for console)
121
+ * @param rawForDeaddrop - Original unmodified text to send to deaddrop (preserves newlines)
160
122
  */
161
- export function printClaude(message) {
162
- console.log(`${timestampPrefix()}${colors.green}[CLAUDE]${colors.reset} ${message}`);
163
- sendToDeadDrop(stripAnsi(message), 'Claude Code');
123
+ export function printClaude(message, rawForDeaddrop) {
124
+ terminalLog(`${timestampPrefix()}${colors.green}[CLAUDE]${colors.reset} ${message}`);
125
+ sendToDeadDrop(stripAnsi(rawForDeaddrop ?? message), 'Claude Code');
164
126
  }
165
127
  //# sourceMappingURL=colors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"colors.js","sourceRoot":"","sources":["../../src/output/colors.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"colors.js","sourceRoot":"","sources":["../../src/output/colors.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Serial message queue for deaddrop communication
3
+ * Encapsulates module-level state into a testable class
4
+ */
5
+ import type { DeadDropSender, DeadDropUser } from './colors.js';
6
+ /**
7
+ * Serial message queue for deaddrop communication
8
+ * Ensures messages are sent one at a time in order
9
+ */
10
+ export declare class DeadDropQueue {
11
+ private sender;
12
+ private messageQueue;
13
+ private isProcessing;
14
+ private flushResolve;
15
+ /**
16
+ * Configure the sender function
17
+ * Call once at startup when --deaddrop is enabled
18
+ */
19
+ configure(sender: DeadDropSender | null): void;
20
+ /**
21
+ * Enqueue a message for sending
22
+ */
23
+ send(message: string, user: DeadDropUser): void;
24
+ /**
25
+ * Wait for all pending messages to be sent
26
+ * Call before process.exit to ensure delivery
27
+ */
28
+ flush(): Promise<void>;
29
+ private processQueue;
30
+ }
31
+ /**
32
+ * Configure the deaddrop sender for all output functions
33
+ * Call once at startup when --deaddrop is enabled
34
+ */
35
+ export declare function configureDeadDrop(sender: DeadDropSender | null): void;
36
+ /**
37
+ * Send a message to deaddrop if configured
38
+ */
39
+ export declare function sendToDeadDrop(message: string, user: DeadDropUser): void;
40
+ /**
41
+ * Flush all pending deaddrop sends
42
+ * Call before process.exit to ensure all messages are sent
43
+ */
44
+ export declare function flushDeadDrop(): Promise<void>;
45
+ //# sourceMappingURL=deaddrop-queue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deaddrop-queue.d.ts","sourceRoot":"","sources":["../../src/output/deaddrop-queue.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAOhE;;;GAGG;AACH,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAA+B;IAC7C,OAAO,CAAC,YAAY,CAAuB;IAC3C,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,YAAY,CAA6B;IAEjD;;;OAGG;IACH,SAAS,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI;IAI9C;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,GAAG,IAAI;IAO/C;;;OAGG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;YAWd,YAAY;CAiB3B;AAKD;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI,CAErE;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,GAAG,IAAI,CAExE;AAED;;;GAGG;AACH,wBAAsB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAEnD"}
@@ -0,0 +1,82 @@
1
+ /**
2
+ * Serial message queue for deaddrop communication
3
+ * Encapsulates module-level state into a testable class
4
+ */
5
+ /**
6
+ * Serial message queue for deaddrop communication
7
+ * Ensures messages are sent one at a time in order
8
+ */
9
+ export class DeadDropQueue {
10
+ sender = null;
11
+ messageQueue = [];
12
+ isProcessing = false;
13
+ flushResolve = null;
14
+ /**
15
+ * Configure the sender function
16
+ * Call once at startup when --deaddrop is enabled
17
+ */
18
+ configure(sender) {
19
+ this.sender = sender;
20
+ }
21
+ /**
22
+ * Enqueue a message for sending
23
+ */
24
+ send(message, user) {
25
+ if (this.sender) {
26
+ this.messageQueue.push({ content: message, user });
27
+ void this.processQueue();
28
+ }
29
+ }
30
+ /**
31
+ * Wait for all pending messages to be sent
32
+ * Call before process.exit to ensure delivery
33
+ */
34
+ async flush() {
35
+ if (this.messageQueue.length === 0 && !this.isProcessing)
36
+ return;
37
+ return new Promise((resolve) => {
38
+ this.flushResolve = resolve;
39
+ if (!this.isProcessing) {
40
+ void this.processQueue();
41
+ }
42
+ });
43
+ }
44
+ async processQueue() {
45
+ if (this.isProcessing || !this.sender)
46
+ return;
47
+ this.isProcessing = true;
48
+ let msg = this.messageQueue.shift();
49
+ while (msg) {
50
+ await this.sender(msg.content, msg.user);
51
+ msg = this.messageQueue.shift();
52
+ }
53
+ this.isProcessing = false;
54
+ if (this.flushResolve && this.messageQueue.length === 0) {
55
+ this.flushResolve();
56
+ this.flushResolve = null;
57
+ }
58
+ }
59
+ }
60
+ // Singleton instance (maintains backward compatibility)
61
+ const defaultQueue = new DeadDropQueue();
62
+ /**
63
+ * Configure the deaddrop sender for all output functions
64
+ * Call once at startup when --deaddrop is enabled
65
+ */
66
+ export function configureDeadDrop(sender) {
67
+ defaultQueue.configure(sender);
68
+ }
69
+ /**
70
+ * Send a message to deaddrop if configured
71
+ */
72
+ export function sendToDeadDrop(message, user) {
73
+ defaultQueue.send(message, user);
74
+ }
75
+ /**
76
+ * Flush all pending deaddrop sends
77
+ * Call before process.exit to ensure all messages are sent
78
+ */
79
+ export async function flushDeadDrop() {
80
+ return defaultQueue.flush();
81
+ }
82
+ //# sourceMappingURL=deaddrop-queue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deaddrop-queue.js","sourceRoot":"","sources":["../../src/output/deaddrop-queue.ts"],"names":[],"mappings":"AAAA;;;GAGG;AASH;;;GAGG;AACH,MAAM,OAAO,aAAa;IAChB,MAAM,GAA0B,IAAI,CAAC;IACrC,YAAY,GAAoB,EAAE,CAAC;IACnC,YAAY,GAAG,KAAK,CAAC;IACrB,YAAY,GAAwB,IAAI,CAAC;IAEjD;;;OAGG;IACH,SAAS,CAAC,MAA6B;QACrC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI,CAAC,OAAe,EAAE,IAAkB;QACtC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;YACnD,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO;QAEjE,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YACnC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;YAC5B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACvB,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,YAAY;QACxB,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QAC9C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAEzB,IAAI,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QACpC,OAAO,GAAG,EAAE,CAAC;YACX,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;YACzC,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAClC,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAE1B,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxD,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;IACH,CAAC;CACF;AAED,wDAAwD;AACxD,MAAM,YAAY,GAAG,IAAI,aAAa,EAAE,CAAC;AAEzC;;;GAGG;AACH,MAAM,UAAU,iBAAiB,CAAC,MAA6B;IAC7D,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;AACjC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,OAAe,EAAE,IAAkB;IAChE,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AACnC,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa;IACjC,OAAO,YAAY,CAAC,KAAK,EAAE,CAAC;AAC9B,CAAC"}
@@ -4,6 +4,7 @@
4
4
  import { type ClaudeMessage } from '../types/claude.js';
5
5
  import { type ActiveTask, type PendingTool, type Verbosity } from '../types/runner.js';
6
6
  import type { Logger } from './logger.js';
7
+ import { type RunStats } from './stats.js';
7
8
  /**
8
9
  * State for tracking parallel tool calls and active tasks
9
10
  */
@@ -13,9 +14,31 @@ export interface FormatterState {
13
14
  activeTask: ActiveTask | null;
14
15
  toolStartTimes: Map<string, number>;
15
16
  currentStep: number;
17
+ /** When true, step completion is not printed (caller handles it) */
18
+ suppressStepCompletion: boolean;
19
+ /** Duration from last result message (for caller to use) */
20
+ lastStepDurationMs: number | null;
21
+ /** Run statistics for current step */
22
+ stats: RunStats;
23
+ /** Overall run statistics (accumulated across steps) */
24
+ runStats: RunStats;
25
+ /** Step start time */
26
+ stepStartTime: number | null;
27
+ /** Task statistics (for nested task tracking) */
28
+ taskStats: RunStats | null;
29
+ /** Task start time */
30
+ taskStartTime: number | null;
16
31
  }
17
32
  export declare function createFormatterState(): FormatterState;
18
33
  export declare function resetFormatterState(state: FormatterState): void;
34
+ /**
35
+ * Finalize step stats: merge into runStats and return step summary
36
+ */
37
+ export declare function finalizeStepStats(state: FormatterState, stepDurationMs: number): string;
38
+ /**
39
+ * Get the overall run stats summary
40
+ */
41
+ export declare function getRunStatsSummary(state: FormatterState, runDurationMs: number): string;
19
42
  /**
20
43
  * Flush pending tools, grouping parallel calls
21
44
  */
@@ -1 +1 @@
1
- {"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../../src/output/formatter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,KAAK,aAAa,EASnB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,KAAK,UAAU,EAEf,KAAK,WAAW,EAChB,KAAK,SAAS,EACf,MAAM,oBAAoB,CAAC;AAU5B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,oBAAoB,IAAI,cAAc,CAQrD;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI,CAK/D;AAwED;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,SAAS,GACnB,IAAI,CAuBN;AAoFD;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,GAAG,EAAE,aAAa,EAClB,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,MAAM,EAAE,sCAAsC;AACvD,mBAAmB,EAAE,MAAM,GAC1B,MAAM,CA2GR"}
1
+ {"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../../src/output/formatter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,KAAK,aAAa,EASnB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,KAAK,UAAU,EAEf,KAAK,WAAW,EAChB,KAAK,SAAS,EACf,MAAM,oBAAoB,CAAC;AAuB5B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAQL,KAAK,QAAQ,EAEd,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC9B,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,WAAW,EAAE,MAAM,CAAC;IACpB,oEAAoE;IACpE,sBAAsB,EAAE,OAAO,CAAC;IAChC,4DAA4D;IAC5D,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,sCAAsC;IACtC,KAAK,EAAE,QAAQ,CAAC;IAChB,wDAAwD;IACxD,QAAQ,EAAE,QAAQ,CAAC;IACnB,sBAAsB;IACtB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,iDAAiD;IACjD,SAAS,EAAE,QAAQ,GAAG,IAAI,CAAC;IAC3B,sBAAsB;IACtB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,wBAAgB,oBAAoB,IAAI,cAAc,CAerD;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI,CAU/D;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,cAAc,EACrB,cAAc,EAAE,MAAM,GACrB,MAAM,CAKR;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,cAAc,EACrB,aAAa,EAAE,MAAM,GACpB,MAAM,CAER;AA2ED;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,SAAS,GACnB,IAAI,CAuBN;AA0ED;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,GAAG,EAAE,aAAa,EAClB,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,MAAM,EAAE,sCAAsC;AACvD,mBAAmB,EAAE,MAAM,GAC1B,MAAM,CA8HR"}