@stackmemoryai/stackmemory 0.3.9 → 0.3.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/README.md +53 -0
  2. package/dist/agents/core/agent-task-manager.js +12 -1
  3. package/dist/agents/core/agent-task-manager.js.map +3 -3
  4. package/dist/agents/testing-agent.js +610 -0
  5. package/dist/agents/testing-agent.js.map +7 -0
  6. package/dist/cli/claude-sm.js +2 -2
  7. package/dist/cli/claude-sm.js.map +2 -2
  8. package/dist/cli/codex-sm.js +2 -2
  9. package/dist/cli/codex-sm.js.map +2 -2
  10. package/dist/cli/commands/handoff.js +65 -18
  11. package/dist/cli/commands/handoff.js.map +3 -3
  12. package/dist/cli/commands/onboard.js +3 -3
  13. package/dist/cli/commands/onboard.js.map +2 -2
  14. package/dist/cli/commands/quality.js +2 -2
  15. package/dist/cli/commands/quality.js.map +2 -2
  16. package/dist/cli/commands/skills.js +113 -28
  17. package/dist/cli/commands/skills.js.map +2 -2
  18. package/dist/cli/commands/test.js +282 -0
  19. package/dist/cli/commands/test.js.map +7 -0
  20. package/dist/cli/commands/worktree.js +28 -10
  21. package/dist/cli/commands/worktree.js.map +2 -2
  22. package/dist/cli/index.js +2 -0
  23. package/dist/cli/index.js.map +2 -2
  24. package/dist/core/config/config-manager.js +26 -0
  25. package/dist/core/config/config-manager.js.map +3 -3
  26. package/dist/core/context/frame-manager.js +139 -0
  27. package/dist/core/context/frame-manager.js.map +2 -2
  28. package/dist/core/context/refactored-frame-manager.js +180 -1
  29. package/dist/core/context/refactored-frame-manager.js.map +2 -2
  30. package/dist/core/utils/update-checker.js +2 -2
  31. package/dist/core/utils/update-checker.js.map +2 -2
  32. package/dist/integrations/claude-code/subagent-client-stub.js +16 -0
  33. package/dist/integrations/claude-code/subagent-client-stub.js.map +7 -0
  34. package/dist/skills/claude-skills.js +97 -3
  35. package/dist/skills/claude-skills.js.map +2 -2
  36. package/dist/skills/security-secrets-scanner.js +21 -6
  37. package/dist/skills/security-secrets-scanner.js.map +2 -2
  38. package/dist/skills/unified-rlm-orchestrator.js +400 -0
  39. package/dist/skills/unified-rlm-orchestrator.js.map +7 -0
  40. package/package.json +3 -2
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/worktree.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n/**\n * Git Worktree Management CLI Commands\n * Handles multiple StackMemory instances across git worktrees\n */\n\nimport { Command } from 'commander';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport chalk from 'chalk';\nimport Table from 'cli-table3';\nimport { join } from 'path';\nimport { existsSync } from 'fs';\nimport Database from 'better-sqlite3';\nimport { execSync } from 'child_process';\n\nexport function registerWorktreeCommands(program: Command): void {\n const worktree = program\n .command('worktree')\n .alias('wt')\n .description('Manage StackMemory across git worktrees');\n\n // Enable/disable worktree support\n worktree\n .command('enable')\n .description('Enable worktree support')\n .option(\n '--isolate',\n 'Isolate contexts between worktrees (default: true)',\n true\n )\n .option('--auto-detect', 'Auto-detect worktrees (default: true)', true)\n .option('--sync-interval <minutes>', 'Context sync interval', '15')\n .action(async (options) => {\n const manager = WorktreeManager.getInstance();\n\n manager.saveConfig({\n enabled: true,\n autoDetect: options.autoDetect,\n isolateContexts: options.isolate,\n shareGlobalContext: false,\n syncInterval: parseInt(options.syncInterval),\n });\n\n console.log(chalk.green('\u2713 Worktree support enabled'));\n\n // Auto-detect current worktrees\n const worktrees = manager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.cyan(`\\nDetected ${worktrees.length} worktree(s):`));\n worktrees.forEach((wt) => {\n const marker = wt.isMainWorktree ? ' (main)' : '';\n console.log(chalk.gray(` - ${wt.branch}${marker} at ${wt.path}`));\n });\n }\n });\n\n worktree\n .command('disable')\n .description('Disable worktree support')\n .action(() => {\n const manager = WorktreeManager.getInstance();\n manager.setEnabled(false);\n console.log(chalk.yellow('\u26A0 Worktree support disabled'));\n });\n\n // List all worktrees\n worktree\n .command('list')\n .alias('ls')\n .description('List all git worktrees with StackMemory status')\n .option('-v, --verbose', 'Show detailed information')\n .action((options) => {\n const manager = WorktreeManager.getInstance();\n const worktrees = manager.detectWorktrees();\n\n if (worktrees.length === 0) {\n console.log(chalk.yellow('No worktrees found in current repository'));\n return;\n }\n\n const table = new Table({\n head: ['Branch', 'Path', 'Type', 'Context', 'Last Activity'],\n style: { head: ['cyan'] },\n });\n\n for (const wt of worktrees) {\n const type = wt.isMainWorktree\n ? 'Main'\n : wt.isDetached\n ? 'Detached'\n : 'Branch';\n\n // Check for context\n let contextStatus = '\u2014';\n let lastActivity = '\u2014';\n\n try {\n const context = manager.getWorktreeContext(wt.path);\n if (existsSync(context.dbPath)) {\n contextStatus = '\u2713 Active';\n\n // Get last activity\n const db = new Database(context.dbPath);\n const lastEvent = db\n .prepare('SELECT MAX(created_at) as last FROM events')\n .get() as any;\n\n if (lastEvent?.last) {\n const date = new Date(lastEvent.last);\n lastActivity = date.toLocaleDateString();\n }\n\n db.close();\n } else {\n contextStatus = '\u25CB Not initialized';\n }\n } catch (error: unknown) {\n contextStatus = '\u2717 Error';\n }\n\n table.push([\n wt.branch || 'detached',\n options.verbose\n ? wt.path\n : `.../${wt.path.split('/').slice(-2).join('/')}`,\n type,\n contextStatus,\n lastActivity,\n ]);\n }\n\n console.log(chalk.cyan('\\nGit Worktrees:\\n'));\n console.log(table.toString());\n\n if (manager.isEnabled()) {\n console.log(chalk.gray('\\n\u2713 Worktree support is enabled'));\n const config = manager.getConfig();\n if (config.isolateContexts) {\n console.log(\n chalk.gray(' - Contexts are isolated between worktrees')\n );\n }\n if (config.autoDetect) {\n console.log(chalk.gray(' - Auto-detection is enabled'));\n }\n } else {\n console.log(chalk.gray('\\n\u25CB Worktree support is disabled'));\n console.log(\n chalk.gray(' Run \"stackmemory worktree enable\" to activate')\n );\n }\n });\n\n // Status of current worktree\n worktree\n .command('status')\n .description('Show status of current worktree')\n .action(async () => {\n const manager = WorktreeManager.getInstance();\n const currentPath = process.cwd();\n\n // Detect current worktree\n const worktrees = manager.detectWorktrees(currentPath);\n const current = worktrees.find((w: any) =>\n currentPath.startsWith(w.path)\n );\n\n if (!current) {\n console.log(chalk.yellow('Not in a git worktree'));\n return;\n }\n\n console.log(chalk.cyan('Current Worktree:\\n'));\n console.log(chalk.gray(' Branch:'), current.branch || 'detached');\n console.log(chalk.gray(' Path:'), current.path);\n console.log(\n chalk.gray(' Type:'),\n current.isMainWorktree ? 'Main' : 'Branch'\n );\n console.log(chalk.gray(' Commit:'), current.commit.substring(0, 8));\n\n if (manager.isEnabled()) {\n try {\n const context = manager.getWorktreeContext(current.path);\n console.log(chalk.gray(' Context Path:'), context.contextPath);\n\n if (existsSync(context.dbPath)) {\n const db = new Database(context.dbPath);\n\n // Get statistics\n const stats = db\n .prepare(\n `\n SELECT \n (SELECT COUNT(*) FROM frames) as frames,\n (SELECT COUNT(*) FROM events) as events,\n (SELECT COUNT(*) FROM contexts) as contexts\n `\n )\n .get() as any;\n\n console.log(chalk.cyan('\\nContext Statistics:'));\n console.log(chalk.gray(' Frames:'), stats.frames);\n console.log(chalk.gray(' Events:'), stats.events);\n console.log(chalk.gray(' Contexts:'), stats.contexts);\n\n db.close();\n } else {\n console.log(chalk.yellow('\\nContext not initialized'));\n console.log(chalk.gray(' Run \"stackmemory init\" to initialize'));\n }\n } catch (error: unknown) {\n console.log(\n chalk.red('\\nError accessing context:'),\n (error as Error).message\n );\n }\n } else {\n console.log(chalk.gray('\\nWorktree support is disabled'));\n }\n });\n\n // Create new worktree with StackMemory\n worktree\n .command('create <branch>')\n .description('Create new git worktree with StackMemory context')\n .option('-p, --path <path>', 'Worktree path (default: ../repo-branch)')\n .option('--from <commit>', 'Create branch from commit/branch')\n .option('--init', 'Initialize StackMemory immediately')\n .action(async (branch, options) => {\n const manager = WorktreeManager.getInstance();\n const projectManager = ProjectManager.getInstance();\n\n try {\n // Get current project info\n const project = await projectManager.detectProject();\n const worktreePath = options.path || `../${project.name}-${branch}`;\n\n // Create git worktree\n let gitCommand = `git worktree add -b ${branch} ${worktreePath}`;\n if (options.from) {\n gitCommand += ` ${options.from}`;\n }\n\n console.log(chalk.gray(`Creating worktree: ${gitCommand}`));\n execSync(gitCommand, { stdio: 'inherit' });\n\n console.log(chalk.green(`\u2713 Created worktree at ${worktreePath}`));\n\n // Set up StackMemory context if enabled\n if (manager.isEnabled()) {\n const context = manager.getWorktreeContext(worktreePath);\n console.log(\n chalk.green(`\u2713 Created isolated context at ${context.contextPath}`)\n );\n\n if (options.init) {\n // Initialize StackMemory in new worktree\n const db = new Database(context.dbPath);\n new FrameManager(db, project.id);\n db.close();\n\n console.log(chalk.green('\u2713 StackMemory initialized in worktree'));\n }\n }\n\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(chalk.gray(` cd ${worktreePath}`));\n if (!options.init && manager.isEnabled()) {\n console.log(chalk.gray(' stackmemory init'));\n }\n console.log(chalk.gray(' # Start working in isolated context'));\n } catch (error: unknown) {\n console.error(\n chalk.red('Failed to create worktree:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n\n // Sync contexts between worktrees\n worktree\n .command('sync')\n .description('Sync contexts between worktrees')\n .option('-s, --source <branch>', 'Source worktree branch')\n .option('-t, --target <branch>', 'Target worktree branch')\n .option('--type <type>', 'Sync type: push|pull|merge (default: merge)')\n .action(async (options) => {\n const manager = WorktreeManager.getInstance();\n\n if (!manager.isEnabled()) {\n console.log(chalk.yellow('Worktree support is not enabled'));\n console.log(chalk.gray('Run \"stackmemory worktree enable\" first'));\n return;\n }\n\n const worktrees = manager.detectWorktrees();\n\n // Find source and target\n let source = worktrees.find((w: any) => w.branch === options.source);\n let target = worktrees.find((w: any) => w.branch === options.target);\n\n if (!source || !target) {\n // Interactive selection if not specified\n const inquirer = await import('inquirer');\n\n if (!source) {\n const { sourceBranch } = await inquirer.default.prompt([\n {\n type: 'list',\n name: 'sourceBranch',\n message: 'Select source worktree:',\n choices: worktrees.map((w: any) => ({\n name: `${w.branch} (${w.path})`,\n value: w,\n })),\n },\n ]);\n source = sourceBranch;\n }\n\n if (!target) {\n const { targetBranch } = await inquirer.default.prompt([\n {\n type: 'list',\n name: 'targetBranch',\n message: 'Select target worktree:',\n choices: worktrees\n .filter((w: any) => w.path !== source!.path)\n .map((w: any) => ({\n name: `${w.branch} (${w.path})`,\n value: w,\n })),\n },\n ]);\n target = targetBranch;\n }\n }\n\n console.log(chalk.cyan('Syncing contexts:'));\n console.log(chalk.gray(' Source:'), source!.branch);\n console.log(chalk.gray(' Target:'), target!.branch);\n console.log(chalk.gray(' Type:'), options.type || 'merge');\n\n try {\n await manager.syncContexts(\n source!.path,\n target!.path,\n options.type || 'merge'\n );\n\n console.log(chalk.green('\u2713 Context sync completed'));\n } catch (error: unknown) {\n console.error(chalk.red('Sync failed:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n // Clean up stale worktree contexts\n worktree\n .command('cleanup')\n .description('Clean up stale worktree contexts')\n .option('--dry-run', 'Show what would be cleaned without doing it')\n .action((options) => {\n const manager = WorktreeManager.getInstance();\n\n if (options.dryRun) {\n console.log(chalk.yellow('Dry run - no changes will be made'));\n }\n\n console.log(chalk.cyan('Checking for stale worktree contexts...'));\n\n if (!options.dryRun) {\n manager.cleanupStaleContexts();\n console.log(chalk.green('\u2713 Cleanup completed'));\n } else {\n const active = manager.detectWorktrees();\n const stored = manager.listActiveWorktrees();\n\n const activePaths = new Set(active.map((w: any) => w.path));\n const stale = stored.filter((w: any) => !activePaths.has(w.path));\n\n if (stale.length === 0) {\n console.log(chalk.green('No stale contexts found'));\n } else {\n console.log(chalk.yellow(`Found ${stale.length} stale context(s):`));\n stale.forEach((w) => {\n console.log(chalk.gray(` - ${w.branch} at ${w.path}`));\n });\n }\n }\n });\n\n // Switch to different worktree\n worktree\n .command('switch <branch>')\n .description('Switch to a different worktree')\n .action(async (branch) => {\n const manager = WorktreeManager.getInstance();\n const worktrees = manager.detectWorktrees();\n\n const target = worktrees.find((w: any) => w.branch === branch);\n if (!target) {\n console.log(chalk.red(`Worktree '${branch}' not found`));\n console.log(chalk.gray('\\nAvailable worktrees:'));\n worktrees.forEach((w) => {\n console.log(chalk.gray(` - ${w.branch}`));\n });\n process.exit(1);\n }\n\n console.log(chalk.cyan(`Switching to worktree: ${branch}`));\n console.log(chalk.gray(`Path: ${target.path}`));\n console.log(chalk.gray('\\nRun this command to switch:'));\n console.log(chalk.green(` cd ${target.path}`));\n\n if (manager.isEnabled() && !target.isMainWorktree) {\n console.log(chalk.gray('\\nThis worktree has an isolated context'));\n }\n });\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * Git Worktree Management CLI Commands\n * Handles multiple StackMemory instances across git worktrees\n */\n\nimport { Command } from 'commander';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport chalk from 'chalk';\nimport Table from 'cli-table3';\nimport { join } from 'path';\nimport { existsSync } from 'fs';\nimport Database from 'better-sqlite3';\nimport { execSync, execFileSync } from 'child_process';\nimport shellEscape from 'shell-escape';\nimport { z } from 'zod';\n\n// Input validation schemas\nconst BranchNameSchema = z.string()\n .min(1, 'Branch name cannot be empty')\n .max(100, 'Branch name too long')\n .regex(/^[a-zA-Z0-9._/-]+$/, 'Branch name contains invalid characters')\n .refine(name => !name.includes('..'), 'Branch name cannot contain \"..\"')\n .refine(name => !name.includes(';'), 'Branch name cannot contain \";\"')\n .refine(name => !name.includes('&'), 'Branch name cannot contain \"&\"')\n .refine(name => !name.includes('|'), 'Branch name cannot contain \"|\"')\n .refine(name => !name.includes('$'), 'Branch name cannot contain \"$\"')\n .refine(name => !name.includes('`'), 'Branch name cannot contain \"`\"');\n\nconst PathSchema = z.string()\n .min(1, 'Path cannot be empty')\n .max(500, 'Path too long')\n .regex(/^[a-zA-Z0-9._/-]+$/, 'Path contains invalid characters')\n .refine(path => !path.includes('..'), 'Path cannot contain \"..\"');\n\nconst CommitSchema = z.string()\n .min(1, 'Commit reference cannot be empty')\n .max(100, 'Commit reference too long')\n .regex(/^[a-zA-Z0-9._/-]+$/, 'Commit reference contains invalid characters');\n\nexport function registerWorktreeCommands(program: Command): void {\n const worktree = program\n .command('worktree')\n .alias('wt')\n .description('Manage StackMemory across git worktrees');\n\n // Enable/disable worktree support\n worktree\n .command('enable')\n .description('Enable worktree support')\n .option(\n '--isolate',\n 'Isolate contexts between worktrees (default: true)',\n true\n )\n .option('--auto-detect', 'Auto-detect worktrees (default: true)', true)\n .option('--sync-interval <minutes>', 'Context sync interval', '15')\n .action(async (options) => {\n const manager = WorktreeManager.getInstance();\n\n manager.saveConfig({\n enabled: true,\n autoDetect: options.autoDetect,\n isolateContexts: options.isolate,\n shareGlobalContext: false,\n syncInterval: parseInt(options.syncInterval),\n });\n\n console.log(chalk.green('\u2713 Worktree support enabled'));\n\n // Auto-detect current worktrees\n const worktrees = manager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.cyan(`\\nDetected ${worktrees.length} worktree(s):`));\n worktrees.forEach((wt) => {\n const marker = wt.isMainWorktree ? ' (main)' : '';\n console.log(chalk.gray(` - ${wt.branch}${marker} at ${wt.path}`));\n });\n }\n });\n\n worktree\n .command('disable')\n .description('Disable worktree support')\n .action(() => {\n const manager = WorktreeManager.getInstance();\n manager.setEnabled(false);\n console.log(chalk.yellow('\u26A0 Worktree support disabled'));\n });\n\n // List all worktrees\n worktree\n .command('list')\n .alias('ls')\n .description('List all git worktrees with StackMemory status')\n .option('-v, --verbose', 'Show detailed information')\n .action((options) => {\n const manager = WorktreeManager.getInstance();\n const worktrees = manager.detectWorktrees();\n\n if (worktrees.length === 0) {\n console.log(chalk.yellow('No worktrees found in current repository'));\n return;\n }\n\n const table = new Table({\n head: ['Branch', 'Path', 'Type', 'Context', 'Last Activity'],\n style: { head: ['cyan'] },\n });\n\n for (const wt of worktrees) {\n const type = wt.isMainWorktree\n ? 'Main'\n : wt.isDetached\n ? 'Detached'\n : 'Branch';\n\n // Check for context\n let contextStatus = '\u2014';\n let lastActivity = '\u2014';\n\n try {\n const context = manager.getWorktreeContext(wt.path);\n if (existsSync(context.dbPath)) {\n contextStatus = '\u2713 Active';\n\n // Get last activity\n const db = new Database(context.dbPath);\n const lastEvent = db\n .prepare('SELECT MAX(created_at) as last FROM events')\n .get() as any;\n\n if (lastEvent?.last) {\n const date = new Date(lastEvent.last);\n lastActivity = date.toLocaleDateString();\n }\n\n db.close();\n } else {\n contextStatus = '\u25CB Not initialized';\n }\n } catch (error: unknown) {\n contextStatus = '\u2717 Error';\n }\n\n table.push([\n wt.branch || 'detached',\n options.verbose\n ? wt.path\n : `.../${wt.path.split('/').slice(-2).join('/')}`,\n type,\n contextStatus,\n lastActivity,\n ]);\n }\n\n console.log(chalk.cyan('\\nGit Worktrees:\\n'));\n console.log(table.toString());\n\n if (manager.isEnabled()) {\n console.log(chalk.gray('\\n\u2713 Worktree support is enabled'));\n const config = manager.getConfig();\n if (config.isolateContexts) {\n console.log(\n chalk.gray(' - Contexts are isolated between worktrees')\n );\n }\n if (config.autoDetect) {\n console.log(chalk.gray(' - Auto-detection is enabled'));\n }\n } else {\n console.log(chalk.gray('\\n\u25CB Worktree support is disabled'));\n console.log(\n chalk.gray(' Run \"stackmemory worktree enable\" to activate')\n );\n }\n });\n\n // Status of current worktree\n worktree\n .command('status')\n .description('Show status of current worktree')\n .action(async () => {\n const manager = WorktreeManager.getInstance();\n const currentPath = process.cwd();\n\n // Detect current worktree\n const worktrees = manager.detectWorktrees(currentPath);\n const current = worktrees.find((w: any) =>\n currentPath.startsWith(w.path)\n );\n\n if (!current) {\n console.log(chalk.yellow('Not in a git worktree'));\n return;\n }\n\n console.log(chalk.cyan('Current Worktree:\\n'));\n console.log(chalk.gray(' Branch:'), current.branch || 'detached');\n console.log(chalk.gray(' Path:'), current.path);\n console.log(\n chalk.gray(' Type:'),\n current.isMainWorktree ? 'Main' : 'Branch'\n );\n console.log(chalk.gray(' Commit:'), current.commit.substring(0, 8));\n\n if (manager.isEnabled()) {\n try {\n const context = manager.getWorktreeContext(current.path);\n console.log(chalk.gray(' Context Path:'), context.contextPath);\n\n if (existsSync(context.dbPath)) {\n const db = new Database(context.dbPath);\n\n // Get statistics\n const stats = db\n .prepare(\n `\n SELECT \n (SELECT COUNT(*) FROM frames) as frames,\n (SELECT COUNT(*) FROM events) as events,\n (SELECT COUNT(*) FROM contexts) as contexts\n `\n )\n .get() as any;\n\n console.log(chalk.cyan('\\nContext Statistics:'));\n console.log(chalk.gray(' Frames:'), stats.frames);\n console.log(chalk.gray(' Events:'), stats.events);\n console.log(chalk.gray(' Contexts:'), stats.contexts);\n\n db.close();\n } else {\n console.log(chalk.yellow('\\nContext not initialized'));\n console.log(chalk.gray(' Run \"stackmemory init\" to initialize'));\n }\n } catch (error: unknown) {\n console.log(\n chalk.red('\\nError accessing context:'),\n (error as Error).message\n );\n }\n } else {\n console.log(chalk.gray('\\nWorktree support is disabled'));\n }\n });\n\n // Create new worktree with StackMemory\n worktree\n .command('create <branch>')\n .description('Create new git worktree with StackMemory context')\n .option('-p, --path <path>', 'Worktree path (default: ../repo-branch)')\n .option('--from <commit>', 'Create branch from commit/branch')\n .option('--init', 'Initialize StackMemory immediately')\n .action(async (branch, options) => {\n const manager = WorktreeManager.getInstance();\n const projectManager = ProjectManager.getInstance();\n\n try {\n // Validate and sanitize inputs\n const validatedBranch = BranchNameSchema.parse(branch);\n \n // Get current project info\n const project = await projectManager.detectProject();\n const worktreePath = options.path || `../${project.name}-${validatedBranch}`;\n \n // Validate path if provided\n if (options.path) {\n PathSchema.parse(options.path);\n }\n \n // Validate commit reference if provided\n if (options.from) {\n CommitSchema.parse(options.from);\n }\n\n // Create git worktree using execFileSync for safety\n const gitArgs = ['worktree', 'add', '-b', validatedBranch, worktreePath];\n if (options.from) {\n gitArgs.push(options.from);\n }\n\n console.log(chalk.gray(`Creating worktree: git ${gitArgs.join(' ')}`));\n execFileSync('git', gitArgs, { stdio: 'inherit' });\n\n console.log(chalk.green(`\u2713 Created worktree at ${worktreePath}`));\n\n // Set up StackMemory context if enabled\n if (manager.isEnabled()) {\n const context = manager.getWorktreeContext(worktreePath);\n console.log(\n chalk.green(`\u2713 Created isolated context at ${context.contextPath}`)\n );\n\n if (options.init) {\n // Initialize StackMemory in new worktree\n const db = new Database(context.dbPath);\n new FrameManager(db, project.id);\n db.close();\n\n console.log(chalk.green('\u2713 StackMemory initialized in worktree'));\n }\n }\n\n console.log(chalk.cyan('\\nNext steps:'));\n console.log(chalk.gray(` cd ${worktreePath}`));\n if (!options.init && manager.isEnabled()) {\n console.log(chalk.gray(' stackmemory init'));\n }\n console.log(chalk.gray(' # Start working in isolated context'));\n } catch (error: unknown) {\n if (error instanceof z.ZodError) {\n console.error(chalk.red('Invalid input:'));\n error.errors.forEach(err => {\n console.error(chalk.red(` ${err.path.join('.')}: ${err.message}`));\n });\n } else {\n console.error(\n chalk.red('Failed to create worktree:'),\n (error as Error).message\n );\n }\n process.exit(1);\n }\n });\n\n // Sync contexts between worktrees\n worktree\n .command('sync')\n .description('Sync contexts between worktrees')\n .option('-s, --source <branch>', 'Source worktree branch')\n .option('-t, --target <branch>', 'Target worktree branch')\n .option('--type <type>', 'Sync type: push|pull|merge (default: merge)')\n .action(async (options) => {\n const manager = WorktreeManager.getInstance();\n\n if (!manager.isEnabled()) {\n console.log(chalk.yellow('Worktree support is not enabled'));\n console.log(chalk.gray('Run \"stackmemory worktree enable\" first'));\n return;\n }\n\n const worktrees = manager.detectWorktrees();\n\n // Find source and target\n let source = worktrees.find((w: any) => w.branch === options.source);\n let target = worktrees.find((w: any) => w.branch === options.target);\n\n if (!source || !target) {\n // Interactive selection if not specified\n const inquirer = await import('inquirer');\n\n if (!source) {\n const { sourceBranch } = await inquirer.default.prompt([\n {\n type: 'list',\n name: 'sourceBranch',\n message: 'Select source worktree:',\n choices: worktrees.map((w: any) => ({\n name: `${w.branch} (${w.path})`,\n value: w,\n })),\n },\n ]);\n source = sourceBranch;\n }\n\n if (!target) {\n const { targetBranch } = await inquirer.default.prompt([\n {\n type: 'list',\n name: 'targetBranch',\n message: 'Select target worktree:',\n choices: worktrees\n .filter((w: any) => w.path !== source!.path)\n .map((w: any) => ({\n name: `${w.branch} (${w.path})`,\n value: w,\n })),\n },\n ]);\n target = targetBranch;\n }\n }\n\n console.log(chalk.cyan('Syncing contexts:'));\n console.log(chalk.gray(' Source:'), source!.branch);\n console.log(chalk.gray(' Target:'), target!.branch);\n console.log(chalk.gray(' Type:'), options.type || 'merge');\n\n try {\n await manager.syncContexts(\n source!.path,\n target!.path,\n options.type || 'merge'\n );\n\n console.log(chalk.green('\u2713 Context sync completed'));\n } catch (error: unknown) {\n console.error(chalk.red('Sync failed:'), (error as Error).message);\n process.exit(1);\n }\n });\n\n // Clean up stale worktree contexts\n worktree\n .command('cleanup')\n .description('Clean up stale worktree contexts')\n .option('--dry-run', 'Show what would be cleaned without doing it')\n .action((options) => {\n const manager = WorktreeManager.getInstance();\n\n if (options.dryRun) {\n console.log(chalk.yellow('Dry run - no changes will be made'));\n }\n\n console.log(chalk.cyan('Checking for stale worktree contexts...'));\n\n if (!options.dryRun) {\n manager.cleanupStaleContexts();\n console.log(chalk.green('\u2713 Cleanup completed'));\n } else {\n const active = manager.detectWorktrees();\n const stored = manager.listActiveWorktrees();\n\n const activePaths = new Set(active.map((w: any) => w.path));\n const stale = stored.filter((w: any) => !activePaths.has(w.path));\n\n if (stale.length === 0) {\n console.log(chalk.green('No stale contexts found'));\n } else {\n console.log(chalk.yellow(`Found ${stale.length} stale context(s):`));\n stale.forEach((w) => {\n console.log(chalk.gray(` - ${w.branch} at ${w.path}`));\n });\n }\n }\n });\n\n // Switch to different worktree\n worktree\n .command('switch <branch>')\n .description('Switch to a different worktree')\n .action(async (branch) => {\n const manager = WorktreeManager.getInstance();\n const worktrees = manager.detectWorktrees();\n\n const target = worktrees.find((w: any) => w.branch === branch);\n if (!target) {\n console.log(chalk.red(`Worktree '${branch}' not found`));\n console.log(chalk.gray('\\nAvailable worktrees:'));\n worktrees.forEach((w) => {\n console.log(chalk.gray(` - ${w.branch}`));\n });\n process.exit(1);\n }\n\n console.log(chalk.cyan(`Switching to worktree: ${branch}`));\n console.log(chalk.gray(`Path: ${target.path}`));\n console.log(chalk.gray('\\nRun this command to switch:'));\n console.log(chalk.green(` cd ${target.path}`));\n\n if (manager.isEnabled() && !target.isMainWorktree) {\n console.log(chalk.gray('\\nThis worktree has an isolated context'));\n }\n });\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/dist/cli/index.js CHANGED
@@ -44,6 +44,7 @@ import { createAgentCommand } from "./commands/agent.js";
44
44
  import { createHandoffCommand } from "./commands/handoff.js";
45
45
  import { createStorageCommand } from "./commands/storage.js";
46
46
  import { createSkillsCommand } from "./commands/skills.js";
47
+ import { createTestCommand } from "./commands/test.js";
47
48
  import clearCommand from "./commands/clear.js";
48
49
  import createWorkflowCommand from "./commands/workflow.js";
49
50
  import monitorCommand from "./commands/monitor.js";
@@ -989,6 +990,7 @@ program.addCommand(createAgentCommand());
989
990
  program.addCommand(createHandoffCommand());
990
991
  program.addCommand(createStorageCommand());
991
992
  program.addCommand(createSkillsCommand());
993
+ program.addCommand(createTestCommand());
992
994
  program.addCommand(clearCommand);
993
995
  program.addCommand(createWorkflowCommand());
994
996
  program.addCommand(monitorCommand);
@@ -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\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { PebblesTaskStore } from '../features/tasks/pebbles-task-store.js';\nimport {\n LinearAuthManager,\n LinearOAuthSetup,\n} from '../integrations/linear/auth.js';\nimport {\n LinearSyncEngine,\n DEFAULT_SYNC_CONFIG,\n} from '../integrations/linear/sync.js';\nimport {\n initializeAutoSync,\n getAutoSyncService,\n stopAutoSync,\n} from '../integrations/linear/auto-sync.js';\nimport { LinearConfigManager } from '../integrations/linear/config.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { registerLinearTestCommand } from './commands/linear-test.js';\nimport { registerLinearListCommand } from './commands/linear-list.js';\nimport { registerLinearMigrateCommand } from './commands/linear-migrate.js';\nimport { registerLinearCreateCommand } from './commands/linear-create.js';\nimport { createChromaDBCommand } from './commands/chromadb.js';\nimport { createInfiniteStorageCommand } from './commands/infinite-storage.js';\nimport { createGCCommand } from './commands/gc.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { webhookCommand } from './commands/webhook.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 { createAgentCommand } from './commands/agent.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\n\nconst VERSION = '0.3.1';\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\nprogram\n .name('stackmemory')\n .description('Lossless memory runtime for AI coding tools')\n .version(VERSION);\n\nprogram\n .command('init')\n .description('Initialize StackMemory in current project')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\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('\u2705 StackMemory initialized in', projectRoot);\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error('\u274C Initialization failed:', (error as Error).message);\n process.exit(1);\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 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(` Cached contexts: ${contextCount.count || 0} (global)`);\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(` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`);\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// Linear Integration Commands\nconst linearCommand = program\n .command('linear')\n .description('Linear API integration commands');\n\nlinearCommand\n .command('setup')\n .description('Setup Linear OAuth integration')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const { authUrl, instructions } = await linearSetup.setupInteractive();\n\n console.log('\uD83D\uDD17 Linear OAuth Setup\\n');\n\n instructions.forEach((instruction) => {\n console.log(instruction);\n });\n\n if (authUrl) {\n console.log('\\n\uD83D\uDCCB Next step: Complete authorization and run:');\n console.log('stackmemory linear authorize <auth-code>');\n }\n } catch (error: unknown) {\n logger.error('Linear setup failed', error as Error);\n console.error('\u274C Setup failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('authorize')\n .description('Complete Linear OAuth authorization')\n .argument('<code>', 'Authorization code from Linear')\n .action(async (authCode: string) => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const success = await linearSetup.completeAuth(authCode);\n\n if (success) {\n console.log('\u2705 Linear integration authorized successfully!');\n console.log('\uD83E\uDDEA Testing connection...');\n\n const connectionOk = await linearSetup.testConnection();\n if (connectionOk) {\n console.log('\u2705 Linear connection test passed!');\n console.log('\\n\uD83D\uDE80 You can now use:');\n console.log('- stackmemory linear sync');\n console.log('- stackmemory linear status');\n } else {\n console.log(\n '\u26A0\uFE0F Linear connection test failed. Check your configuration.'\n );\n }\n } else {\n console.error('\u274C Authorization failed. Please try again.');\n process.exit(1);\n }\n } catch (error: unknown) {\n logger.error('Linear authorization failed', error as Error);\n console.error('\u274C Authorization failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('status')\n .description('Show Linear integration status')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n\n const isConfigured = authManager.isConfigured();\n\n console.log('\uD83D\uDCCA Linear Integration Status:');\n console.log(` Configured: ${isConfigured ? '\u2705' : '\u274C'}`);\n\n if (isConfigured) {\n const config = authManager.loadConfig();\n const tokens = authManager.loadTokens();\n\n console.log(\n ` Client ID: ${config?.clientId ? config.clientId.substring(0, 8) + '...' : 'Not set'}`\n );\n console.log(` Tokens: ${tokens ? '\u2705 Valid' : '\u274C Missing'}`);\n\n if (tokens) {\n const expiresIn = Math.floor(\n (tokens.expiresAt - Date.now()) / 1000 / 60\n );\n console.log(\n ` Token expires: ${expiresIn > 0 ? `${expiresIn} minutes` : 'Expired'}`\n );\n }\n\n // Test connection\n console.log('\\n\uD83E\uDDEA Testing connection...');\n const linearSetup = new LinearOAuthSetup(projectRoot);\n const connectionOk = await linearSetup.testConnection();\n console.log(` Connection: ${connectionOk ? '\u2705 OK' : '\u274C Failed'}`);\n } else {\n console.log('\\n\uD83D\uDCA1 Run \"stackmemory linear setup\" to get started');\n }\n } catch (error: unknown) {\n logger.error('Linear status check failed', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('sync')\n .description('Sync tasks with Linear')\n .option(\n '-d, --direction <direction>',\n 'Sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .action(async (options) => {\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 authManager = new LinearAuthManager(projectRoot);\n\n // Check for API key from environment first\n if (!process.env['LINEAR_API_KEY'] && !authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Set LINEAR_API_KEY environment variable or run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n\n const syncConfig = {\n ...DEFAULT_SYNC_CONFIG,\n enabled: true,\n direction: options.direction,\n };\n\n const linearSync = new LinearSyncEngine(\n taskStore,\n authManager,\n syncConfig\n );\n\n console.log(`\uD83D\uDD04 Starting ${options.direction} sync with Linear...`);\n\n const result = await linearSync.sync();\n\n // Track progress\n const progress = new ProgressTracker(projectRoot);\n\n if (result.success) {\n console.log('\u2705 Sync completed successfully!');\n console.log(` To Linear: ${result.synced.toLinear} created`);\n console.log(` From Linear: ${result.synced.fromLinear} created`);\n console.log(` Updated: ${result.synced.updated}`);\n\n // Update progress tracker\n progress.updateLinearStatus({\n lastSync: new Date().toISOString(),\n tasksSynced:\n result.synced.toLinear +\n result.synced.fromLinear +\n result.synced.updated,\n });\n\n if (result.conflicts.length > 0) {\n console.log(`\\n\u26A0\uFE0F Conflicts detected: ${result.conflicts.length}`);\n result.conflicts.forEach((conflict) => {\n console.log(` - ${conflict.taskId}: ${conflict.reason}`);\n });\n }\n } else {\n console.log('\u274C Sync failed');\n if (result.errors.length > 0) {\n result.errors.forEach((error) => {\n console.log(` Error: ${error}`);\n });\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Linear sync failed', error as Error);\n console.error('\u274C Sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Auto-sync commands\nlinearCommand\n .command('auto-sync')\n .description('Manage automatic synchronization')\n .option('--start', 'Start auto-sync service')\n .option('--stop', 'Stop auto-sync service')\n .option('--status', 'Show auto-sync status')\n .option('--interval <minutes>', 'Set sync interval in minutes', '5')\n .option(\n '--direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .option('--quiet-start <hour>', 'Start of quiet hours (0-23)', '22')\n .option('--quiet-end <hour>', 'End of quiet hours (0-23)', '7')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n\n if (options.status) {\n const service = getAutoSyncService();\n if (service) {\n const status = service.getStatus();\n console.log('\uD83D\uDCCA Linear Auto-Sync Status:');\n console.log(` Running: ${status.running ? '\u2705' : '\u274C'}`);\n console.log(` Direction: ${status.config.direction}`);\n console.log(` Interval: ${status.config.interval} minutes`);\n console.log(\n ` Conflict Resolution: ${status.config.conflictResolution}`\n );\n\n if (status.lastSyncTime > 0) {\n const lastSync = new Date(status.lastSyncTime);\n console.log(` Last Sync: ${lastSync.toLocaleString()}`);\n }\n\n if (status.nextSyncTime) {\n const nextSync = new Date(status.nextSyncTime);\n console.log(` Next Sync: ${nextSync.toLocaleString()}`);\n }\n\n if (status.config.quietHours) {\n console.log(\n ` Quiet Hours: ${status.config.quietHours.start}:00 - ${status.config.quietHours.end}:00`\n );\n }\n\n if (status.retryCount > 0) {\n console.log(` \u26A0\uFE0F Retry Count: ${status.retryCount}`);\n }\n } else {\n console.log('\uD83D\uDCCA Linear Auto-Sync Status: \u274C Not running');\n }\n return;\n }\n\n if (options.start) {\n const authManager = new LinearAuthManager(projectRoot);\n if (!authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const config = {\n interval: parseInt(options.interval),\n direction: options.direction,\n quietHours: {\n start: parseInt(options.quietStart),\n end: parseInt(options.quietEnd),\n },\n };\n\n const service = initializeAutoSync(projectRoot, config);\n await service.start();\n\n console.log('\u2705 Linear auto-sync started');\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n console.log(\n '\\n\uD83D\uDCA1 Use \"stackmemory linear auto-sync --status\" to check status'\n );\n\n // Keep process alive for auto-sync\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDED1 Stopping auto-sync service...');\n service.stop();\n process.exit(0);\n });\n\n console.log('\uD83D\uDD04 Auto-sync running... Press Ctrl+C to stop');\n // Keep the process running\n await new Promise(() => {}); // Intentionally never resolves\n }\n\n if (options.stop) {\n stopAutoSync();\n console.log('\uD83D\uDED1 Linear auto-sync stopped');\n }\n\n if (!options.start && !options.stop && !options.status) {\n console.log('\uD83D\uDCA1 Usage:');\n console.log(' --start Start auto-sync service');\n console.log(' --stop Stop auto-sync service');\n console.log(' --status Show current status');\n console.log(\n '\\nExample: stackmemory linear auto-sync --start --interval 10'\n );\n }\n } catch (error: unknown) {\n logger.error('Linear auto-sync command failed', error as Error);\n console.error('\u274C Auto-sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('force-sync')\n .description('Force immediate synchronization')\n .action(async () => {\n try {\n const service = getAutoSyncService();\n if (service) {\n console.log('\uD83D\uDD04 Forcing immediate sync...');\n await service.forceSync();\n console.log('\u2705 Sync completed');\n } else {\n console.log(\n '\u274C Auto-sync service not running. Use manual sync instead:'\n );\n console.log(' stackmemory linear sync');\n }\n } catch (error: unknown) {\n logger.error('Force sync failed', error as Error);\n console.error('\u274C Force sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('update <issueId>')\n .description('Update Linear task status')\n .option(\n '-s, --status <status>',\n 'New status (todo, in-progress, done, canceled)'\n )\n .option('-t, --title <title>', 'Update task title')\n .option('-d, --description <desc>', 'Update task description')\n .option(\n '-p, --priority <priority>',\n 'Set priority (1=urgent, 2=high, 3=medium, 4=low)'\n )\n .action(async (issueId, options) => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n const tokens = authManager.loadTokens();\n\n if (!tokens) {\n console.error('\u274C Not authenticated. Run: stackmemory linear setup');\n process.exit(1);\n }\n\n const { LinearClient } = await import('../integrations/linear/client.js');\n const client = new LinearClient({\n apiKey: tokens.accessToken,\n useBearer: true,\n onUnauthorized: async () => {\n const refreshed = await authManager.refreshAccessToken();\n return refreshed.accessToken;\n },\n });\n\n // Find the issue first\n let issue = await client.getIssue(issueId);\n if (!issue) {\n // Try finding by identifier\n issue = await client.findIssueByIdentifier(issueId);\n }\n\n if (!issue) {\n console.error(`\u274C Issue ${issueId} not found`);\n process.exit(1);\n }\n\n const updates: Record<string, unknown> = {};\n\n // Handle status update\n if (options.status) {\n const team = await client.getTeam();\n const states = await client.getWorkflowStates(team.id);\n\n const statusMap: Record<string, string> = {\n todo: 'unstarted',\n 'in-progress': 'started',\n done: 'completed',\n canceled: 'cancelled',\n };\n\n const targetType =\n statusMap[options.status.toLowerCase()] || options.status;\n const targetState = states.find(\n (s: { type: string }) => s.type === targetType\n );\n\n if (!targetState) {\n console.error(`\u274C Invalid status: ${options.status}`);\n console.log('Available states:');\n states.forEach((s: { name: string; type: string }) =>\n console.log(` - ${s.name} (${s.type})`)\n );\n process.exit(1);\n }\n\n updates.stateId = targetState.id;\n }\n\n if (options.title) updates.title = options.title;\n if (options.description) updates.description = options.description;\n if (options.priority) updates.priority = parseInt(options.priority);\n\n // Perform update\n const updatedIssue = await client.updateIssue(issue.id, updates);\n\n console.log(\n `\u2705 Updated ${updatedIssue.identifier}: ${updatedIssue.title}`\n );\n if (options.status) {\n console.log(` Status: ${updatedIssue.state.name}`);\n }\n console.log(` ${updatedIssue.url}`);\n\n // Auto-sync to local tasks after update\n console.log('\\n\uD83D\uDD04 Syncing to local tasks...');\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n if (existsSync(dbPath)) {\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n const { LinearSyncEngine, DEFAULT_SYNC_CONFIG } =\n await import('../integrations/linear/sync.js');\n const syncEngine = new LinearSyncEngine(\n taskStore,\n authManager,\n { ...DEFAULT_SYNC_CONFIG, enabled: true, direction: 'from_linear' },\n projectRoot\n );\n const syncResult = await syncEngine.sync();\n if (syncResult.success) {\n console.log(\n ` \u2705 Local tasks synced (${syncResult.synced.fromLinear} new, ${syncResult.synced.updated} updated)`\n );\n }\n db.close();\n }\n } catch (error: unknown) {\n logger.error('Failed to update Linear task', error as Error);\n console.error('\u274C Failed to update task:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('config')\n .description('Configure auto-sync settings')\n .option('--show', 'Show current configuration')\n .option('--set-interval <minutes>', 'Set sync interval in minutes')\n .option(\n '--set-direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear'\n )\n .option(\n '--set-conflict-resolution <strategy>',\n 'Set conflict resolution: newest_wins, linear_wins, stackmemory_wins, manual'\n )\n .option('--set-quiet-start <hour>', 'Set start of quiet hours (0-23)')\n .option('--set-quiet-end <hour>', 'Set end of quiet hours (0-23)')\n .option('--enable', 'Enable auto-sync')\n .option('--disable', 'Disable auto-sync')\n .option('--reset', 'Reset to default configuration')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const configManager = new LinearConfigManager(projectRoot);\n\n if (options.reset) {\n configManager.resetConfig();\n console.log('\u2705 Configuration reset to defaults');\n return;\n }\n\n if (options.show) {\n const config = configManager.loadConfig();\n if (config) {\n console.log('\uD83D\uDCCA Linear Auto-Sync Configuration:');\n console.log(` Enabled: ${config.enabled ? '\u2705' : '\u274C'}`);\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(` Conflict Resolution: ${config.conflictResolution}`);\n console.log(` Retry Attempts: ${config.retryAttempts}`);\n console.log(` Retry Delay: ${config.retryDelay / 1000}s`);\n\n if (config.quietHours) {\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n }\n\n const lastUpdated = new Date(config.lastUpdated);\n console.log(` Last Updated: ${lastUpdated.toLocaleString()}`);\n } else {\n console.log('\uD83D\uDCCA No configuration found. Using defaults.');\n const defaultConfig = configManager.getDefaultConfig();\n console.log(` Default interval: ${defaultConfig.interval} minutes`);\n console.log(` Default direction: ${defaultConfig.direction}`);\n }\n return;\n }\n\n // Update configuration\n const updates: Record<string, unknown> = {};\n\n if (options.setInterval) {\n const interval = parseInt(options.setInterval);\n if (isNaN(interval) || interval < 1) {\n console.error('\u274C Interval must be a positive number');\n process.exit(1);\n }\n updates.interval = interval;\n console.log(`\u2705 Set interval to ${interval} minutes`);\n }\n\n if (options.setDirection) {\n const validDirections = ['bidirectional', 'to_linear', 'from_linear'];\n if (!validDirections.includes(options.setDirection)) {\n console.error(\n `\u274C Invalid direction. Must be one of: ${validDirections.join(', ')}`\n );\n process.exit(1);\n }\n updates.direction = options.setDirection;\n console.log(`\u2705 Set direction to ${options.setDirection}`);\n }\n\n if (options.setConflictResolution) {\n const validStrategies = [\n 'newest_wins',\n 'linear_wins',\n 'stackmemory_wins',\n 'manual',\n ];\n if (!validStrategies.includes(options.setConflictResolution)) {\n console.error(\n `\u274C Invalid strategy. Must be one of: ${validStrategies.join(', ')}`\n );\n process.exit(1);\n }\n updates.conflictResolution = options.setConflictResolution;\n console.log(\n `\u2705 Set conflict resolution to ${options.setConflictResolution}`\n );\n }\n\n if (options.setQuietStart) {\n const hour = parseInt(options.setQuietStart);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet start hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: hour,\n end: currentConfig.quietHours?.end || 7,\n };\n console.log(`\u2705 Set quiet hours start to ${hour}:00`);\n }\n\n if (options.setQuietEnd) {\n const hour = parseInt(options.setQuietEnd);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet end hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: currentConfig.quietHours?.start || 22,\n end: hour,\n };\n console.log(`\u2705 Set quiet hours end to ${hour}:00`);\n }\n\n if (options.enable) {\n updates.enabled = true;\n console.log('\u2705 Auto-sync enabled');\n }\n\n if (options.disable) {\n updates.enabled = false;\n console.log('\u274C Auto-sync disabled');\n }\n\n if (Object.keys(updates).length > 0) {\n configManager.saveConfig(updates);\n console.log(\n '\\n\uD83D\uDCA1 Configuration updated. Restart auto-sync service to apply changes.'\n );\n } else if (!options.show) {\n console.log('\uD83D\uDCA1 Use --show to view current configuration');\n console.log('\uD83D\uDCA1 Use --help to see all configuration options');\n }\n } catch (error: unknown) {\n logger.error('Linear config command failed', error as Error);\n console.error('\u274C Config failed:', (error as Error).message);\n process.exit(1);\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('analytics')\n .description('Launch task analytics dashboard')\n .option('-p, --port <port>', 'Port for dashboard server', '3000')\n .option('-o, --open', 'Open dashboard in browser')\n .option('--export <format>', 'Export metrics (json|csv)')\n .option('--sync', 'Sync with Linear before launching')\n .option('--view', 'Show analytics in terminal')\n .action(async (options) => {\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 (options.view) {\n const { displayAnalyticsDashboard } = await import('./utils/viewer.js');\n await displayAnalyticsDashboard(projectRoot);\n return;\n }\n\n if (options.export) {\n const { AnalyticsService } =\n await import('../features/analytics/index.js');\n const service = new AnalyticsService(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n await service.syncLinearTasks();\n }\n\n const state = await service.getDashboardState();\n\n if (options.export === 'csv') {\n console.log('\uD83D\uDCCA Exporting metrics as CSV...');\n // Convert to CSV format\n const tasks = state.recentTasks;\n const headers = [\n 'ID',\n 'Title',\n 'State',\n 'Priority',\n 'Created',\n 'Completed',\n ];\n const rows = tasks.map((t) => [\n t.id,\n t.title,\n t.state,\n t.priority,\n t.createdAt.toISOString(),\n t.completedAt?.toISOString() || '',\n ]);\n console.log(headers.join(','));\n rows.forEach((r) => console.log(r.join(',')));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n\n service.close();\n return;\n }\n\n // Launch dashboard server\n console.log(\n `\uD83D\uDE80 Launching analytics dashboard on port ${options.port}...`\n );\n\n const express = (await import('express')).default;\n const { AnalyticsAPI } = await import('../features/analytics/index.js');\n const { createServer } = await import('http');\n\n const app = express();\n\n // Add error handling middleware\n app.use(\n (\n err: Error,\n _req: import('express').Request,\n res: import('express').Response,\n _next: import('express').NextFunction\n ) => {\n console.error('Express error:', err);\n res.status(500).json({ error: err.message });\n }\n );\n\n const analyticsAPI = new AnalyticsAPI(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n const service = new (\n await import('../features/analytics/index.js')\n ).AnalyticsService(projectRoot);\n await service.syncLinearTasks();\n service.close();\n }\n\n app.use('/api/analytics', analyticsAPI.getRouter());\n\n // Serve the HTML dashboard\n app.get('/', async (req, res) => {\n // Try multiple paths for the dashboard HTML\n const possiblePaths = [\n join(projectRoot, 'src/features/analytics/dashboard.html'),\n join(projectRoot, 'dist/features/analytics/dashboard.html'),\n ];\n\n for (const dashboardPath of possiblePaths) {\n if (existsSync(dashboardPath)) {\n res.sendFile(dashboardPath);\n return;\n }\n }\n\n // Inline fallback dashboard\n res.send(`<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>StackMemory Analytics</title>\n <script src=\"https://cdn.jsdelivr.net/npm/chart.js\"></script>\n <style>\n * { margin: 0; padding: 0; box-sizing: border-box; }\n body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #1a1a2e; color: #eee; padding: 20px; }\n .container { max-width: 1200px; margin: 0 auto; }\n h1 { color: #667eea; margin-bottom: 20px; }\n .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-bottom: 30px; }\n .card { background: #16213e; border-radius: 12px; padding: 20px; }\n .metric-value { font-size: 2.5em; font-weight: bold; color: #667eea; }\n .metric-label { color: #888; text-transform: uppercase; font-size: 0.8em; }\n .task-list { max-height: 400px; overflow-y: auto; }\n .task-item { padding: 10px; border-left: 3px solid #667eea; margin-bottom: 8px; background: #1a1a2e; }\n .task-item.completed { border-color: #22c55e; }\n .task-item.in_progress { border-color: #f59e0b; }\n .status { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.8em; margin-right: 8px; }\n .status.completed { background: #22c55e30; color: #22c55e; }\n .status.in_progress { background: #f59e0b30; color: #f59e0b; }\n .status.todo { background: #667eea30; color: #667eea; }\n </style>\n</head>\n<body>\n <div class=\"container\">\n <h1>\uD83D\uDCCA StackMemory Analytics</h1>\n <div class=\"grid\" id=\"metrics\"></div>\n <div class=\"card\"><h3>Recent Tasks</h3><div class=\"task-list\" id=\"tasks\">Loading...</div></div>\n </div>\n <script>\n async function load() {\n const metrics = await fetch('/api/analytics/metrics').then(r => r.json());\n const tasks = await fetch('/api/analytics/tasks').then(r => r.json());\n \n document.getElementById('metrics').innerHTML = \\`\n <div class=\"card\"><div class=\"metric-label\">Total</div><div class=\"metric-value\">\\${metrics.data.metrics.totalTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completed</div><div class=\"metric-value\">\\${metrics.data.metrics.completedTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">In Progress</div><div class=\"metric-value\">\\${metrics.data.metrics.inProgressTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completion</div><div class=\"metric-value\">\\${metrics.data.metrics.completionRate.toFixed(0)}%</div></div>\n \\`;\n \n document.getElementById('tasks').innerHTML = tasks.data.tasks.slice(0, 10).map((t: any) => \\`\n <div class=\"task-item \\${t.state}\">\n <span class=\"status \\${t.state}\">\\${t.state}</span>\n <strong>\\${t.title}</strong>\n </div>\n \\`).join('');\n }\n load();\n setInterval(load, 30000);\n </script>\n</body>\n</html>`);\n });\n\n const server = createServer(app);\n analyticsAPI.setupWebSocket(server);\n\n server.listen(options.port, async () => {\n console.log(\n `\u2705 Analytics dashboard running at http://localhost:${options.port}`\n );\n\n if (options.open) {\n const { exec } = await import('child_process');\n const url = `http://localhost:${options.port}`;\n const command =\n process.platform === 'darwin'\n ? `open ${url}`\n : process.platform === 'win32'\n ? `start ${url}`\n : `xdg-open ${url}`;\n exec(command);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDC4B Shutting down analytics dashboard...');\n analyticsAPI.close();\n server.close();\n process.exit(0);\n });\n\n // Keep the process alive\n await new Promise(() => {});\n } catch (error: unknown) {\n logger.error('Analytics command failed', error as Error);\n console.error('\u274C Analytics 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\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);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\nregisterLinearTestCommand(program);\nregisterLinearListCommand(program);\nregisterLinearMigrateCommand(program);\nregisterLinearCreateCommand(program);\n\n// Add ChromaDB command\nprogram.addCommand(createChromaDBCommand());\n\n// Add Infinite Storage command\nprogram.addCommand(createInfiniteStorageCommand());\nprogram.addCommand(createGCCommand());\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register webhook command\nprogram.addCommand(webhookCommand());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createAgentCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\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// Register TUI command (advanced terminal UI - requires blessed)\nprogram\n .command('tui')\n .description('Launch interactive TUI monitoring dashboard (requires blessed)')\n .option('-s, --server', 'Start WebSocket server for real-time updates')\n .option('-w, --ws-url <url>', 'WebSocket server URL', 'ws://localhost:8080')\n .option('-r, --refresh <ms>', 'Auto-refresh interval in milliseconds', '2000')\n .action(async (options) => {\n try {\n // Check if blessed is installed by trying to import it\n try {\n await import('blessed');\n } catch {\n console.log(\n '\u274C The TUI requires the blessed package. Install it with:'\n );\n console.log(' npm install blessed blessed-contrib');\n console.log(\n '\\n\uD83D\uDCA1 Alternatively, use \"stackmemory dashboard\" for a simpler view'\n );\n process.exit(1);\n }\n\n const { spawn } = await import('child_process');\n const { fileURLToPath } = await import('url');\n const { dirname, join } = await import('path');\n\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n\n console.log('\uD83D\uDE80 Launching StackMemory TUI Dashboard...');\n\n // Set environment variables\n process.env['STACKMEMORY_WS_URL'] = options.wsUrl;\n\n // Get TUI module path\n const tuiPath = join(__dirname, '../features/tui/index.js');\n\n // Launch TUI directly\n const tui = spawn('node', [tuiPath], {\n stdio: 'inherit',\n env: {\n ...process.env,\n STACKMEMORY_WS_URL: options.wsUrl,\n },\n });\n\n tui.on('error', (error) => {\n console.error('Failed to launch TUI:', error);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" instead');\n process.exit(1);\n });\n\n tui.on('exit', (code) => {\n if (code !== 0) {\n console.error(`TUI exited with code ${code}`);\n process.exit(code || 1);\n }\n });\n } catch (error: unknown) {\n console.error('\u274C Failed to launch TUI:', (error as Error).message);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" for a simpler view');\n process.exit(1);\n }\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\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\nimport { program } from 'commander';\nimport { logger } from '../core/monitoring/logger.js';\nimport { FrameManager } from '../core/context/frame-manager.js';\nimport { sessionManager, FrameQueryMode } from '../core/session/index.js';\nimport { sharedContextLayer } from '../core/context/shared-context-layer.js';\nimport { PebblesTaskStore } from '../features/tasks/pebbles-task-store.js';\nimport {\n LinearAuthManager,\n LinearOAuthSetup,\n} from '../integrations/linear/auth.js';\nimport {\n LinearSyncEngine,\n DEFAULT_SYNC_CONFIG,\n} from '../integrations/linear/sync.js';\nimport {\n initializeAutoSync,\n getAutoSyncService,\n stopAutoSync,\n} from '../integrations/linear/auto-sync.js';\nimport { LinearConfigManager } from '../integrations/linear/config.js';\nimport { UpdateChecker } from '../core/utils/update-checker.js';\nimport { ProgressTracker } from '../core/monitoring/progress-tracker.js';\nimport { registerProjectCommands } from './commands/projects.js';\nimport { registerLinearCommands } from './commands/linear.js';\nimport { registerLinearTestCommand } from './commands/linear-test.js';\nimport { registerLinearListCommand } from './commands/linear-list.js';\nimport { registerLinearMigrateCommand } from './commands/linear-migrate.js';\nimport { registerLinearCreateCommand } from './commands/linear-create.js';\nimport { createChromaDBCommand } from './commands/chromadb.js';\nimport { createInfiniteStorageCommand } from './commands/infinite-storage.js';\nimport { createGCCommand } from './commands/gc.js';\nimport { createSessionCommands } from './commands/session.js';\nimport { registerWorktreeCommands } from './commands/worktree.js';\nimport { registerOnboardingCommand } from './commands/onboard.js';\nimport { webhookCommand } from './commands/webhook.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 { createAgentCommand } from './commands/agent.js';\nimport { createHandoffCommand } from './commands/handoff.js';\nimport { createStorageCommand } from './commands/storage.js';\nimport { createSkillsCommand } from './commands/skills.js';\nimport { createTestCommand } from './commands/test.js';\nimport clearCommand from './commands/clear.js';\nimport createWorkflowCommand from './commands/workflow.js';\nimport monitorCommand from './commands/monitor.js';\nimport qualityCommand from './commands/quality.js';\nimport { ProjectManager } from '../core/projects/project-manager.js';\nimport Database from 'better-sqlite3';\nimport { join } from 'path';\nimport { existsSync, mkdirSync } from 'fs';\n\nconst VERSION = '0.3.1';\n\n// Check for updates on CLI startup\nUpdateChecker.checkForUpdates(VERSION, true).catch(() => {\n // Silently ignore errors\n});\n\nprogram\n .name('stackmemory')\n .description('Lossless memory runtime for AI coding tools')\n .version(VERSION);\n\nprogram\n .command('init')\n .description('Initialize StackMemory in current project')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const dbDir = join(projectRoot, '.stackmemory');\n\n if (!existsSync(dbDir)) {\n mkdirSync(dbDir, { recursive: true });\n }\n\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('\u2705 StackMemory initialized in', projectRoot);\n\n db.close();\n } catch (error: unknown) {\n logger.error('Failed to initialize StackMemory', error as Error);\n console.error('\u274C Initialization failed:', (error as Error).message);\n process.exit(1);\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 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(` Cached contexts: ${contextCount.count || 0} (global)`);\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(` ${stateIcon} ${f.name} [${f.type}] - ${f.created}`);\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// Linear Integration Commands\nconst linearCommand = program\n .command('linear')\n .description('Linear API integration commands');\n\nlinearCommand\n .command('setup')\n .description('Setup Linear OAuth integration')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const { authUrl, instructions } = await linearSetup.setupInteractive();\n\n console.log('\uD83D\uDD17 Linear OAuth Setup\\n');\n\n instructions.forEach((instruction) => {\n console.log(instruction);\n });\n\n if (authUrl) {\n console.log('\\n\uD83D\uDCCB Next step: Complete authorization and run:');\n console.log('stackmemory linear authorize <auth-code>');\n }\n } catch (error: unknown) {\n logger.error('Linear setup failed', error as Error);\n console.error('\u274C Setup failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('authorize')\n .description('Complete Linear OAuth authorization')\n .argument('<code>', 'Authorization code from Linear')\n .action(async (authCode: string) => {\n try {\n const projectRoot = process.cwd();\n const linearSetup = new LinearOAuthSetup(projectRoot);\n\n const success = await linearSetup.completeAuth(authCode);\n\n if (success) {\n console.log('\u2705 Linear integration authorized successfully!');\n console.log('\uD83E\uDDEA Testing connection...');\n\n const connectionOk = await linearSetup.testConnection();\n if (connectionOk) {\n console.log('\u2705 Linear connection test passed!');\n console.log('\\n\uD83D\uDE80 You can now use:');\n console.log('- stackmemory linear sync');\n console.log('- stackmemory linear status');\n } else {\n console.log(\n '\u26A0\uFE0F Linear connection test failed. Check your configuration.'\n );\n }\n } else {\n console.error('\u274C Authorization failed. Please try again.');\n process.exit(1);\n }\n } catch (error: unknown) {\n logger.error('Linear authorization failed', error as Error);\n console.error('\u274C Authorization failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('status')\n .description('Show Linear integration status')\n .action(async () => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n\n const isConfigured = authManager.isConfigured();\n\n console.log('\uD83D\uDCCA Linear Integration Status:');\n console.log(` Configured: ${isConfigured ? '\u2705' : '\u274C'}`);\n\n if (isConfigured) {\n const config = authManager.loadConfig();\n const tokens = authManager.loadTokens();\n\n console.log(\n ` Client ID: ${config?.clientId ? config.clientId.substring(0, 8) + '...' : 'Not set'}`\n );\n console.log(` Tokens: ${tokens ? '\u2705 Valid' : '\u274C Missing'}`);\n\n if (tokens) {\n const expiresIn = Math.floor(\n (tokens.expiresAt - Date.now()) / 1000 / 60\n );\n console.log(\n ` Token expires: ${expiresIn > 0 ? `${expiresIn} minutes` : 'Expired'}`\n );\n }\n\n // Test connection\n console.log('\\n\uD83E\uDDEA Testing connection...');\n const linearSetup = new LinearOAuthSetup(projectRoot);\n const connectionOk = await linearSetup.testConnection();\n console.log(` Connection: ${connectionOk ? '\u2705 OK' : '\u274C Failed'}`);\n } else {\n console.log('\\n\uD83D\uDCA1 Run \"stackmemory linear setup\" to get started');\n }\n } catch (error: unknown) {\n logger.error('Linear status check failed', error as Error);\n console.error('\u274C Status check failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('sync')\n .description('Sync tasks with Linear')\n .option(\n '-d, --direction <direction>',\n 'Sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .action(async (options) => {\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 authManager = new LinearAuthManager(projectRoot);\n\n // Check for API key from environment first\n if (!process.env['LINEAR_API_KEY'] && !authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Set LINEAR_API_KEY environment variable or run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n\n const syncConfig = {\n ...DEFAULT_SYNC_CONFIG,\n enabled: true,\n direction: options.direction,\n };\n\n const linearSync = new LinearSyncEngine(\n taskStore,\n authManager,\n syncConfig\n );\n\n console.log(`\uD83D\uDD04 Starting ${options.direction} sync with Linear...`);\n\n const result = await linearSync.sync();\n\n // Track progress\n const progress = new ProgressTracker(projectRoot);\n\n if (result.success) {\n console.log('\u2705 Sync completed successfully!');\n console.log(` To Linear: ${result.synced.toLinear} created`);\n console.log(` From Linear: ${result.synced.fromLinear} created`);\n console.log(` Updated: ${result.synced.updated}`);\n\n // Update progress tracker\n progress.updateLinearStatus({\n lastSync: new Date().toISOString(),\n tasksSynced:\n result.synced.toLinear +\n result.synced.fromLinear +\n result.synced.updated,\n });\n\n if (result.conflicts.length > 0) {\n console.log(`\\n\u26A0\uFE0F Conflicts detected: ${result.conflicts.length}`);\n result.conflicts.forEach((conflict) => {\n console.log(` - ${conflict.taskId}: ${conflict.reason}`);\n });\n }\n } else {\n console.log('\u274C Sync failed');\n if (result.errors.length > 0) {\n result.errors.forEach((error) => {\n console.log(` Error: ${error}`);\n });\n }\n }\n\n db.close();\n } catch (error: unknown) {\n logger.error('Linear sync failed', error as Error);\n console.error('\u274C Sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\n// Auto-sync commands\nlinearCommand\n .command('auto-sync')\n .description('Manage automatic synchronization')\n .option('--start', 'Start auto-sync service')\n .option('--stop', 'Stop auto-sync service')\n .option('--status', 'Show auto-sync status')\n .option('--interval <minutes>', 'Set sync interval in minutes', '5')\n .option(\n '--direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear',\n 'bidirectional'\n )\n .option('--quiet-start <hour>', 'Start of quiet hours (0-23)', '22')\n .option('--quiet-end <hour>', 'End of quiet hours (0-23)', '7')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n\n if (options.status) {\n const service = getAutoSyncService();\n if (service) {\n const status = service.getStatus();\n console.log('\uD83D\uDCCA Linear Auto-Sync Status:');\n console.log(` Running: ${status.running ? '\u2705' : '\u274C'}`);\n console.log(` Direction: ${status.config.direction}`);\n console.log(` Interval: ${status.config.interval} minutes`);\n console.log(\n ` Conflict Resolution: ${status.config.conflictResolution}`\n );\n\n if (status.lastSyncTime > 0) {\n const lastSync = new Date(status.lastSyncTime);\n console.log(` Last Sync: ${lastSync.toLocaleString()}`);\n }\n\n if (status.nextSyncTime) {\n const nextSync = new Date(status.nextSyncTime);\n console.log(` Next Sync: ${nextSync.toLocaleString()}`);\n }\n\n if (status.config.quietHours) {\n console.log(\n ` Quiet Hours: ${status.config.quietHours.start}:00 - ${status.config.quietHours.end}:00`\n );\n }\n\n if (status.retryCount > 0) {\n console.log(` \u26A0\uFE0F Retry Count: ${status.retryCount}`);\n }\n } else {\n console.log('\uD83D\uDCCA Linear Auto-Sync Status: \u274C Not running');\n }\n return;\n }\n\n if (options.start) {\n const authManager = new LinearAuthManager(projectRoot);\n if (!authManager.isConfigured()) {\n console.log(\n '\u274C Linear not configured. Run \"stackmemory linear setup\" first.'\n );\n return;\n }\n\n const config = {\n interval: parseInt(options.interval),\n direction: options.direction,\n quietHours: {\n start: parseInt(options.quietStart),\n end: parseInt(options.quietEnd),\n },\n };\n\n const service = initializeAutoSync(projectRoot, config);\n await service.start();\n\n console.log('\u2705 Linear auto-sync started');\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n console.log(\n '\\n\uD83D\uDCA1 Use \"stackmemory linear auto-sync --status\" to check status'\n );\n\n // Keep process alive for auto-sync\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDED1 Stopping auto-sync service...');\n service.stop();\n process.exit(0);\n });\n\n console.log('\uD83D\uDD04 Auto-sync running... Press Ctrl+C to stop');\n // Keep the process running\n await new Promise(() => {}); // Intentionally never resolves\n }\n\n if (options.stop) {\n stopAutoSync();\n console.log('\uD83D\uDED1 Linear auto-sync stopped');\n }\n\n if (!options.start && !options.stop && !options.status) {\n console.log('\uD83D\uDCA1 Usage:');\n console.log(' --start Start auto-sync service');\n console.log(' --stop Stop auto-sync service');\n console.log(' --status Show current status');\n console.log(\n '\\nExample: stackmemory linear auto-sync --start --interval 10'\n );\n }\n } catch (error: unknown) {\n logger.error('Linear auto-sync command failed', error as Error);\n console.error('\u274C Auto-sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('force-sync')\n .description('Force immediate synchronization')\n .action(async () => {\n try {\n const service = getAutoSyncService();\n if (service) {\n console.log('\uD83D\uDD04 Forcing immediate sync...');\n await service.forceSync();\n console.log('\u2705 Sync completed');\n } else {\n console.log(\n '\u274C Auto-sync service not running. Use manual sync instead:'\n );\n console.log(' stackmemory linear sync');\n }\n } catch (error: unknown) {\n logger.error('Force sync failed', error as Error);\n console.error('\u274C Force sync failed:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('update <issueId>')\n .description('Update Linear task status')\n .option(\n '-s, --status <status>',\n 'New status (todo, in-progress, done, canceled)'\n )\n .option('-t, --title <title>', 'Update task title')\n .option('-d, --description <desc>', 'Update task description')\n .option(\n '-p, --priority <priority>',\n 'Set priority (1=urgent, 2=high, 3=medium, 4=low)'\n )\n .action(async (issueId, options) => {\n try {\n const projectRoot = process.cwd();\n const authManager = new LinearAuthManager(projectRoot);\n const tokens = authManager.loadTokens();\n\n if (!tokens) {\n console.error('\u274C Not authenticated. Run: stackmemory linear setup');\n process.exit(1);\n }\n\n const { LinearClient } = await import('../integrations/linear/client.js');\n const client = new LinearClient({\n apiKey: tokens.accessToken,\n useBearer: true,\n onUnauthorized: async () => {\n const refreshed = await authManager.refreshAccessToken();\n return refreshed.accessToken;\n },\n });\n\n // Find the issue first\n let issue = await client.getIssue(issueId);\n if (!issue) {\n // Try finding by identifier\n issue = await client.findIssueByIdentifier(issueId);\n }\n\n if (!issue) {\n console.error(`\u274C Issue ${issueId} not found`);\n process.exit(1);\n }\n\n const updates: Record<string, unknown> = {};\n\n // Handle status update\n if (options.status) {\n const team = await client.getTeam();\n const states = await client.getWorkflowStates(team.id);\n\n const statusMap: Record<string, string> = {\n todo: 'unstarted',\n 'in-progress': 'started',\n done: 'completed',\n canceled: 'cancelled',\n };\n\n const targetType =\n statusMap[options.status.toLowerCase()] || options.status;\n const targetState = states.find(\n (s: { type: string }) => s.type === targetType\n );\n\n if (!targetState) {\n console.error(`\u274C Invalid status: ${options.status}`);\n console.log('Available states:');\n states.forEach((s: { name: string; type: string }) =>\n console.log(` - ${s.name} (${s.type})`)\n );\n process.exit(1);\n }\n\n updates.stateId = targetState.id;\n }\n\n if (options.title) updates.title = options.title;\n if (options.description) updates.description = options.description;\n if (options.priority) updates.priority = parseInt(options.priority);\n\n // Perform update\n const updatedIssue = await client.updateIssue(issue.id, updates);\n\n console.log(\n `\u2705 Updated ${updatedIssue.identifier}: ${updatedIssue.title}`\n );\n if (options.status) {\n console.log(` Status: ${updatedIssue.state.name}`);\n }\n console.log(` ${updatedIssue.url}`);\n\n // Auto-sync to local tasks after update\n console.log('\\n\uD83D\uDD04 Syncing to local tasks...');\n const dbPath = join(projectRoot, '.stackmemory', 'context.db');\n if (existsSync(dbPath)) {\n const db = new Database(dbPath);\n const taskStore = new PebblesTaskStore(projectRoot, db);\n const { LinearSyncEngine, DEFAULT_SYNC_CONFIG } =\n await import('../integrations/linear/sync.js');\n const syncEngine = new LinearSyncEngine(\n taskStore,\n authManager,\n { ...DEFAULT_SYNC_CONFIG, enabled: true, direction: 'from_linear' },\n projectRoot\n );\n const syncResult = await syncEngine.sync();\n if (syncResult.success) {\n console.log(\n ` \u2705 Local tasks synced (${syncResult.synced.fromLinear} new, ${syncResult.synced.updated} updated)`\n );\n }\n db.close();\n }\n } catch (error: unknown) {\n logger.error('Failed to update Linear task', error as Error);\n console.error('\u274C Failed to update task:', (error as Error).message);\n process.exit(1);\n }\n });\n\nlinearCommand\n .command('config')\n .description('Configure auto-sync settings')\n .option('--show', 'Show current configuration')\n .option('--set-interval <minutes>', 'Set sync interval in minutes')\n .option(\n '--set-direction <direction>',\n 'Set sync direction: bidirectional, to_linear, from_linear'\n )\n .option(\n '--set-conflict-resolution <strategy>',\n 'Set conflict resolution: newest_wins, linear_wins, stackmemory_wins, manual'\n )\n .option('--set-quiet-start <hour>', 'Set start of quiet hours (0-23)')\n .option('--set-quiet-end <hour>', 'Set end of quiet hours (0-23)')\n .option('--enable', 'Enable auto-sync')\n .option('--disable', 'Disable auto-sync')\n .option('--reset', 'Reset to default configuration')\n .action(async (options) => {\n try {\n const projectRoot = process.cwd();\n const configManager = new LinearConfigManager(projectRoot);\n\n if (options.reset) {\n configManager.resetConfig();\n console.log('\u2705 Configuration reset to defaults');\n return;\n }\n\n if (options.show) {\n const config = configManager.loadConfig();\n if (config) {\n console.log('\uD83D\uDCCA Linear Auto-Sync Configuration:');\n console.log(` Enabled: ${config.enabled ? '\u2705' : '\u274C'}`);\n console.log(` Interval: ${config.interval} minutes`);\n console.log(` Direction: ${config.direction}`);\n console.log(` Conflict Resolution: ${config.conflictResolution}`);\n console.log(` Retry Attempts: ${config.retryAttempts}`);\n console.log(` Retry Delay: ${config.retryDelay / 1000}s`);\n\n if (config.quietHours) {\n console.log(\n ` Quiet Hours: ${config.quietHours.start}:00 - ${config.quietHours.end}:00`\n );\n }\n\n const lastUpdated = new Date(config.lastUpdated);\n console.log(` Last Updated: ${lastUpdated.toLocaleString()}`);\n } else {\n console.log('\uD83D\uDCCA No configuration found. Using defaults.');\n const defaultConfig = configManager.getDefaultConfig();\n console.log(` Default interval: ${defaultConfig.interval} minutes`);\n console.log(` Default direction: ${defaultConfig.direction}`);\n }\n return;\n }\n\n // Update configuration\n const updates: Record<string, unknown> = {};\n\n if (options.setInterval) {\n const interval = parseInt(options.setInterval);\n if (isNaN(interval) || interval < 1) {\n console.error('\u274C Interval must be a positive number');\n process.exit(1);\n }\n updates.interval = interval;\n console.log(`\u2705 Set interval to ${interval} minutes`);\n }\n\n if (options.setDirection) {\n const validDirections = ['bidirectional', 'to_linear', 'from_linear'];\n if (!validDirections.includes(options.setDirection)) {\n console.error(\n `\u274C Invalid direction. Must be one of: ${validDirections.join(', ')}`\n );\n process.exit(1);\n }\n updates.direction = options.setDirection;\n console.log(`\u2705 Set direction to ${options.setDirection}`);\n }\n\n if (options.setConflictResolution) {\n const validStrategies = [\n 'newest_wins',\n 'linear_wins',\n 'stackmemory_wins',\n 'manual',\n ];\n if (!validStrategies.includes(options.setConflictResolution)) {\n console.error(\n `\u274C Invalid strategy. Must be one of: ${validStrategies.join(', ')}`\n );\n process.exit(1);\n }\n updates.conflictResolution = options.setConflictResolution;\n console.log(\n `\u2705 Set conflict resolution to ${options.setConflictResolution}`\n );\n }\n\n if (options.setQuietStart) {\n const hour = parseInt(options.setQuietStart);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet start hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: hour,\n end: currentConfig.quietHours?.end || 7,\n };\n console.log(`\u2705 Set quiet hours start to ${hour}:00`);\n }\n\n if (options.setQuietEnd) {\n const hour = parseInt(options.setQuietEnd);\n if (isNaN(hour) || hour < 0 || hour > 23) {\n console.error('\u274C Quiet end hour must be between 0 and 23');\n process.exit(1);\n }\n const currentConfig =\n configManager.loadConfig() || configManager.getDefaultConfig();\n updates.quietHours = {\n start: currentConfig.quietHours?.start || 22,\n end: hour,\n };\n console.log(`\u2705 Set quiet hours end to ${hour}:00`);\n }\n\n if (options.enable) {\n updates.enabled = true;\n console.log('\u2705 Auto-sync enabled');\n }\n\n if (options.disable) {\n updates.enabled = false;\n console.log('\u274C Auto-sync disabled');\n }\n\n if (Object.keys(updates).length > 0) {\n configManager.saveConfig(updates);\n console.log(\n '\\n\uD83D\uDCA1 Configuration updated. Restart auto-sync service to apply changes.'\n );\n } else if (!options.show) {\n console.log('\uD83D\uDCA1 Use --show to view current configuration');\n console.log('\uD83D\uDCA1 Use --help to see all configuration options');\n }\n } catch (error: unknown) {\n logger.error('Linear config command failed', error as Error);\n console.error('\u274C Config failed:', (error as Error).message);\n process.exit(1);\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('analytics')\n .description('Launch task analytics dashboard')\n .option('-p, --port <port>', 'Port for dashboard server', '3000')\n .option('-o, --open', 'Open dashboard in browser')\n .option('--export <format>', 'Export metrics (json|csv)')\n .option('--sync', 'Sync with Linear before launching')\n .option('--view', 'Show analytics in terminal')\n .action(async (options) => {\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 (options.view) {\n const { displayAnalyticsDashboard } = await import('./utils/viewer.js');\n await displayAnalyticsDashboard(projectRoot);\n return;\n }\n\n if (options.export) {\n const { AnalyticsService } =\n await import('../features/analytics/index.js');\n const service = new AnalyticsService(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n await service.syncLinearTasks();\n }\n\n const state = await service.getDashboardState();\n\n if (options.export === 'csv') {\n console.log('\uD83D\uDCCA Exporting metrics as CSV...');\n // Convert to CSV format\n const tasks = state.recentTasks;\n const headers = [\n 'ID',\n 'Title',\n 'State',\n 'Priority',\n 'Created',\n 'Completed',\n ];\n const rows = tasks.map((t) => [\n t.id,\n t.title,\n t.state,\n t.priority,\n t.createdAt.toISOString(),\n t.completedAt?.toISOString() || '',\n ]);\n console.log(headers.join(','));\n rows.forEach((r) => console.log(r.join(',')));\n } else {\n console.log(JSON.stringify(state, null, 2));\n }\n\n service.close();\n return;\n }\n\n // Launch dashboard server\n console.log(\n `\uD83D\uDE80 Launching analytics dashboard on port ${options.port}...`\n );\n\n const express = (await import('express')).default;\n const { AnalyticsAPI } = await import('../features/analytics/index.js');\n const { createServer } = await import('http');\n\n const app = express();\n\n // Add error handling middleware\n app.use(\n (\n err: Error,\n _req: import('express').Request,\n res: import('express').Response,\n _next: import('express').NextFunction\n ) => {\n console.error('Express error:', err);\n res.status(500).json({ error: err.message });\n }\n );\n\n const analyticsAPI = new AnalyticsAPI(projectRoot);\n\n if (options.sync) {\n console.log('\uD83D\uDD04 Syncing with Linear...');\n const service = new (\n await import('../features/analytics/index.js')\n ).AnalyticsService(projectRoot);\n await service.syncLinearTasks();\n service.close();\n }\n\n app.use('/api/analytics', analyticsAPI.getRouter());\n\n // Serve the HTML dashboard\n app.get('/', async (req, res) => {\n // Try multiple paths for the dashboard HTML\n const possiblePaths = [\n join(projectRoot, 'src/features/analytics/dashboard.html'),\n join(projectRoot, 'dist/features/analytics/dashboard.html'),\n ];\n\n for (const dashboardPath of possiblePaths) {\n if (existsSync(dashboardPath)) {\n res.sendFile(dashboardPath);\n return;\n }\n }\n\n // Inline fallback dashboard\n res.send(`<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <title>StackMemory Analytics</title>\n <script src=\"https://cdn.jsdelivr.net/npm/chart.js\"></script>\n <style>\n * { margin: 0; padding: 0; box-sizing: border-box; }\n body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: #1a1a2e; color: #eee; padding: 20px; }\n .container { max-width: 1200px; margin: 0 auto; }\n h1 { color: #667eea; margin-bottom: 20px; }\n .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; margin-bottom: 30px; }\n .card { background: #16213e; border-radius: 12px; padding: 20px; }\n .metric-value { font-size: 2.5em; font-weight: bold; color: #667eea; }\n .metric-label { color: #888; text-transform: uppercase; font-size: 0.8em; }\n .task-list { max-height: 400px; overflow-y: auto; }\n .task-item { padding: 10px; border-left: 3px solid #667eea; margin-bottom: 8px; background: #1a1a2e; }\n .task-item.completed { border-color: #22c55e; }\n .task-item.in_progress { border-color: #f59e0b; }\n .status { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.8em; margin-right: 8px; }\n .status.completed { background: #22c55e30; color: #22c55e; }\n .status.in_progress { background: #f59e0b30; color: #f59e0b; }\n .status.todo { background: #667eea30; color: #667eea; }\n </style>\n</head>\n<body>\n <div class=\"container\">\n <h1>\uD83D\uDCCA StackMemory Analytics</h1>\n <div class=\"grid\" id=\"metrics\"></div>\n <div class=\"card\"><h3>Recent Tasks</h3><div class=\"task-list\" id=\"tasks\">Loading...</div></div>\n </div>\n <script>\n async function load() {\n const metrics = await fetch('/api/analytics/metrics').then(r => r.json());\n const tasks = await fetch('/api/analytics/tasks').then(r => r.json());\n \n document.getElementById('metrics').innerHTML = \\`\n <div class=\"card\"><div class=\"metric-label\">Total</div><div class=\"metric-value\">\\${metrics.data.metrics.totalTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completed</div><div class=\"metric-value\">\\${metrics.data.metrics.completedTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">In Progress</div><div class=\"metric-value\">\\${metrics.data.metrics.inProgressTasks}</div></div>\n <div class=\"card\"><div class=\"metric-label\">Completion</div><div class=\"metric-value\">\\${metrics.data.metrics.completionRate.toFixed(0)}%</div></div>\n \\`;\n \n document.getElementById('tasks').innerHTML = tasks.data.tasks.slice(0, 10).map((t: any) => \\`\n <div class=\"task-item \\${t.state}\">\n <span class=\"status \\${t.state}\">\\${t.state}</span>\n <strong>\\${t.title}</strong>\n </div>\n \\`).join('');\n }\n load();\n setInterval(load, 30000);\n </script>\n</body>\n</html>`);\n });\n\n const server = createServer(app);\n analyticsAPI.setupWebSocket(server);\n\n server.listen(options.port, async () => {\n console.log(\n `\u2705 Analytics dashboard running at http://localhost:${options.port}`\n );\n\n if (options.open) {\n const { exec } = await import('child_process');\n const url = `http://localhost:${options.port}`;\n const command =\n process.platform === 'darwin'\n ? `open ${url}`\n : process.platform === 'win32'\n ? `start ${url}`\n : `xdg-open ${url}`;\n exec(command);\n }\n });\n\n process.on('SIGINT', () => {\n console.log('\\n\uD83D\uDC4B Shutting down analytics dashboard...');\n analyticsAPI.close();\n server.close();\n process.exit(0);\n });\n\n // Keep the process alive\n await new Promise(() => {});\n } catch (error: unknown) {\n logger.error('Analytics command failed', error as Error);\n console.error('\u274C Analytics 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\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);\nregisterProjectCommands(program);\nregisterWorktreeCommands(program);\n\n// Register Linear integration commands\nregisterLinearCommands(program);\nregisterLinearTestCommand(program);\nregisterLinearListCommand(program);\nregisterLinearMigrateCommand(program);\nregisterLinearCreateCommand(program);\n\n// Add ChromaDB command\nprogram.addCommand(createChromaDBCommand());\n\n// Add Infinite Storage command\nprogram.addCommand(createInfiniteStorageCommand());\nprogram.addCommand(createGCCommand());\n\n// Register session management commands\nprogram.addCommand(createSessionCommands());\n\n// Register webhook command\nprogram.addCommand(webhookCommand());\n\n// Register enhanced CLI commands\nprogram.addCommand(createTaskCommands());\nprogram.addCommand(createSearchCommand());\nprogram.addCommand(createLogCommand());\nprogram.addCommand(createContextCommands());\nprogram.addCommand(createConfigCommand());\nprogram.addCommand(createAgentCommand());\nprogram.addCommand(createHandoffCommand());\nprogram.addCommand(createStorageCommand());\nprogram.addCommand(createSkillsCommand());\nprogram.addCommand(createTestCommand());\nprogram.addCommand(clearCommand);\nprogram.addCommand(createWorkflowCommand());\nprogram.addCommand(monitorCommand);\nprogram.addCommand(qualityCommand);\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// Register TUI command (advanced terminal UI - requires blessed)\nprogram\n .command('tui')\n .description('Launch interactive TUI monitoring dashboard (requires blessed)')\n .option('-s, --server', 'Start WebSocket server for real-time updates')\n .option('-w, --ws-url <url>', 'WebSocket server URL', 'ws://localhost:8080')\n .option('-r, --refresh <ms>', 'Auto-refresh interval in milliseconds', '2000')\n .action(async (options) => {\n try {\n // Check if blessed is installed by trying to import it\n try {\n await import('blessed');\n } catch {\n console.log(\n '\u274C The TUI requires the blessed package. Install it with:'\n );\n console.log(' npm install blessed blessed-contrib');\n console.log(\n '\\n\uD83D\uDCA1 Alternatively, use \"stackmemory dashboard\" for a simpler view'\n );\n process.exit(1);\n }\n\n const { spawn } = await import('child_process');\n const { fileURLToPath } = await import('url');\n const { dirname, join } = await import('path');\n\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n\n console.log('\uD83D\uDE80 Launching StackMemory TUI Dashboard...');\n\n // Set environment variables\n process.env['STACKMEMORY_WS_URL'] = options.wsUrl;\n\n // Get TUI module path\n const tuiPath = join(__dirname, '../features/tui/index.js');\n\n // Launch TUI directly\n const tui = spawn('node', [tuiPath], {\n stdio: 'inherit',\n env: {\n ...process.env,\n STACKMEMORY_WS_URL: options.wsUrl,\n },\n });\n\n tui.on('error', (error) => {\n console.error('Failed to launch TUI:', error);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" instead');\n process.exit(1);\n });\n\n tui.on('exit', (code) => {\n if (code !== 0) {\n console.error(`TUI exited with code ${code}`);\n process.exit(code || 1);\n }\n });\n } catch (error: unknown) {\n console.error('\u274C Failed to launch TUI:', (error as Error).message);\n console.log('\\n\uD83D\uDCA1 Try \"stackmemory dashboard\" for a simpler view');\n process.exit(1);\n }\n });\n\n// Auto-detect current project on startup\nif (process.argv.length > 2) {\n const manager = ProjectManager.getInstance();\n manager.detectProject().catch(() => {\n // Silently fail if not in a project directory\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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",
6
6
  "names": ["LinearSyncEngine", "DEFAULT_SYNC_CONFIG", "join"]
7
7
  }
