@stackmemoryai/stackmemory 0.5.66 → 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.
- package/README.md +139 -45
- package/bin/codex-sm +6 -0
- package/bin/opencode-sm +1 -1
- package/dist/src/cli/claude-sm.js +162 -25
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/commands/ping.js +14 -0
- package/dist/src/cli/commands/ping.js.map +7 -0
- package/dist/src/cli/commands/ralph.js +103 -1
- package/dist/src/cli/commands/ralph.js.map +2 -2
- package/dist/src/cli/commands/retrieval.js +1 -1
- package/dist/src/cli/commands/retrieval.js.map +2 -2
- package/dist/src/cli/commands/skills.js +201 -6
- package/dist/src/cli/commands/skills.js.map +2 -2
- package/dist/src/cli/index.js +66 -27
- package/dist/src/cli/index.js.map +2 -2
- package/dist/src/core/digest/types.js +1 -1
- package/dist/src/core/digest/types.js.map +1 -1
- package/dist/src/core/extensions/provider-adapter.js +2 -5
- package/dist/src/core/extensions/provider-adapter.js.map +2 -2
- package/dist/src/core/retrieval/llm-provider.js +2 -2
- package/dist/src/core/retrieval/llm-provider.js.map +1 -1
- package/dist/src/core/retrieval/types.js +1 -1
- package/dist/src/core/retrieval/types.js.map +1 -1
- package/dist/src/features/sweep/pty-wrapper.js +15 -5
- package/dist/src/features/sweep/pty-wrapper.js.map +2 -2
- package/dist/src/features/workers/tmux-manager.js +71 -0
- package/dist/src/features/workers/tmux-manager.js.map +7 -0
- package/dist/src/features/workers/worker-registry.js +52 -0
- package/dist/src/features/workers/worker-registry.js.map +7 -0
- package/dist/src/integrations/linear/webhook-handler.js +82 -0
- package/dist/src/integrations/linear/webhook-handler.js.map +2 -2
- package/dist/src/integrations/mcp/server.js +16 -10
- package/dist/src/integrations/mcp/server.js.map +2 -2
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +2 -2
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +2 -2
- package/dist/src/orchestrators/multimodal/constants.js +1 -1
- package/dist/src/orchestrators/multimodal/constants.js.map +1 -1
- package/dist/src/orchestrators/multimodal/harness.js +28 -29
- package/dist/src/orchestrators/multimodal/harness.js.map +2 -2
- package/dist/src/orchestrators/multimodal/providers.js +35 -22
- package/dist/src/orchestrators/multimodal/providers.js.map +2 -2
- package/dist/src/skills/claude-skills.js +116 -1
- package/dist/src/skills/claude-skills.js.map +2 -2
- package/dist/src/skills/linear-task-runner.js +262 -0
- package/dist/src/skills/linear-task-runner.js.map +7 -0
- package/dist/src/skills/recursive-agent-orchestrator.js +114 -85
- package/dist/src/skills/recursive-agent-orchestrator.js.map +2 -2
- package/dist/src/skills/spec-generator-skill.js +441 -0
- package/dist/src/skills/spec-generator-skill.js.map +7 -0
- package/package.json +12 -5
- package/scripts/install-claude-hooks-auto.js +23 -9
- package/scripts/install-claude-hooks.sh +2 -2
- package/templates/claude-hooks/hooks.json +4 -2
- package/templates/claude-hooks/on-task-complete.js +91 -0
- package/templates/claude-hooks/post-edit-sweep.js +7 -10
- package/templates/claude-hooks/skill-eval.cjs +411 -0
- package/templates/claude-hooks/skill-eval.sh +31 -0
- package/templates/claude-hooks/skill-rules.json +274 -0
package/dist/src/cli/index.js
CHANGED
|
@@ -51,12 +51,12 @@ import { createRetrievalCommands } from "./commands/retrieval.js";
|
|
|
51
51
|
import { createDiscoveryCommands } from "./commands/discovery.js";
|
|
52
52
|
import { createModelCommand } from "./commands/model.js";
|
|
53
53
|
import { registerSetupCommands } from "./commands/setup.js";
|
|
54
|
+
import { createPingCommand } from "./commands/ping.js";
|
|
54
55
|
import chalk from "chalk";
|
|
55
56
|
import * as fs from "fs";
|
|
56
57
|
import * as path from "path";
|
|
57
58
|
import { filterPending } from "../integrations/mcp/pending-utils.js";
|
|
58
59
|
import { ProjectManager } from "../core/projects/project-manager.js";
|
|
59
|
-
import Database from "better-sqlite3";
|
|
60
60
|
import { join } from "path";
|
|
61
61
|
import { existsSync, mkdirSync } from "fs";
|
|
62
62
|
import inquirer from "inquirer";
|
|
@@ -82,6 +82,13 @@ function findPackageJson() {
|
|
|
82
82
|
return { version: "0.0.0" };
|
|
83
83
|
}
|
|
84
84
|
const VERSION = findPackageJson().version;
|
|
85
|
+
async function openDatabase(dbPath) {
|
|
86
|
+
const { default: Database } = await import("better-sqlite3");
|
|
87
|
+
return new Database(dbPath);
|
|
88
|
+
}
|
|
89
|
+
function isTestEnv() {
|
|
90
|
+
return process.env["VITEST"] === "true" || process.env["NODE_ENV"] === "test" || process.env["STACKMEMORY_TEST_SKIP_DB"] === "1";
|
|
91
|
+
}
|
|
85
92
|
UpdateChecker.checkForUpdates(VERSION, true).catch(() => {
|
|
86
93
|
});
|
|
87
94
|
async function startNotificationServices() {
|
|
@@ -186,13 +193,15 @@ program.command("init").description(
|
|
|
186
193
|
}
|
|
187
194
|
}
|
|
188
195
|
const dbPath = join(dbDir, "context.db");
|
|
189
|
-
|
|
190
|
-
|
|
196
|
+
if (!isTestEnv()) {
|
|
197
|
+
const db = await openDatabase(dbPath);
|
|
198
|
+
new FrameManager(db, "cli-project");
|
|
199
|
+
db.close();
|
|
200
|
+
}
|
|
191
201
|
logger.info("StackMemory initialized successfully", { projectRoot });
|
|
192
202
|
console.log(chalk.green("\n[OK] StackMemory initialized"));
|
|
193
203
|
console.log(chalk.gray(` Project: ${projectRoot}`));
|
|
194
204
|
console.log(chalk.gray(` Storage: SQLite (local)`));
|
|
195
|
-
db.close();
|
|
196
205
|
if (options.daemon) {
|
|
197
206
|
console.log(chalk.cyan("\nInstalling background service..."));
|
|
198
207
|
try {
|
|
@@ -276,6 +285,13 @@ program.command("status").description("Show current StackMemory status").option(
|
|
|
276
285
|
);
|
|
277
286
|
return;
|
|
278
287
|
}
|
|
288
|
+
if (isTestEnv()) {
|
|
289
|
+
console.log("\u{1F4CA} StackMemory Status (test mode):");
|
|
290
|
+
console.log(" Frames: n/a");
|
|
291
|
+
console.log(" Events: n/a");
|
|
292
|
+
console.log(" Sessions: n/a");
|
|
293
|
+
return;
|
|
294
|
+
}
|
|
279
295
|
await UpdateChecker.checkForUpdates(VERSION);
|
|
280
296
|
await sessionManager.initialize();
|
|
281
297
|
await sharedContextLayer.initialize();
|
|
@@ -304,7 +320,7 @@ program.command("status").description("Show current StackMemory status").option(
|
|
|
304
320
|
);
|
|
305
321
|
}
|
|
306
322
|
}
|
|
307
|
-
const db =
|
|
323
|
+
const db = await openDatabase(dbPath);
|
|
308
324
|
const frameManager = new FrameManager(db, session.projectId);
|
|
309
325
|
if (options.all) {
|
|
310
326
|
frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);
|
|
@@ -493,7 +509,11 @@ program.command("context:test").description("Test context persistence by creatin
|
|
|
493
509
|
);
|
|
494
510
|
return;
|
|
495
511
|
}
|
|
496
|
-
|
|
512
|
+
if (isTestEnv()) {
|
|
513
|
+
console.log("\u{1F4DD} [test] Skipping DB write in context:test");
|
|
514
|
+
return;
|
|
515
|
+
}
|
|
516
|
+
const db = await openDatabase(dbPath);
|
|
497
517
|
const frameManager = new FrameManager(db, "cli-project");
|
|
498
518
|
console.log("\u{1F4DD} Creating test context frames...");
|
|
499
519
|
const rootFrame = frameManager.createFrame({
|
|
@@ -561,17 +581,22 @@ program.addCommand(createMemoryCommand());
|
|
|
561
581
|
program.addCommand(clearCommand);
|
|
562
582
|
program.addCommand(serviceCommand);
|
|
563
583
|
program.addCommand(createHooksCommand());
|
|
584
|
+
const lazyCommands = [];
|
|
564
585
|
if (isFeatureEnabled("skills")) {
|
|
565
|
-
|
|
566
|
-
(
|
|
567
|
-
|
|
568
|
-
|
|
586
|
+
lazyCommands.push(
|
|
587
|
+
import("./commands/skills.js").then(
|
|
588
|
+
({ createSkillsCommand }) => program.addCommand(createSkillsCommand())
|
|
589
|
+
).catch(() => {
|
|
590
|
+
})
|
|
591
|
+
);
|
|
569
592
|
}
|
|
570
593
|
if (isFeatureEnabled("ralph")) {
|
|
571
|
-
|
|
572
|
-
(
|
|
573
|
-
|
|
574
|
-
|
|
594
|
+
lazyCommands.push(
|
|
595
|
+
import("./commands/ralph.js").then(
|
|
596
|
+
({ default: createRalphCommand }) => program.addCommand(createRalphCommand())
|
|
597
|
+
).catch(() => {
|
|
598
|
+
})
|
|
599
|
+
);
|
|
575
600
|
}
|
|
576
601
|
program.addCommand(createDaemonCommand());
|
|
577
602
|
program.addCommand(createSweepCommand());
|
|
@@ -580,11 +605,14 @@ program.addCommand(createAPICommand());
|
|
|
580
605
|
program.addCommand(createCleanupProcessesCommand());
|
|
581
606
|
program.addCommand(createAutoBackgroundCommand());
|
|
582
607
|
program.addCommand(createSettingsCommand());
|
|
608
|
+
program.addCommand(createPingCommand());
|
|
583
609
|
if (isFeatureEnabled("whatsapp")) {
|
|
584
|
-
|
|
585
|
-
(
|
|
586
|
-
|
|
587
|
-
|
|
610
|
+
lazyCommands.push(
|
|
611
|
+
import("./commands/sms-notify.js").then(
|
|
612
|
+
({ createSMSNotifyCommand }) => program.addCommand(createSMSNotifyCommand())
|
|
613
|
+
).catch(() => {
|
|
614
|
+
})
|
|
615
|
+
);
|
|
588
616
|
}
|
|
589
617
|
program.addCommand(createRetrievalCommands());
|
|
590
618
|
program.addCommand(createDiscoveryCommands());
|
|
@@ -599,11 +627,11 @@ program.command("mm-spike").description(
|
|
|
599
627
|
).option(
|
|
600
628
|
"--planner-model <name>",
|
|
601
629
|
"Claude model for planning",
|
|
602
|
-
"claude-
|
|
630
|
+
"claude-sonnet-4-20250514"
|
|
603
631
|
).option(
|
|
604
632
|
"--reviewer-model <name>",
|
|
605
633
|
"Claude model for review",
|
|
606
|
-
"claude-
|
|
634
|
+
"claude-sonnet-4-20250514"
|
|
607
635
|
).option(
|
|
608
636
|
"--execute",
|
|
609
637
|
"Execute implementer (codex-sm) instead of dry-run",
|
|
@@ -680,12 +708,12 @@ program.command("build").description(
|
|
|
680
708
|
).option(
|
|
681
709
|
"--planner-model <name>",
|
|
682
710
|
"Claude model for planning",
|
|
683
|
-
"claude-
|
|
711
|
+
"claude-sonnet-4-20250514"
|
|
684
712
|
).option(
|
|
685
713
|
"--reviewer-model <name>",
|
|
686
714
|
"Claude model for review",
|
|
687
|
-
"claude-
|
|
688
|
-
).option("--execute", "Execute implementer (default: true)", true).option("--dry-run", "Skip execution, show commands only").option("--implementer <name>", "codex|claude", "codex").option("--max-iters <n>", "Retry loop iterations", "2").option("--audit-dir <path>", "Persist spike results to directory").option("--record-frame", "Record as real frame with anchors").option("--record", "Record plan & critique into StackMemory context").option("--json", "Emit single JSON result (UI-friendly)").option("--quiet", "Minimal output").option("--verbose", "Verbose sectioned output").option("--log", "Pretty print interaction log (default: true)", true).action(async (taskArg, opts) => {
|
|
715
|
+
"claude-sonnet-4-20250514"
|
|
716
|
+
).option("--execute", "Execute implementer (default: true)", true).option("--dry-run", "Skip execution, show commands only").option("--implementer <name>", "codex|claude", "codex").option("--max-iters <n>", "Retry loop iterations", "2").option("--audit-dir <path>", "Persist spike results to directory").option("--record-frame", "Record as real frame with anchors").option("--record", "Record plan & critique into StackMemory context").option("--json", "Emit single JSON result (UI-friendly)").option("--quiet", "Minimal output").option("--verbose", "Verbose sectioned output").option("--log", "Pretty print interaction log (default: true)", true).option("-C, --cwd <path>", "Working directory for implementation").action(async (taskArg, opts) => {
|
|
689
717
|
try {
|
|
690
718
|
const task = typeof taskArg === "string" && taskArg.length > 0 ? taskArg : opts.task;
|
|
691
719
|
if (!task) {
|
|
@@ -701,8 +729,19 @@ program.command("build").description(
|
|
|
701
729
|
}
|
|
702
730
|
const { runSpike } = await import("../orchestrators/multimodal/harness.js");
|
|
703
731
|
const dryRun = opts.dryRun === true || opts.execute === false;
|
|
732
|
+
const findGitRoot = (startDir) => {
|
|
733
|
+
let dir = startDir;
|
|
734
|
+
while (dir !== "/") {
|
|
735
|
+
if (existsSync(join(dir, ".git"))) {
|
|
736
|
+
return dir;
|
|
737
|
+
}
|
|
738
|
+
dir = path.dirname(dir);
|
|
739
|
+
}
|
|
740
|
+
return startDir;
|
|
741
|
+
};
|
|
742
|
+
const repoPath = opts.cwd ? path.resolve(opts.cwd) : findGitRoot(process.cwd());
|
|
704
743
|
const result = await runSpike(
|
|
705
|
-
{ task, repoPath
|
|
744
|
+
{ task, repoPath },
|
|
706
745
|
{
|
|
707
746
|
plannerModel: opts.plannerModel,
|
|
708
747
|
reviewerModel: opts.reviewerModel,
|
|
@@ -837,7 +876,7 @@ program.command("pending:list").description(
|
|
|
837
876
|
}
|
|
838
877
|
const items = Object.entries(pending).map(([approvalId, data]) => ({
|
|
839
878
|
approvalId,
|
|
840
|
-
task: data?.task,
|
|
879
|
+
task: data?.task ?? "",
|
|
841
880
|
createdAt: Number(data?.createdAt || 0) || null
|
|
842
881
|
}));
|
|
843
882
|
const filters = {
|
|
@@ -861,7 +900,7 @@ program.command("pending:list").description(
|
|
|
861
900
|
program.command("plan").description("Generate an implementation plan (no code execution)").option("-t, --task <desc>", "Task description", "Plan a small change").option(
|
|
862
901
|
"--planner-model <name>",
|
|
863
902
|
"Claude model for planning",
|
|
864
|
-
"claude-
|
|
903
|
+
"claude-sonnet-4-20250514"
|
|
865
904
|
).option("--json", "Emit JSON (default)", true).option("--pretty", "Pretty-print JSON", false).option(
|
|
866
905
|
"--compact",
|
|
867
906
|
"Compact output (summary + step titles + criteria)",
|
|
@@ -904,7 +943,7 @@ if (process.argv.length > 2) {
|
|
|
904
943
|
}
|
|
905
944
|
const isMainModule = import.meta.url === `file://${process.argv[1]}` || process.argv[1]?.endsWith("/stackmemory") || process.argv[1]?.endsWith("index.ts") || process.argv[1]?.includes("tsx");
|
|
906
945
|
if (isMainModule) {
|
|
907
|
-
program.parse();
|
|
946
|
+
Promise.all(lazyCommands).then(() => program.parse());
|
|
908
947
|
}
|
|
909
948
|
export {
|
|
910
949
|
program
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/cli/index.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/index.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.js';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { filterPending } from '../integrations/mcp/pending-utils.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport type {\n HarnessResult,\n PlanStep,\n} from '../orchestrators/multimodal/types.js';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().version;\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n 'Initialize StackMemory in current project (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n }\n }\n\n // Initialize SQLite database\n const dbPath = join(dbDir, 'context.db');\n const db = new Database(dbPath);\n new FrameManager(db, 'cli-project');\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n db.close();\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register skills commands (optional, lazy-loaded)\nif (isFeatureEnabled('skills')) {\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n });\n}\n\n// Register ralph commands (feature-flagged, lazy-loaded)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n });\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n });\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\n\n// Multi-modal spike: planner (Claude), implementer (Codex), critic (Claude)\nprogram\n .command('mm-spike')\n .description(\n 'Run multi-agent planning/implementation spike (planner/implementer/critic)'\n )\n .option(\n '-t, --task <desc>',\n 'Task description',\n 'Add multi-agent spike harness'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--execute',\n 'Execute implementer (codex-sm) instead of dry-run',\n false\n )\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors', false)\n .option('--record', 'Record plan & critique into StackMemory context', false)\n .option('--json', 'Emit single JSON result (UI-friendly)', false)\n .option('--quiet', 'Minimal output (default)', true)\n .option('--verbose', 'Verbose sectioned output', false)\n .option(\n '--log',\n 'Pretty print interaction log (planner/implementer/critic)',\n false\n )\n .action(async (opts) => {\n try {\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const result = await runSpike(\n {\n task: opts.task,\n repoPath: process.cwd(),\n },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun: !opts.execute,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task: opts.task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: Boolean(opts.execute),\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n // brief human-readable summary\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('mm-spike failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Alias: build (same behavior as mm-spike)\nprogram\n .command('build')\n .description(\n 'Plan + code: planner (Claude), implementer (Codex/Claude), critic (Claude) with optional log/json output'\n )\n .argument('[task]', 'Task description (positional)')\n .option(\n '-t, --task <desc>',\n 'Task description (required if no positional arg)'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-3-5-sonnet-latest'\n )\n .option('--execute', 'Execute implementer (default: true)', true)\n .option('--dry-run', 'Skip execution, show commands only')\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors')\n .option('--record', 'Record plan & critique into StackMemory context')\n .option('--json', 'Emit single JSON result (UI-friendly)')\n .option('--quiet', 'Minimal output')\n .option('--verbose', 'Verbose sectioned output')\n .option('--log', 'Pretty print interaction log (default: true)', true)\n .action(async (taskArg, opts) => {\n try {\n // Resolve task from positional arg or --task option\n const task =\n typeof taskArg === 'string' && taskArg.length > 0 ? taskArg : opts.task;\n\n if (!task) {\n console.error(\n chalk.red(\n 'Error: Task description required. Provide as argument or --task option.'\n )\n );\n console.error(\n chalk.gray(' Example: stackmemory build \"Add user authentication\"')\n );\n process.exit(1);\n }\n\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const dryRun = opts.dryRun === true || opts.execute === false;\n const result = await runSpike(\n { task, repoPath: process.cwd() },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: !dryRun,\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('build failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\ninterface BuildLogMeta {\n task: string;\n plannerModel: string;\n reviewerModel: string;\n implementer: string;\n execute: boolean;\n}\n\nfunction printInteractionLog(meta: BuildLogMeta, result: HarnessResult): void {\n const divider = chalk.gray(\n '\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500'\n );\n console.log(chalk.cyan.bold('\\nPlan & Code Session'));\n console.log(`${chalk.gray('Task:')} ${meta.task}`);\n console.log(`${chalk.gray('Planner:')} ${meta.plannerModel}`);\n console.log(`${chalk.gray('Reviewer:')} ${meta.reviewerModel}`);\n console.log(\n `${chalk.gray('Implementer:')} ${meta.implementer} ${\n meta.execute ? chalk.green('(execute)') : chalk.yellow('(dry-run)')\n }`\n );\n console.log(divider);\n\n // Plan summary\n if (result.plan) {\n console.log(\n chalk.bold('Plan Summary: '),\n result.plan.summary || '(no summary)'\n );\n const steps: PlanStep[] = result.plan.steps.slice(0, 6);\n if (steps.length) {\n console.log(chalk.bold('\\nSteps:'));\n steps.forEach((s, idx) => {\n console.log(`${chalk.gray(String(idx + 1) + '.')} ${s.title || s.id}`);\n const ac = s.acceptanceCriteria || [];\n if (ac.length) {\n ac.slice(0, 3).forEach((c) => console.log(chalk.gray(` - ${c}`)));\n if (ac.length > 3) console.log(chalk.gray(' - ...'));\n }\n });\n }\n if (result.plan.risks?.length) {\n console.log(chalk.bold('\\nRisks:'));\n result.plan.risks\n .slice(0, 5)\n .forEach((r) => console.log(chalk.gray(` - ${r}`)));\n }\n }\n\n console.log(`\\n${divider}`);\n const iters = result.iterations || [];\n if (iters.length) {\n iters.forEach((it, i) => {\n console.log(chalk.magenta(`Attempt ${i + 1}`));\n console.log(`${chalk.gray('Command:')} ${it.command}`);\n console.log(\n `${chalk.gray('OK:')} ${it.ok ? chalk.green('true') : chalk.red('false')}`\n );\n const issues = it.critique?.issues || [];\n const sugg = it.critique?.suggestions || [];\n if (issues.length) {\n console.log(chalk.bold('Issues:'));\n issues.slice(0, 5).forEach((x) => console.log(chalk.red(` - ${x}`)));\n }\n if (sugg.length) {\n console.log(chalk.bold('Suggestions:'));\n sugg.slice(0, 5).forEach((x) => console.log(chalk.yellow(` - ${x}`)));\n }\n console.log(divider);\n });\n }\n\n const approved = result.critique?.approved ?? false;\n console.log(\n `${chalk.bold('Final:')} ${\n approved ? chalk.green('Approved') : chalk.yellow('Needs changes')\n }`\n );\n console.log('');\n}\n\n// Pending approvals: list with optional filters (CLI helper)\nprogram\n .command('pending:list')\n .description(\n 'List pending approval-gated plans (from .stackmemory/build/pending.json)'\n )\n .option('--task-contains <substr>', 'Filter tasks containing this substring')\n .option('--older-than-ms <number>', 'Only items older than this age (ms)')\n .option('--newer-than-ms <number>', 'Only items newer than this age (ms)')\n .option('--sort <asc|desc>', 'Sort by createdAt', 'desc')\n .option('--limit <number>', 'Max items to return', '20')\n .option('--pretty', 'Pretty-print JSON output', false)\n .action(async (opts) => {\n try {\n const storePath = path.join(\n process.cwd(),\n '.stackmemory',\n 'build',\n 'pending.json'\n );\n let pending: Record<string, any> = {};\n if (fs.existsSync(storePath)) {\n try {\n pending = JSON.parse(fs.readFileSync(storePath, 'utf-8'));\n } catch {}\n }\n const items = Object.entries(pending).map(([approvalId, data]) => ({\n approvalId,\n task: (data as any)?.task as string,\n createdAt: Number((data as any)?.createdAt || 0) || null,\n }));\n const filters = {\n taskContains: opts.taskContains as string | undefined,\n olderThanMs: opts.olderThanMs ? Number(opts.olderThanMs) : undefined,\n newerThanMs: opts.newerThanMs ? Number(opts.newerThanMs) : undefined,\n sort: (opts.sort as 'asc' | 'desc') || undefined,\n limit: opts.limit ? Number(opts.limit) : undefined,\n };\n const out = filterPending(items, filters);\n console.log(\n JSON.stringify({ ok: true, pending: out }, null, opts.pretty ? 2 : 0)\n );\n } catch (error) {\n console.error(\n JSON.stringify({ ok: false, error: (error as Error).message })\n );\n process.exit(1);\n }\n });\n\n// Lightweight planner: output only plan (JSON-friendly)\nprogram\n .command('plan')\n .description('Generate an implementation plan (no code execution)')\n .option('-t, --task <desc>', 'Task description', 'Plan a small change')\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-3-5-sonnet-latest'\n )\n .option('--json', 'Emit JSON (default)', true)\n .option('--pretty', 'Pretty-print JSON', false)\n .option(\n '--compact',\n 'Compact output (summary + step titles + criteria)',\n false\n )\n .action(async (opts) => {\n try {\n const { runPlanOnly } =\n await import('../orchestrators/multimodal/harness.js');\n const plan = await runPlanOnly(\n { task: opts.task, repoPath: process.cwd() },\n { plannerModel: opts.plannerModel }\n );\n const typedPlan = plan as {\n summary?: string;\n steps?: Array<{\n id: string;\n title: string;\n acceptanceCriteria: string[];\n }>;\n risks?: string[];\n };\n const compacted = opts.compact\n ? {\n summary: typedPlan?.summary,\n steps: Array.isArray(typedPlan?.steps)\n ? typedPlan.steps.map((s) => ({\n id: s.id,\n title: s.title,\n acceptanceCriteria: s.acceptanceCriteria,\n }))\n : [],\n risks: typedPlan?.risks,\n }\n : plan;\n const payload = JSON.stringify(compacted, null, opts.pretty ? 2 : 0);\n console.log(payload);\n } catch (error) {\n console.error('plan failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\n }\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n program.parse();\n}\n\nexport { program };\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory CLI\n * Command-line interface for StackMemory operations\n */\n\n// Set environment flag for CLI usage to skip async context bridge\nprocess.env['STACKMEMORY_CLI'] = 'true';\n\n// Load environment variables (quiet mode to suppress logging)\nimport { config as loadDotenv } from 'dotenv';\nloadDotenv({ quiet: true });\n\n// Initialize tracing system early\nimport { initializeTracing, trace } from '../core/trace/index.js';\ninitializeTracing();\n\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/index.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { isFeatureEnabled, isLocalOnly } from '../core/config/feature-flags.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { createTaskCommands } from './commands/tasks.js';\nimport { createSearchCommand } from './commands/search.js';\nimport { createLogCommand } from './commands/log.js';\nimport { createContextCommands } from './commands/context.js';\nimport { createConfigCommand } from './commands/config.js';\nimport {\n createCaptureCommand,\n createRestoreCommand,\n createAutoCaptureCommand,\n} from './commands/handoff.js';\nimport {\n createDecisionCommand,\n createMemoryCommand,\n} from './commands/decision.js';\nimport clearCommand from './commands/clear.js';\nimport serviceCommand from './commands/service.js';\nimport { registerLoginCommand } from './commands/login.js';\nimport { registerSignupCommand } from './commands/signup.js';\nimport { registerLogoutCommand, registerDbCommands } from './commands/db.js';\nimport { createHooksCommand } from './commands/hooks.js';\nimport { createDaemonCommand } from './commands/daemon.js';\nimport { createSweepCommand } from './commands/sweep.js';\nimport { createShellCommand } from './commands/shell.js';\nimport { createAPICommand } from './commands/api.js';\nimport { createCleanupProcessesCommand } from './commands/cleanup-processes.js';\nimport { createAutoBackgroundCommand } from './commands/auto-background.js';\nimport { createSettingsCommand } from './commands/settings.js';\nimport { createRetrievalCommands } from './commands/retrieval.js';\nimport { createDiscoveryCommands } from './commands/discovery.js';\nimport { createModelCommand } from './commands/model.js';\nimport { registerSetupCommands } from './commands/setup.js';\nimport { createPingCommand } from './commands/ping.js';\nimport chalk from 'chalk';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { filterPending } from '../integrations/mcp/pending-utils.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\nimport inquirer from 'inquirer';\nimport { enableChromaDB } from '../core/config/storage-config.js';\nimport { spawn } from 'child_process';\nimport type {\n HarnessResult,\n PlanStep,\n} from '../orchestrators/multimodal/types.js';\nimport { homedir } from 'os';\n\n// Read version from package.json - works from both src/ and dist/src/\nimport { createRequire } from 'module';\nimport { fileURLToPath } from 'url';\nimport * as pathModule from 'path';\nconst localRequire = createRequire(import.meta.url);\nconst currentFilePath = fileURLToPath(import.meta.url);\nconst currentDirPath = pathModule.dirname(currentFilePath);\n\n// Find package.json by walking up directories\nfunction findPackageJson(): { version: string } {\n let dir = currentDirPath;\n for (let i = 0; i < 5; i++) {\n const pkgPath = pathModule.join(dir, 'package.json');\n try {\n return localRequire(pkgPath);\n } catch {\n dir = pathModule.dirname(dir);\n }\n }\n return { version: '0.0.0' };\n}\nconst VERSION = findPackageJson().version;\n\n// Lazy DB opener to avoid loading native module at import time (test-friendly)\nasync function openDatabase(dbPath: string) {\n const { default: Database } = await import('better-sqlite3');\n return new Database(dbPath);\n}\n\nfunction isTestEnv(): boolean {\n return (\n process.env['VITEST'] === 'true' ||\n process.env['NODE_ENV'] === 'test' ||\n process.env['STACKMEMORY_TEST_SKIP_DB'] === '1'\n );\n}\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\n// Auto-start webhook and ngrok if notifications are enabled\nasync function startNotificationServices(): Promise<void> {\n // Skip in local-only mode\n if (isLocalOnly() || !isFeatureEnabled('whatsapp')) return;\n\n try {\n const { loadSMSConfig } = await import('../hooks/sms-notify.js');\n const config = loadSMSConfig();\n if (!config.enabled) return;\n\n const WEBHOOK_PORT = 3456;\n let webhookStarted = false;\n let ngrokStarted = false;\n\n // Check if webhook is already running\n const webhookRunning = await fetch(\n `http://localhost:${WEBHOOK_PORT}/health`\n )\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!webhookRunning) {\n // Start webhook in background using the dist path\n const webhookPath = join(__dirname, '../hooks/sms-webhook.js');\n const webhookProcess = spawn('node', [webhookPath], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env, SMS_WEBHOOK_PORT: String(WEBHOOK_PORT) },\n });\n webhookProcess.unref();\n webhookStarted = true;\n }\n\n // Check if ngrok is running\n const ngrokRunning = await fetch('http://localhost:4040/api/tunnels')\n .then((r) => r.ok)\n .catch(() => false);\n\n if (!ngrokRunning) {\n // Start ngrok in background\n const ngrokProcess = spawn('ngrok', ['http', String(WEBHOOK_PORT)], {\n detached: true,\n stdio: 'ignore',\n });\n ngrokProcess.unref();\n ngrokStarted = true;\n }\n\n // Save ngrok URL after startup\n if (webhookStarted || ngrokStarted) {\n setTimeout(async () => {\n try {\n const tunnels = await fetch('http://localhost:4040/api/tunnels').then(\n (r) =>\n r.json() as Promise<{ tunnels: Array<{ public_url: string }> }>\n );\n const publicUrl = tunnels?.tunnels?.[0]?.public_url;\n if (publicUrl) {\n const configDir = join(homedir(), '.stackmemory');\n const configPath = join(configDir, 'ngrok-url.txt');\n const { writeFileSync, mkdirSync, existsSync } = await import('fs');\n if (!existsSync(configDir)) {\n mkdirSync(configDir, { recursive: true });\n }\n writeFileSync(configPath, publicUrl);\n console.log(\n chalk.gray(`[notify] Webhook: ${publicUrl}/sms/incoming`)\n );\n }\n } catch {\n // Ignore errors\n }\n }, 4000);\n }\n } catch {\n // Silently ignore - notifications are optional\n }\n}\n\nstartNotificationServices();\n\nprogram\n .name('stackmemory')\n .description(\n 'Lossless memory runtime for AI coding tools - organizes context as a call stack instead of linear chat logs, with team collaboration and infinite retention'\n )\n .version(VERSION);\n\nprogram\n .command('init')\n .description(\n 'Initialize StackMemory in current project (zero-config by default)'\n )\n .option('-i, --interactive', 'Interactive mode with configuration prompts')\n .option(\n '--chromadb',\n 'Enable ChromaDB for semantic search (prompts for API key)'\n )\n .option('--daemon', 'Start the background daemon after initialization')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n // Check if already initialized\n const alreadyInit = existsSync(join(dbDir, 'context.db'));\n if (alreadyInit && !options.interactive) {\n console.log(chalk.yellow('StackMemory already initialized.'));\n console.log(chalk.gray('Run with --interactive to reconfigure.'));\n return;\n }\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\n // Zero-config by default - just use SQLite, no questions\n if (options.chromadb) {\n await promptAndEnableChromaDB();\n } else if (options.interactive && process.stdin.isTTY) {\n // Only ask questions in interactive mode\n console.log(chalk.cyan('\\nStorage Configuration'));\n console.log(\n chalk.gray('SQLite (default) is fast and requires no setup.')\n );\n console.log(\n chalk.gray('ChromaDB adds semantic search but requires an API key.\\n')\n );\n\n const { enableChroma } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableChroma',\n message: 'Enable ChromaDB for semantic search?',\n default: false,\n },\n ]);\n\n if (enableChroma) {\n await promptAndEnableChromaDB();\n }\n }\n\n // Initialize SQLite database (skip in test env)\n const dbPath = join(dbDir, 'context.db');\n if (!isTestEnv()) {\n const db = await openDatabase(dbPath);\n new FrameManager(db, 'cli-project');\n db.close();\n }\n\n logger.info('StackMemory initialized successfully', { projectRoot });\n console.log(chalk.green('\\n[OK] StackMemory initialized'));\n console.log(chalk.gray(` Project: ${projectRoot}`));\n console.log(chalk.gray(` Storage: SQLite (local)`));\n\n // Install daemon service if requested\n if (options.daemon) {\n console.log(chalk.cyan('\\nInstalling background service...'));\n try {\n const { installServiceSilent } =\n await import('./commands/service.js');\n const success = await installServiceSilent();\n if (success) {\n console.log(chalk.green('[OK] Guardian service installed'));\n console.log(chalk.gray(' Auto-starts on login'));\n console.log(\n chalk.gray(' Check status: stackmemory service status')\n );\n } else {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n } catch {\n console.log(chalk.yellow('[WARN] Could not install service'));\n console.log(chalk.gray(' Run: stackmemory service install'));\n }\n }\n\n // Show next steps\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(\n chalk.white(' 1. stackmemory setup-mcp') +\n chalk.gray(' # Configure Claude Code integration')\n );\n console.log(\n chalk.white(' 2. stackmemory status') +\n chalk.gray(' # Check status')\n );\n console.log(\n chalk.white(' 3. stackmemory doctor') +\n chalk.gray(' # Diagnose issues')\n );\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error(chalk.red('\\n[ERROR] Initialization failed'));\n console.error(chalk.gray(` Reason: ${(error as Error).message}`));\n console.error(\n chalk.gray(\n ' Fix: Ensure you have write permissions to the current directory'\n )\n );\n console.error(chalk.gray(' Run: stackmemory doctor'));\n process.exit(1);\n }\n });\n\n/**\n * Prompt user for ChromaDB configuration and enable it\n */\nasync function promptAndEnableChromaDB(): Promise<void> {\n const answers = await inquirer.prompt([\n {\n type: 'password',\n name: 'apiKey',\n message: 'Enter your ChromaDB API key:',\n validate: (input: string) => {\n if (!input || input.trim().length === 0) {\n return 'API key is required for ChromaDB';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'apiUrl',\n message: 'ChromaDB API URL (press Enter for default):',\n default: 'https://api.trychroma.com',\n },\n ]);\n\n enableChromaDB({\n apiKey: answers.apiKey,\n apiUrl: answers.apiUrl,\n });\n\n console.log(chalk.green('[OK] ChromaDB enabled for semantic search.'));\n console.log(\n chalk.gray('API key saved to ~/.stackmemory/storage-config.json')\n );\n}\n\nprogram\n .command('status')\n .description('Show current StackMemory status')\n .option('--all', 'Show all active frames across sessions')\n .option('--project', 'Show all active frames in current project')\n .option('--session <id>', 'Show frames for specific session')\n .action(async (options) => {\n return trace.command('stackmemory-status', options, async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (isTestEnv()) {\n console.log('\uD83D\uDCCA StackMemory Status (test mode):');\n console.log(' Frames: n/a');\n console.log(' Events: n/a');\n console.log(' Sessions: n/a');\n return;\n }\n\n // Check for updates and display if available\n await UpdateChecker.checkForUpdates(VERSION);\n\n // Initialize session manager and shared context\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({\n projectPath: projectRoot,\n sessionId: options.session,\n });\n\n // Auto-discover shared context on startup\n const contextDiscovery = await sharedContextLayer.autoDiscoverContext();\n\n // Show context hints if available\n if (\n contextDiscovery.hasSharedContext &&\n contextDiscovery.sessionCount > 1\n ) {\n console.log(`\\n\uD83D\uDCA1 Shared Context Available:`);\n console.log(\n ` ${contextDiscovery.sessionCount} sessions with shared context`\n );\n\n if (contextDiscovery.recentPatterns.length > 0) {\n console.log(` Recent patterns:`);\n contextDiscovery.recentPatterns.slice(0, 3).forEach((p) => {\n console.log(\n ` \u2022 ${p.type}: ${p.pattern.slice(0, 50)} (${p.frequency}x)`\n );\n });\n }\n\n if (contextDiscovery.lastDecisions.length > 0) {\n console.log(\n ` Last decision: ${contextDiscovery.lastDecisions[0].decision.slice(0, 60)}`\n );\n }\n }\n\n const db = await openDatabase(dbPath);\n const frameManager = new FrameManager(db, session.projectId);\n\n // Set query mode based on options\n if (options.all) {\n frameManager.setQueryMode(FrameQueryMode.ALL_ACTIVE);\n } else if (options.project) {\n frameManager.setQueryMode(FrameQueryMode.PROJECT_ACTIVE);\n }\n\n const activeFrames = frameManager.getActiveFramePath();\n const stackDepth = frameManager.getStackDepth();\n\n // Always get total counts across all sessions\n const totalStats = db\n .prepare(\n `\n SELECT \n COUNT(*) as total_frames,\n SUM(CASE WHEN state = 'active' THEN 1 ELSE 0 END) as active_frames,\n SUM(CASE WHEN state = 'closed' THEN 1 ELSE 0 END) as closed_frames,\n COUNT(DISTINCT run_id) as total_sessions\n FROM frames\n WHERE project_id = ?\n `\n )\n .get(session.projectId) as {\n total_frames: number;\n active_frames: number;\n closed_frames: number;\n total_sessions: number;\n };\n\n const contextCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM contexts\n `\n )\n .get() as { count: number };\n\n const eventCount = db\n .prepare(\n `\n SELECT COUNT(*) as count FROM events e\n JOIN frames f ON e.frame_id = f.frame_id\n WHERE f.project_id = ?\n `\n )\n .get(session.projectId) as { count: number };\n\n console.log('\uD83D\uDCCA StackMemory Status:');\n console.log(\n ` Session: ${session.sessionId.slice(0, 8)} (${session.state}, ${Math.round((Date.now() - session.startedAt) / 1000 / 60)}min old)`\n );\n console.log(` Project: ${session.projectId}`);\n if (session.branch) {\n console.log(` Branch: ${session.branch}`);\n }\n\n // Show total database statistics\n console.log(`\\n Database Statistics (this project):`);\n console.log(\n ` Frames: ${totalStats.total_frames || 0} (${totalStats.active_frames || 0} active, ${totalStats.closed_frames || 0} closed)`\n );\n console.log(` Events: ${eventCount.count || 0}`);\n console.log(` Sessions: ${totalStats.total_sessions || 0}`);\n console.log(\n ` Cached contexts: ${contextCount.count || 0} (global)`\n );\n\n // Show recent activity\n const recentFrames = db\n .prepare(\n `\n SELECT name, type, state, datetime(created_at, 'unixepoch') as created\n FROM frames\n WHERE project_id = ?\n ORDER BY created_at DESC\n LIMIT 3\n `\n )\n .all(session.projectId) as Array<{\n name: string;\n type: string;\n state: string;\n created: string;\n }>;\n\n if (recentFrames.length > 0) {\n console.log(`\\n Recent Activity:`);\n recentFrames.forEach((f) => {\n const stateIcon = f.state === 'active' ? '\uD83D\uDFE2' : '\u26AB';\n console.log(\n ` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`\n );\n });\n }\n\n console.log(`\\n Current Session:`);\n console.log(` Stack depth: ${stackDepth}`);\n console.log(` Active frames: ${activeFrames.length}`);\n\n if (activeFrames.length > 0) {\n activeFrames.forEach((frame, i) => {\n const indent = ' ' + ' '.repeat(frame.depth || i);\n const prefix = i === 0 ? '\u2514\u2500' : ' \u2514\u2500';\n console.log(`${indent}${prefix} ${frame.name} [${frame.type}]`);\n });\n }\n\n // Show other sessions if in default mode\n if (!options.all && !options.project) {\n const otherSessions = await sessionManager.listSessions({\n projectId: session.projectId,\n state: 'active',\n });\n\n const otherActive = otherSessions.filter(\n (s) => s.sessionId !== session.sessionId\n );\n if (otherActive.length > 0) {\n console.log(`\\n Other Active Sessions (same project):`);\n otherActive.forEach((s) => {\n const age = Math.round(\n (Date.now() - s.lastActiveAt) / 1000 / 60 / 60\n );\n console.log(\n ` - ${s.sessionId.slice(0, 8)}: ${s.branch || 'main'}, ${age}h old`\n );\n });\n console.log(`\\n Tip: Use --all to see frames across sessions`);\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to get status', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n });\n\nprogram\n .command('update-check')\n .description('Check for StackMemory updates')\n .action(async () => {\n try {\n console.log('\uD83D\uDD0D Checking for updates...');\n await UpdateChecker.forceCheck(VERSION);\n } catch (error: unknown) {\n logger.error('Update check failed', error as Error);\n console.error('\u274C Update check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('progress')\n .description('Show current progress and recent changes')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n const progress = new ProgressTracker(projectRoot);\n console.log(progress.getSummary());\n } catch (error: unknown) {\n logger.error('Failed to show progress', error as Error);\n console.error('\u274C Failed to show progress:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-server')\n .description('Start StackMemory MCP server for Claude Desktop')\n .option('-p, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runMCPServer } = await import('../integrations/mcp/server.js');\n\n // Set project root\n process.env['PROJECT_ROOT'] = options.project;\n\n console.log('\uD83D\uDE80 Starting StackMemory MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n\n // Check for updates silently\n UpdateChecker.checkForUpdates(VERSION, true).catch(() => {});\n\n // Start the MCP server\n await runMCPServer();\n } catch (error: unknown) {\n logger.error('Failed to start MCP server', error as Error);\n console.error('\u274C MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nprogram\n .command('mcp-remote')\n .description(\n 'Start StackMemory Remote MCP server (HTTP/SSE) for Claude.ai web'\n )\n .option('-p, --port <number>', 'Port to listen on', '3847')\n .option('-d, --project <path>', 'Project root directory', process.cwd())\n .action(async (options) => {\n try {\n const { runRemoteMCPServer } =\n await import('../integrations/mcp/remote-server.js');\n\n const port = parseInt(options.port, 10);\n\n console.log('Starting StackMemory Remote MCP Server...');\n console.log(` Project: ${options.project}`);\n console.log(` Version: ${VERSION}`);\n console.log('');\n\n await runRemoteMCPServer(port, options.project);\n\n console.log('');\n console.log('For Claude.ai web connector:');\n console.log(` URL: http://localhost:${port}/sse`);\n console.log('');\n console.log('For external access (ngrok):');\n console.log(` ngrok http ${port}`);\n console.log(' Then use the ngrok URL + /sse in Claude.ai');\n } catch (error: unknown) {\n logger.error('Failed to start remote MCP server', error as Error);\n console.error('Remote MCP server failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Add test context command\nprogram\n .command('context:test')\n .description('Test context persistence by creating sample frames')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n\n if (!existsSync(dbPath)) {\n console.log(\n '\u274C StackMemory not initialized. Run \"stackmemory init\" first.'\n );\n return;\n }\n\n if (isTestEnv()) {\n console.log('\uD83D\uDCDD [test] Skipping DB write in context:test');\n return;\n }\n\n const db = await openDatabase(dbPath);\n const frameManager = new FrameManager(db, 'cli-project');\n\n // Create test frames\n console.log('\uD83D\uDCDD Creating test context frames...');\n\n const rootFrame = frameManager.createFrame({\n type: 'task',\n name: 'Test Session',\n inputs: { test: true, timestamp: new Date().toISOString() },\n });\n\n const taskFrame = frameManager.createFrame({\n type: 'subtask',\n name: 'Sample Task',\n inputs: { description: 'Testing context persistence' },\n parentFrameId: rootFrame,\n });\n\n const commandFrame = frameManager.createFrame({\n type: 'tool_scope',\n name: 'test-command',\n inputs: { args: ['--test'] },\n parentFrameId: taskFrame,\n });\n\n // Add some events\n frameManager.addEvent(\n 'observation',\n {\n message: 'Test event recorded',\n },\n commandFrame\n );\n\n console.log('\u2705 Test frames created!');\n console.log(`\uD83D\uDCCA Stack depth: ${frameManager.getStackDepth()}`);\n console.log(\n `\uD83D\uDD04 Active frames: ${frameManager.getActiveFramePath().length}`\n );\n\n // Close one frame to test state changes\n frameManager.closeFrame(commandFrame);\n console.log(\n `\uD83D\uDCCA After closing command frame: depth = ${frameManager.getStackDepth()}`\n );\n\n db.close();\n } catch (error: unknown) {\n logger.error('Test context failed', error as Error);\n console.error('\u274C Test failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register project management commands\n// Register command modules\nregisterOnboardingCommand(program);\nregisterSignupCommand(program);\nregisterLoginCommand(program);\nregisterLogoutCommand(program);\nregisterDbCommands(program);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands (lazy-loaded, optional)\nif (isFeatureEnabled('linear')) {\n import('./commands/linear.js')\n .then(({ registerLinearCommands }) => registerLinearCommands(program))\n .catch(() => {\n // Linear integration not available - silently skip\n });\n}\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createCaptureCommand());\nprogram.addCommand(createRestoreCommand());\nprogram.addCommand(createAutoCaptureCommand());\nprogram.addCommand(createDecisionCommand());\nprogram.addCommand(createMemoryCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(serviceCommand);\nprogram.addCommand(createHooksCommand());\n\n// Register feature-flagged commands (awaited before parse)\nconst lazyCommands: Promise<void>[] = [];\n\nif (isFeatureEnabled('skills')) {\n lazyCommands.push(\n import('./commands/skills.js')\n .then(({ createSkillsCommand }) =>\n program.addCommand(createSkillsCommand())\n )\n .catch(() => {\n // Skills integration not available - silently skip\n })\n );\n}\n\n// Register ralph commands (feature-flagged)\n// Default ON for development, OFF for npm package users\nif (isFeatureEnabled('ralph')) {\n lazyCommands.push(\n import('./commands/ralph.js')\n .then(({ default: createRalphCommand }) =>\n program.addCommand(createRalphCommand())\n )\n .catch(() => {\n // Ralph integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createDaemonCommand());\nprogram.addCommand(createSweepCommand());\nprogram.addCommand(createShellCommand());\nprogram.addCommand(createAPICommand());\nprogram.addCommand(createCleanupProcessesCommand());\nprogram.addCommand(createAutoBackgroundCommand());\nprogram.addCommand(createSettingsCommand());\nprogram.addCommand(createPingCommand());\n\n// Register WhatsApp/SMS commands (lazy-loaded, optional)\nif (isFeatureEnabled('whatsapp')) {\n lazyCommands.push(\n import('./commands/sms-notify.js')\n .then(({ createSMSNotifyCommand }) =>\n program.addCommand(createSMSNotifyCommand())\n )\n .catch(() => {\n // WhatsApp integration not available - silently skip\n })\n );\n}\nprogram.addCommand(createRetrievalCommands());\nprogram.addCommand(createDiscoveryCommands());\nprogram.addCommand(createModelCommand());\n\n// Register setup and diagnostic commands\nregisterSetupCommands(program);\n\n// Multi-modal spike: planner (Claude), implementer (Codex), critic (Claude)\nprogram\n .command('mm-spike')\n .description(\n 'Run multi-agent planning/implementation spike (planner/implementer/critic)'\n )\n .option(\n '-t, --task <desc>',\n 'Task description',\n 'Add multi-agent spike harness'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--execute',\n 'Execute implementer (codex-sm) instead of dry-run',\n false\n )\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors', false)\n .option('--record', 'Record plan & critique into StackMemory context', false)\n .option('--json', 'Emit single JSON result (UI-friendly)', false)\n .option('--quiet', 'Minimal output (default)', true)\n .option('--verbose', 'Verbose sectioned output', false)\n .option(\n '--log',\n 'Pretty print interaction log (planner/implementer/critic)',\n false\n )\n .action(async (opts) => {\n try {\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const result = await runSpike(\n {\n task: opts.task,\n repoPath: process.cwd(),\n },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun: !opts.execute,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task: opts.task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: Boolean(opts.execute),\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n // brief human-readable summary\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('mm-spike failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Alias: build (same behavior as mm-spike)\nprogram\n .command('build')\n .description(\n 'Plan + code: planner (Claude), implementer (Codex/Claude), critic (Claude) with optional log/json output'\n )\n .argument('[task]', 'Task description (positional)')\n .option(\n '-t, --task <desc>',\n 'Task description (required if no positional arg)'\n )\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option(\n '--reviewer-model <name>',\n 'Claude model for review',\n 'claude-sonnet-4-20250514'\n )\n .option('--execute', 'Execute implementer (default: true)', true)\n .option('--dry-run', 'Skip execution, show commands only')\n .option('--implementer <name>', 'codex|claude', 'codex')\n .option('--max-iters <n>', 'Retry loop iterations', '2')\n .option('--audit-dir <path>', 'Persist spike results to directory')\n .option('--record-frame', 'Record as real frame with anchors')\n .option('--record', 'Record plan & critique into StackMemory context')\n .option('--json', 'Emit single JSON result (UI-friendly)')\n .option('--quiet', 'Minimal output')\n .option('--verbose', 'Verbose sectioned output')\n .option('--log', 'Pretty print interaction log (default: true)', true)\n .option('-C, --cwd <path>', 'Working directory for implementation')\n .action(async (taskArg, opts) => {\n try {\n // Resolve task from positional arg or --task option\n const task =\n typeof taskArg === 'string' && taskArg.length > 0 ? taskArg : opts.task;\n\n if (!task) {\n console.error(\n chalk.red(\n 'Error: Task description required. Provide as argument or --task option.'\n )\n );\n console.error(\n chalk.gray(' Example: stackmemory build \"Add user authentication\"')\n );\n process.exit(1);\n }\n\n const { runSpike } =\n await import('../orchestrators/multimodal/harness.js');\n const dryRun = opts.dryRun === true || opts.execute === false;\n\n // Find git root for proper working directory\n const findGitRoot = (startDir: string): string => {\n let dir = startDir;\n while (dir !== '/') {\n if (existsSync(join(dir, '.git'))) {\n return dir;\n }\n dir = path.dirname(dir);\n }\n return startDir;\n };\n // Use --cwd if provided, otherwise find git root from cwd\n const repoPath = opts.cwd\n ? path.resolve(opts.cwd)\n : findGitRoot(process.cwd());\n\n const result = await runSpike(\n { task, repoPath },\n {\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n maxIters: parseInt(opts.maxIters),\n dryRun,\n auditDir: opts.auditDir,\n recordFrame: Boolean(opts.recordFrame),\n record: Boolean(opts.record),\n }\n );\n\n if (opts.log) {\n printInteractionLog(\n {\n task,\n plannerModel: opts.plannerModel,\n reviewerModel: opts.reviewerModel,\n implementer: opts.implementer,\n execute: !dryRun,\n },\n result\n );\n return;\n }\n\n if (opts.json) {\n console.log(JSON.stringify(result));\n return;\n }\n if (opts.verbose) {\n console.log('\\n=== Plan ===');\n console.log(JSON.stringify(result.plan, null, 2));\n console.log('\\n=== Iterations ===');\n (result.iterations || []).forEach((it, i) => {\n console.log(`\\n[Attempt ${i + 1}] ${it.command}`);\n console.log('OK:', it.ok);\n console.log('Critique:', JSON.stringify(it.critique));\n });\n console.log('\\n=== Implementation ===');\n console.log(JSON.stringify(result.implementation, null, 2));\n console.log('\\n=== Critique ===');\n console.log(JSON.stringify(result.critique, null, 2));\n } else if (!opts.quiet) {\n console.log(\n `Plan steps: ${result.plan.steps.length}, Approved: ${result.critique.approved}`\n );\n }\n } catch (error) {\n console.error('build failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\ninterface BuildLogMeta {\n task: string;\n plannerModel: string;\n reviewerModel: string;\n implementer: string;\n execute: boolean;\n}\n\nfunction printInteractionLog(meta: BuildLogMeta, result: HarnessResult): void {\n const divider = chalk.gray(\n '\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500'\n );\n console.log(chalk.cyan.bold('\\nPlan & Code Session'));\n console.log(`${chalk.gray('Task:')} ${meta.task}`);\n console.log(`${chalk.gray('Planner:')} ${meta.plannerModel}`);\n console.log(`${chalk.gray('Reviewer:')} ${meta.reviewerModel}`);\n console.log(\n `${chalk.gray('Implementer:')} ${meta.implementer} ${\n meta.execute ? chalk.green('(execute)') : chalk.yellow('(dry-run)')\n }`\n );\n console.log(divider);\n\n // Plan summary\n if (result.plan) {\n console.log(\n chalk.bold('Plan Summary: '),\n result.plan.summary || '(no summary)'\n );\n const steps: PlanStep[] = result.plan.steps.slice(0, 6);\n if (steps.length) {\n console.log(chalk.bold('\\nSteps:'));\n steps.forEach((s, idx) => {\n console.log(`${chalk.gray(String(idx + 1) + '.')} ${s.title || s.id}`);\n const ac = s.acceptanceCriteria || [];\n if (ac.length) {\n ac.slice(0, 3).forEach((c) => console.log(chalk.gray(` - ${c}`)));\n if (ac.length > 3) console.log(chalk.gray(' - ...'));\n }\n });\n }\n if (result.plan.risks?.length) {\n console.log(chalk.bold('\\nRisks:'));\n result.plan.risks\n .slice(0, 5)\n .forEach((r) => console.log(chalk.gray(` - ${r}`)));\n }\n }\n\n console.log(`\\n${divider}`);\n const iters = result.iterations || [];\n if (iters.length) {\n iters.forEach((it, i) => {\n console.log(chalk.magenta(`Attempt ${i + 1}`));\n console.log(`${chalk.gray('Command:')} ${it.command}`);\n console.log(\n `${chalk.gray('OK:')} ${it.ok ? chalk.green('true') : chalk.red('false')}`\n );\n const issues = it.critique?.issues || [];\n const sugg = it.critique?.suggestions || [];\n if (issues.length) {\n console.log(chalk.bold('Issues:'));\n issues.slice(0, 5).forEach((x) => console.log(chalk.red(` - ${x}`)));\n }\n if (sugg.length) {\n console.log(chalk.bold('Suggestions:'));\n sugg.slice(0, 5).forEach((x) => console.log(chalk.yellow(` - ${x}`)));\n }\n console.log(divider);\n });\n }\n\n const approved = result.critique?.approved ?? false;\n console.log(\n `${chalk.bold('Final:')} ${\n approved ? chalk.green('Approved') : chalk.yellow('Needs changes')\n }`\n );\n console.log('');\n}\n\n// Pending approvals: list with optional filters (CLI helper)\nprogram\n .command('pending:list')\n .description(\n 'List pending approval-gated plans (from .stackmemory/build/pending.json)'\n )\n .option('--task-contains <substr>', 'Filter tasks containing this substring')\n .option('--older-than-ms <number>', 'Only items older than this age (ms)')\n .option('--newer-than-ms <number>', 'Only items newer than this age (ms)')\n .option('--sort <asc|desc>', 'Sort by createdAt', 'desc')\n .option('--limit <number>', 'Max items to return', '20')\n .option('--pretty', 'Pretty-print JSON output', false)\n .action(async (opts) => {\n try {\n const storePath = path.join(\n process.cwd(),\n '.stackmemory',\n 'build',\n 'pending.json'\n );\n let pending: Record<string, { task?: string; createdAt?: number }> = {};\n if (fs.existsSync(storePath)) {\n try {\n pending = JSON.parse(fs.readFileSync(storePath, 'utf-8'));\n } catch {}\n }\n const items = Object.entries(pending).map(([approvalId, data]) => ({\n approvalId,\n task: data?.task ?? '',\n createdAt: Number(data?.createdAt || 0) || null,\n }));\n const filters = {\n taskContains: opts.taskContains as string | undefined,\n olderThanMs: opts.olderThanMs ? Number(opts.olderThanMs) : undefined,\n newerThanMs: opts.newerThanMs ? Number(opts.newerThanMs) : undefined,\n sort: (opts.sort as 'asc' | 'desc') || undefined,\n limit: opts.limit ? Number(opts.limit) : undefined,\n };\n const out = filterPending(items, filters);\n console.log(\n JSON.stringify({ ok: true, pending: out }, null, opts.pretty ? 2 : 0)\n );\n } catch (error) {\n console.error(\n JSON.stringify({ ok: false, error: (error as Error).message })\n );\n process.exit(1);\n }\n });\n\n// Lightweight planner: output only plan (JSON-friendly)\nprogram\n .command('plan')\n .description('Generate an implementation plan (no code execution)')\n .option('-t, --task <desc>', 'Task description', 'Plan a small change')\n .option(\n '--planner-model <name>',\n 'Claude model for planning',\n 'claude-sonnet-4-20250514'\n )\n .option('--json', 'Emit JSON (default)', true)\n .option('--pretty', 'Pretty-print JSON', false)\n .option(\n '--compact',\n 'Compact output (summary + step titles + criteria)',\n false\n )\n .action(async (opts) => {\n try {\n const { runPlanOnly } =\n await import('../orchestrators/multimodal/harness.js');\n const plan = await runPlanOnly(\n { task: opts.task, repoPath: process.cwd() },\n { plannerModel: opts.plannerModel }\n );\n const typedPlan = plan as {\n summary?: string;\n steps?: Array<{\n id: string;\n title: string;\n acceptanceCriteria: string[];\n }>;\n risks?: string[];\n };\n const compacted = opts.compact\n ? {\n summary: typedPlan?.summary,\n steps: Array.isArray(typedPlan?.steps)\n ? typedPlan.steps.map((s) => ({\n id: s.id,\n title: s.title,\n acceptanceCriteria: s.acceptanceCriteria,\n }))\n : [],\n risks: typedPlan?.risks,\n }\n : plan;\n const payload = JSON.stringify(compacted, null, opts.pretty ? 2 : 0);\n console.log(payload);\n } catch (error) {\n console.error('plan failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Register dashboard command\nprogram\n .command('dashboard')\n .description('Display monitoring dashboard in terminal')\n .option('-w, --watch', 'Auto-refresh dashboard')\n .option('-i, --interval <seconds>', 'Refresh interval in seconds', '5')\n .action(async (options) => {\n const { dashboardCommand } = await import('./commands/dashboard.js');\n await dashboardCommand.handler(options);\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n try {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\n });\n } catch {\n // Silently fail if database initialization fails (e.g., native module version mismatch)\n }\n}\n\n// Only parse when running as main module (not when imported for testing)\nconst isMainModule =\n import.meta.url === `file://${process.argv[1]}` ||\n process.argv[1]?.endsWith('/stackmemory') ||\n process.argv[1]?.endsWith('index.ts') ||\n process.argv[1]?.includes('tsx');\n\nif (isMainModule) {\n Promise.all(lazyCommands).then(() => program.parse());\n}\n\nexport { program };\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["mkdirSync", "existsSync"]
|
|
7
7
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/core/digest/types.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-haiku-
|
|
4
|
+
"sourcesContent": ["/**\n * Types for Hybrid Digest Generation System\n * 80% deterministic extraction, 20% AI-generated review/insights\n */\n\nimport { Frame, Anchor, Event } from '../context/index.js';\n\n/**\n * Deterministic fields extracted directly from frame data (60%)\n */\nexport interface DeterministicDigest {\n /** Files that were modified during this frame */\n filesModified: FileModification[];\n /** Tests that were run */\n testsRun: TestResult[];\n /** Errors encountered */\n errorsEncountered: ErrorInfo[];\n /** Number of tool calls made */\n toolCallCount: number;\n /** Tool calls by type */\n toolCallsByType: Record<string, number>;\n /** Frame duration in seconds */\n durationSeconds: number;\n /** Exit status */\n exitStatus: 'success' | 'failure' | 'partial' | 'cancelled';\n /** Anchors by type */\n anchorCounts: Record<string, number>;\n /** Key decisions made (extracted from DECISION anchors) */\n decisions: string[];\n /** Constraints established (extracted from CONSTRAINT anchors) */\n constraints: string[];\n /** Risks identified (extracted from RISK anchors) */\n risks: string[];\n}\n\nexport interface FileModification {\n path: string;\n operation: 'create' | 'modify' | 'delete' | 'read';\n linesChanged?: number;\n}\n\nexport interface TestResult {\n name: string;\n status: 'passed' | 'failed' | 'skipped';\n duration?: number;\n}\n\nexport interface ErrorInfo {\n type: string;\n message: string;\n resolved: boolean;\n count: number;\n}\n\n/**\n * AI-generated review fields (20%)\n * Focused on high-value insights only\n */\nexport interface AIGeneratedDigest {\n /** One-line summary of what was accomplished */\n summary: string;\n /** Key insight or learning (if any) */\n insight?: string;\n /** Potential issue or risk spotted */\n flaggedIssue?: string;\n /** Generated at timestamp */\n generatedAt: number;\n /** Model used for generation */\n modelUsed?: string;\n /** Tokens used */\n tokensUsed?: number;\n}\n\n/**\n * Complete hybrid digest combining both approaches\n */\nexport interface HybridDigest {\n /** Frame identifier */\n frameId: string;\n /** Frame name/goal */\n frameName: string;\n /** Frame type */\n frameType: string;\n /** Deterministic fields (always available) */\n deterministic: DeterministicDigest;\n /** AI-generated fields (may be pending) */\n aiGenerated?: AIGeneratedDigest;\n /** Processing status */\n status: DigestStatus;\n /** Human-readable text representation */\n text: string;\n /** Version for schema evolution */\n version: number;\n /** Created timestamp */\n createdAt: number;\n /** Last updated timestamp */\n updatedAt: number;\n}\n\nexport type DigestStatus =\n | 'deterministic_only' // Only deterministic fields populated\n | 'ai_pending' // Queued for AI generation\n | 'ai_processing' // Currently being processed by AI\n | 'complete' // Both deterministic and AI fields populated\n | 'ai_failed'; // AI generation failed, falling back to deterministic\n\n/**\n * Digest generation request for the queue\n */\nexport interface DigestGenerationRequest {\n frameId: string;\n frameName: string;\n frameType: string;\n priority: 'low' | 'normal' | 'high';\n createdAt: number;\n retryCount: number;\n maxRetries: number;\n}\n\n/**\n * Configuration for the digest generator\n */\nexport interface DigestConfig {\n /** Enable AI generation (can be disabled for deterministic-only mode) */\n enableAIGeneration: boolean;\n /** Maximum tokens for AI summary */\n maxTokens: number;\n /** Batch size for idle processing */\n batchSize: number;\n /** Idle threshold in ms before processing queue */\n idleThresholdMs: number;\n /** Maximum retries for failed AI generation */\n maxRetries: number;\n /** Retry delay in ms */\n retryDelayMs: number;\n /** LLM provider configuration */\n llmConfig: {\n provider: 'anthropic' | 'openai' | 'local' | 'none';\n model: string;\n temperature: number;\n };\n}\n\nexport const DEFAULT_DIGEST_CONFIG: DigestConfig = {\n enableAIGeneration: true,\n maxTokens: 100, // Reduced for 20% AI contribution\n batchSize: 10, // Process more at once since smaller\n idleThresholdMs: 3000, // 3 seconds of idle time\n maxRetries: 2,\n retryDelayMs: 1000,\n llmConfig: {\n provider: 'anthropic',\n model: 'claude-3-5-haiku-20241022',\n temperature: 0.2, // Lower for more consistent output\n },\n};\n\n/**\n * Input for digest generation\n */\nexport interface DigestInput {\n frame: Frame;\n anchors: Anchor[];\n events: Event[];\n parentDigest?: HybridDigest;\n}\n\n/**\n * LLM provider interface for AI digest generation\n */\nexport interface DigestLLMProvider {\n generateSummary(\n input: DigestInput,\n deterministic: DeterministicDigest,\n maxTokens: number\n ): Promise<AIGeneratedDigest>;\n}\n\n/**\n * Digest queue statistics\n */\nexport interface DigestQueueStats {\n pending: number;\n processing: number;\n completed: number;\n failed: number;\n avgProcessingTimeMs: number;\n}\n"],
|
|
5
5
|
"mappings": ";;;;AA+IO,MAAM,wBAAsC;AAAA,EACjD,oBAAoB;AAAA,EACpB,WAAW;AAAA;AAAA,EACX,WAAW;AAAA;AAAA,EACX,iBAAiB;AAAA;AAAA,EACjB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,WAAW;AAAA,IACT,UAAU;AAAA,IACV,OAAO;AAAA,IACP,aAAa;AAAA;AAAA,EACf;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -111,7 +111,7 @@ class ClaudeAdapter {
|
|
|
111
111
|
"anthropic-version": "2023-06-01"
|
|
112
112
|
},
|
|
113
113
|
body: JSON.stringify({
|
|
114
|
-
model: "claude-3-haiku-
|
|
114
|
+
model: "claude-3-5-haiku-20241022",
|
|
115
115
|
max_tokens: 1,
|
|
116
116
|
messages: [{ role: "user", content: "hi" }]
|
|
117
117
|
})
|
|
@@ -125,11 +125,8 @@ class ClaudeAdapter {
|
|
|
125
125
|
return [
|
|
126
126
|
"claude-opus-4-20250514",
|
|
127
127
|
"claude-sonnet-4-20250514",
|
|
128
|
-
"claude-3-5-sonnet-20241022",
|
|
129
128
|
"claude-3-5-haiku-20241022",
|
|
130
|
-
"claude-3-opus-20240229"
|
|
131
|
-
"claude-3-sonnet-20240229",
|
|
132
|
-
"claude-3-haiku-20240307"
|
|
129
|
+
"claude-3-opus-20240229"
|
|
133
130
|
];
|
|
134
131
|
}
|
|
135
132
|
buildRequestBody(messages, options) {
|