@@ -6,6 +6,7 @@ import {
6
6
  PRESET_PROFILES
7
7
  } from "./types.js";
8
8
  class ConfigManager {
9
+ static instance = null;
9
10
  config;
10
11
  configPath;
11
12
  fileWatcher;
@@ -14,6 +15,15 @@ class ConfigManager {
14
15
  this.configPath = configPath || path.join(process.cwd(), ".stackmemory", "config.yaml");
15
16
  this.config = this.loadConfig();
16
17
  }
18
+ /**
19
+ * Get singleton instance of ConfigManager
20
+ */
21
+ static getInstance(configPath) {
22
+ if (!ConfigManager.instance) {
23
+ ConfigManager.instance = new ConfigManager(configPath);
24
+ }
25
+ return ConfigManager.instance;
26
+ }
17
27
  /**
18
28
  * Load configuration from file or use defaults
19
29
  */
@@ -248,6 +258,22 @@ class ConfigManager {
248
258
  getConfig() {
249
259
  return { ...this.config };
250
260
  }
261
+ /**
262
+ * Get a specific configuration value by path
263
+ * Example: config.get('project.id') returns config.project.id
264
+ */
265
+ get(path2) {
266
+ const keys = path2.split(".");
267
+ let value = this.config;
268
+ for (const key of keys) {
269
+ if (value && typeof value === "object" && key in value) {
270
+ value = value[key];
271
+ } else {
272
+ return void 0;
273
+ }
274
+ }
275
+ return value;
276
+ }
251
277
  /**
252
278
  * Set active profile
253
279
  */