@stackmemoryai/stackmemory 0.3.9 → 0.3.11

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 (86) hide show
  1. package/README.md +54 -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/browser-test.js +4 -4
  7. package/dist/cli/browser-test.js.map +2 -2
  8. package/dist/cli/claude-sm.js +2 -2
  9. package/dist/cli/claude-sm.js.map +2 -2
  10. package/dist/cli/codex-sm.js +5 -5
  11. package/dist/cli/codex-sm.js.map +2 -2
  12. package/dist/cli/commands/agent.js +3 -3
  13. package/dist/cli/commands/agent.js.map +2 -2
  14. package/dist/cli/commands/handoff.js +67 -20
  15. package/dist/cli/commands/handoff.js.map +3 -3
  16. package/dist/cli/commands/linear-unified.js +3 -3
  17. package/dist/cli/commands/linear-unified.js.map +2 -2
  18. package/dist/cli/commands/linear.js +2 -2
  19. package/dist/cli/commands/linear.js.map +2 -2
  20. package/dist/cli/commands/onboard.js +3 -3
  21. package/dist/cli/commands/onboard.js.map +2 -2
  22. package/dist/cli/commands/quality.js +2 -2
  23. package/dist/cli/commands/quality.js.map +2 -2
  24. package/dist/cli/commands/skills.js +113 -28
  25. package/dist/cli/commands/skills.js.map +2 -2
  26. package/dist/cli/commands/tasks.js +3 -3
  27. package/dist/cli/commands/tasks.js.map +2 -2
  28. package/dist/cli/commands/test.js +282 -0
  29. package/dist/cli/commands/test.js.map +7 -0
  30. package/dist/cli/commands/worktree.js +28 -10
  31. package/dist/cli/commands/worktree.js.map +2 -2
  32. package/dist/cli/index.js +5 -3
  33. package/dist/cli/index.js.map +2 -2
  34. package/dist/cli/utils/viewer.js +9 -9
  35. package/dist/cli/utils/viewer.js.map +2 -2
  36. package/dist/core/config/config-manager.js +26 -0
  37. package/dist/core/config/config-manager.js.map +3 -3
  38. package/dist/core/context/frame-handoff-manager.js +4 -4
  39. package/dist/core/context/frame-handoff-manager.js.map +1 -1
  40. package/dist/core/context/frame-manager.js +139 -0
  41. package/dist/core/context/frame-manager.js.map +2 -2
  42. package/dist/core/context/refactored-frame-manager.js +180 -1
  43. package/dist/core/context/refactored-frame-manager.js.map +2 -2
  44. package/dist/core/projects/project-isolation.js +197 -0
  45. package/dist/core/projects/project-isolation.js.map +7 -0
  46. package/dist/core/trace/debug-trace.js +1 -1
  47. package/dist/core/trace/debug-trace.js.map +2 -2
  48. package/dist/core/trace/index.js +4 -4
  49. package/dist/core/trace/index.js.map +2 -2
  50. package/dist/core/trace/trace-demo.js +8 -8
  51. package/dist/core/trace/trace-demo.js.map +2 -2
  52. package/dist/core/trace/trace-detector.demo.js +5 -5
  53. package/dist/core/trace/trace-detector.demo.js.map +2 -2
  54. package/dist/core/utils/update-checker.js +2 -2
  55. package/dist/core/utils/update-checker.js.map +2 -2
  56. package/dist/features/analytics/core/analytics-service.js +2 -2
  57. package/dist/features/analytics/core/analytics-service.js.map +2 -2
  58. package/dist/features/tasks/linear-task-manager.js +483 -0
  59. package/dist/features/tasks/linear-task-manager.js.map +7 -0
  60. package/dist/integrations/claude-code/subagent-client-stub.js +16 -0
  61. package/dist/integrations/claude-code/subagent-client-stub.js.map +7 -0
  62. package/dist/integrations/linear/auto-sync.js +2 -2
  63. package/dist/integrations/linear/auto-sync.js.map +2 -2
  64. package/dist/integrations/linear/config.js +12 -1
  65. package/dist/integrations/linear/config.js.map +2 -2
  66. package/dist/integrations/linear/sync-manager.js.map +1 -1
  67. package/dist/integrations/linear/sync.js.map +1 -1
  68. package/dist/integrations/linear/unified-sync.js.map +1 -1
  69. package/dist/integrations/linear/webhook-handler.js.map +2 -2
  70. package/dist/integrations/linear/webhook.js.map +2 -2
  71. package/dist/integrations/mcp/handlers/linear-handlers.js.map +1 -1
  72. package/dist/integrations/mcp/handlers/task-handlers.js.map +1 -1
  73. package/dist/integrations/mcp/refactored-server.js +2 -2
  74. package/dist/integrations/mcp/refactored-server.js.map +2 -2
  75. package/dist/integrations/mcp/server.js +3 -3
  76. package/dist/integrations/mcp/server.js.map +2 -2
  77. package/dist/mcp/stackmemory-mcp-server.js +3 -3
  78. package/dist/mcp/stackmemory-mcp-server.js.map +2 -2
  79. package/dist/skills/claude-skills.js +99 -5
  80. package/dist/skills/claude-skills.js.map +2 -2
  81. package/dist/skills/recursive-agent-orchestrator.js.map +1 -1
  82. package/dist/skills/security-secrets-scanner.js +21 -6
  83. package/dist/skills/security-secrets-scanner.js.map +2 -2
  84. package/dist/skills/unified-rlm-orchestrator.js +400 -0
  85. package/dist/skills/unified-rlm-orchestrator.js.map +7 -0
  86. package/package.json +4 -5
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/onboard.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory Onboarding CLI\n * Interactive setup for new StackMemory installations\n */\n\nimport { Command } from 'commander';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { existsSync, mkdirSync, writeFileSync } from 'fs';\nimport { execSync } from 'child_process';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { logger } from '../../core/monitoring/logger.js';\n\ninterface OnboardingConfig {\n setupType: 'basic' | 'advanced';\n enableWorktrees: boolean;\n worktreeIsolation: boolean;\n enableProjects: boolean;\n scanProjects: boolean;\n enableLinear: boolean;\n linearApiKey?: string;\n enableAnalytics: boolean;\n defaultContextPath: string;\n}\n\nexport function registerOnboardingCommand(program: Command): void {\n program\n .command('onboard')\n .alias('setup')\n .description('Interactive setup for StackMemory')\n .option('--reset', 'Reset all configurations and start fresh')\n .action(async (options) => {\n console.log(chalk.cyan('\\n\uD83D\uDE80 Welcome to StackMemory Setup!\\n'));\n\n // Check if already configured\n const configPath = join(homedir(), '.stackmemory');\n if (existsSync(configPath) && !options.reset) {\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message:\n 'StackMemory is already configured. Do you want to reconfigure?',\n default: false,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.yellow('\\nSetup cancelled.'));\n return;\n }\n }\n\n try {\n const config = await runOnboarding();\n await applyConfiguration(config);\n\n console.log(\n chalk.green('\\n\u2705 StackMemory setup completed successfully!\\n')\n );\n showNextSteps(config);\n } catch (error: unknown) {\n logger.error('Onboarding failed', error as Error);\n console.error(\n chalk.red('\\n\u274C Setup failed:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n}\n\nasync function runOnboarding(): Promise<OnboardingConfig> {\n // Basic or Advanced Setup\n const { setupType } = await inquirer.prompt([\n {\n type: 'list',\n name: 'setupType',\n message: 'Choose your setup type:',\n choices: [\n { name: 'Basic (Recommended for most users)', value: 'basic' },\n { name: 'Advanced (Full customization)', value: 'advanced' },\n ],\n default: 'basic',\n },\n ]);\n\n let config: OnboardingConfig = {\n setupType,\n enableWorktrees: false,\n worktreeIsolation: true,\n enableProjects: true,\n scanProjects: false,\n enableLinear: false,\n enableAnalytics: true,\n defaultContextPath: join(homedir(), '.stackmemory'),\n };\n\n if (setupType === 'basic') {\n // Basic setup with sensible defaults\n const basicAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message:\n 'Enable Git worktree support? (Recommended for multi-branch workflows)',\n default: false,\n },\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan and organize your existing projects?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Connect to Linear for task management?',\n default: false,\n },\n ]);\n\n config = { ...config, ...basicAnswers };\n\n if (basicAnswers.enableLinear) {\n const { linearApiKey } = await inquirer.prompt([\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Enter your Linear API key:',\n validate: (input: string) =>\n input.length > 0 || 'API key is required',\n },\n ]);\n config.linearApiKey = linearApiKey;\n }\n } else {\n // Advanced setup with all options\n const advancedAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message: 'Enable Git worktree support?',\n default: false,\n },\n ]);\n\n if (advancedAnswers.enableWorktrees) {\n const worktreeAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'worktreeIsolation',\n message: 'Isolate contexts between worktrees? (Recommended)',\n default: true,\n },\n {\n type: 'confirm',\n name: 'autoDetect',\n message: 'Auto-detect worktrees when switching directories?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'shareGlobal',\n message: 'Share global context across worktrees?',\n default: false,\n },\n {\n type: 'number',\n name: 'syncInterval',\n message: 'Context sync interval in minutes (0 to disable):',\n default: 15,\n validate: (input: number) => input >= 0 || 'Must be 0 or positive',\n },\n ]);\n\n config = { ...config, ...advancedAnswers, ...worktreeAnswers };\n }\n\n const projectAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableProjects',\n message: 'Enable automatic project management?',\n default: true,\n },\n ]);\n\n if (projectAnswers.enableProjects) {\n const projectDetailAnswers: any = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan for existing projects now?',\n default: true,\n },\n {\n type: 'checkbox',\n name: 'scanPaths',\n message: 'Select directories to scan:',\n choices: [\n { name: '~/Dev', value: join(homedir(), 'Dev'), checked: true },\n { name: '~/dev', value: join(homedir(), 'dev'), checked: true },\n {\n name: '~/Projects',\n value: join(homedir(), 'Projects'),\n checked: true,\n },\n {\n name: '~/projects',\n value: join(homedir(), 'projects'),\n checked: true,\n },\n { name: '~/Work', value: join(homedir(), 'Work'), checked: false },\n { name: '~/code', value: join(homedir(), 'code'), checked: true },\n {\n name: '~/Documents/GitHub',\n value: join(homedir(), 'Documents/GitHub'),\n checked: false,\n },\n ],\n when: (): boolean => projectDetailAnswers.scanProjects,\n },\n ]);\n\n config = { ...config, ...projectAnswers, ...projectDetailAnswers };\n }\n\n const integrationAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Enable Linear integration?',\n default: false,\n },\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Linear API key:',\n when: (answers: any) => answers.enableLinear,\n validate: (input: string) => input.length > 0 || 'API key is required',\n },\n {\n type: 'confirm',\n name: 'enableAnalytics',\n message: 'Enable usage analytics? (Local only)',\n default: true,\n },\n {\n type: 'input',\n name: 'defaultContextPath',\n message: 'Default context storage path:',\n default: join(homedir(), '.stackmemory'),\n validate: (input: string) => input.length > 0 || 'Path is required',\n },\n ]);\n\n config = { ...config, ...integrationAnswers };\n }\n\n return config;\n}\n\nasync function applyConfiguration(config: OnboardingConfig): Promise<void> {\n const configPath = join(homedir(), '.stackmemory');\n\n // Create base directory structure\n console.log(chalk.gray('\\nCreating directory structure...'));\n const dirs = [\n configPath,\n join(configPath, 'contexts'),\n join(configPath, 'projects'),\n join(configPath, 'worktrees'),\n join(configPath, 'bin'),\n join(configPath, 'logs'),\n join(configPath, 'analytics'),\n ];\n\n for (const dir of dirs) {\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n\n // Configure git worktree support\n if (config.enableWorktrees) {\n console.log(chalk.gray('Configuring worktree support...'));\n const worktreeManager = WorktreeManager.getInstance();\n worktreeManager.saveConfig({\n enabled: true,\n autoDetect: true,\n isolateContexts: config.worktreeIsolation,\n shareGlobalContext: false,\n syncInterval: 15,\n });\n\n // Detect current worktrees\n const worktrees = worktreeManager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.green(` \u2713 Found ${worktrees.length} worktree(s)`));\n worktrees.forEach((wt) => {\n console.log(chalk.gray(` - ${wt.branch} at ${wt.path}`));\n });\n }\n }\n\n // Scan and organize projects\n if (config.enableProjects && config.scanProjects) {\n console.log(chalk.gray('Scanning for projects...'));\n const projectManager = ProjectManager.getInstance();\n\n const scanPaths = (config as any).scanPaths || [\n join(homedir(), 'Dev'),\n join(homedir(), 'dev'),\n join(homedir(), 'Projects'),\n join(homedir(), 'projects'),\n join(homedir(), 'code'),\n ];\n\n await projectManager.scanAndCategorizeAllProjects(\n scanPaths.filter((p: string) => existsSync(p))\n );\n\n const projects = projectManager.getAllProjects();\n console.log(chalk.green(` \u2713 Found ${projects.length} project(s)`));\n\n // Show summary\n const byType: Record<string, number> = {};\n projects.forEach((p) => {\n byType[p.accountType] = (byType[p.accountType] || 0) + 1;\n });\n\n Object.entries(byType).forEach(([type, count]) => {\n console.log(chalk.gray(` - ${type}: ${count} project(s)`));\n });\n }\n\n // Configure Linear integration\n if (config.enableLinear && config.linearApiKey) {\n console.log(chalk.gray('Configuring Linear integration...'));\n const linearConfig = {\n apiKey: config.linearApiKey,\n autoSync: true,\n syncInterval: 300000, // 5 minutes\n };\n\n writeFileSync(\n join(configPath, 'linear-config.json'),\n JSON.stringify(linearConfig, null, 2)\n );\n console.log(chalk.green(' \u2713 Linear configured'));\n }\n\n // Save main configuration\n const mainConfig = {\n version: '1.0.0',\n setupCompleted: new Date().toISOString(),\n features: {\n worktrees: config.enableWorktrees,\n projects: config.enableProjects,\n linear: config.enableLinear,\n analytics: config.enableAnalytics,\n },\n paths: {\n default: config.defaultContextPath,\n },\n };\n\n writeFileSync(\n join(configPath, 'config.json'),\n JSON.stringify(mainConfig, null, 2)\n );\n\n // Create claude-sm symlink for easy access\n const binPath = '/usr/local/bin/claude-sm';\n const sourcePath = join(configPath, 'bin', 'stackmemory');\n\n try {\n // Create wrapper script\n const wrapperScript = `#!/bin/bash\n# StackMemory CLI wrapper with worktree support\nCURRENT_DIR=$(pwd)\n\n# Auto-detect worktree if enabled\nif [ -f ~/.stackmemory/worktree-config.json ]; then\n WORKTREE_ENABLED=$(grep '\"enabled\": true' ~/.stackmemory/worktree-config.json)\n if [ ! -z \"$WORKTREE_ENABLED\" ]; then\n # Check if we're in a git worktree\n if git worktree list &>/dev/null; then\n export SM_WORKTREE_PATH=\"$CURRENT_DIR\"\n fi\n fi\nfi\n\n# Run StackMemory with context\nexec stackmemory \"$@\"\n`;\n\n writeFileSync(sourcePath, wrapperScript);\n execSync(`chmod +x ${sourcePath}`);\n\n // Create symlink if it doesn't exist\n if (!existsSync(binPath)) {\n execSync(`ln -s ${sourcePath} ${binPath}`);\n console.log(chalk.green(' \u2713 Created claude-sm command'));\n }\n } catch (error: unknown) {\n console.log(\n chalk.yellow(' \u26A0 Could not create claude-sm symlink (may need sudo)')\n );\n }\n}\n\nfunction showNextSteps(config: OnboardingConfig): void {\n console.log(chalk.cyan('\uD83C\uDF89 Next Steps:\\n'));\n\n console.log('1. Initialize StackMemory in your project:');\n console.log(chalk.gray(' cd your-project'));\n console.log(chalk.gray(' stackmemory init\\n'));\n\n if (config.enableWorktrees) {\n console.log('2. Create a new worktree:');\n console.log(\n chalk.gray(\n ' git worktree add -b feature/new-feature ../project-feature'\n )\n );\n console.log(chalk.gray(' cd ../project-feature'));\n console.log(\n chalk.gray(\n ' stackmemory status # Isolated context for this worktree\\n'\n )\n );\n }\n\n console.log('3. Use with Claude:');\n console.log(chalk.gray(' claude-sm # Or use stackmemory directly\\n'));\n\n if (config.enableLinear) {\n console.log('4. Sync with Linear:');\n console.log(chalk.gray(' stackmemory linear sync\\n'));\n }\n\n console.log('For more help:');\n console.log(chalk.gray(' stackmemory --help'));\n console.log(chalk.gray(' stackmemory projects --help'));\n if (config.enableWorktrees) {\n console.log(chalk.gray(' stackmemory worktree --help'));\n }\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n/**\n * StackMemory Onboarding CLI\n * Interactive setup for new StackMemory installations\n */\n\nimport { Command } from 'commander';\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { existsSync, mkdirSync, writeFileSync } from 'fs';\nimport { execSync, execFileSync } from 'child_process';\nimport { WorktreeManager } from '../../core/worktree/worktree-manager.js';\nimport { ProjectManager } from '../../core/projects/project-manager.js';\nimport { logger } from '../../core/monitoring/logger.js';\n\ninterface OnboardingConfig {\n setupType: 'basic' | 'advanced';\n enableWorktrees: boolean;\n worktreeIsolation: boolean;\n enableProjects: boolean;\n scanProjects: boolean;\n enableLinear: boolean;\n linearApiKey?: string;\n enableAnalytics: boolean;\n defaultContextPath: string;\n}\n\nexport function registerOnboardingCommand(program: Command): void {\n program\n .command('onboard')\n .alias('setup')\n .description('Interactive setup for StackMemory')\n .option('--reset', 'Reset all configurations and start fresh')\n .action(async (options) => {\n console.log(chalk.cyan('\\n\uD83D\uDE80 Welcome to StackMemory Setup!\\n'));\n\n // Check if already configured\n const configPath = join(homedir(), '.stackmemory');\n if (existsSync(configPath) && !options.reset) {\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message:\n 'StackMemory is already configured. Do you want to reconfigure?',\n default: false,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.yellow('\\nSetup cancelled.'));\n return;\n }\n }\n\n try {\n const config = await runOnboarding();\n await applyConfiguration(config);\n\n console.log(\n chalk.green('\\n\u2705 StackMemory setup completed successfully!\\n')\n );\n showNextSteps(config);\n } catch (error: unknown) {\n logger.error('Onboarding failed', error as Error);\n console.error(\n chalk.red('\\n\u274C Setup failed:'),\n (error as Error).message\n );\n process.exit(1);\n }\n });\n}\n\nasync function runOnboarding(): Promise<OnboardingConfig> {\n // Basic or Advanced Setup\n const { setupType } = await inquirer.prompt([\n {\n type: 'list',\n name: 'setupType',\n message: 'Choose your setup type:',\n choices: [\n { name: 'Basic (Recommended for most users)', value: 'basic' },\n { name: 'Advanced (Full customization)', value: 'advanced' },\n ],\n default: 'basic',\n },\n ]);\n\n let config: OnboardingConfig = {\n setupType,\n enableWorktrees: false,\n worktreeIsolation: true,\n enableProjects: true,\n scanProjects: false,\n enableLinear: false,\n enableAnalytics: true,\n defaultContextPath: join(homedir(), '.stackmemory'),\n };\n\n if (setupType === 'basic') {\n // Basic setup with sensible defaults\n const basicAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message:\n 'Enable Git worktree support? (Recommended for multi-branch workflows)',\n default: false,\n },\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan and organize your existing projects?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Connect to Linear for task management?',\n default: false,\n },\n ]);\n\n config = { ...config, ...basicAnswers };\n\n if (basicAnswers.enableLinear) {\n const { linearApiKey } = await inquirer.prompt([\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Enter your Linear API key:',\n validate: (input: string) =>\n input.length > 0 || 'API key is required',\n },\n ]);\n config.linearApiKey = linearApiKey;\n }\n } else {\n // Advanced setup with all options\n const advancedAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableWorktrees',\n message: 'Enable Git worktree support?',\n default: false,\n },\n ]);\n\n if (advancedAnswers.enableWorktrees) {\n const worktreeAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'worktreeIsolation',\n message: 'Isolate contexts between worktrees? (Recommended)',\n default: true,\n },\n {\n type: 'confirm',\n name: 'autoDetect',\n message: 'Auto-detect worktrees when switching directories?',\n default: true,\n },\n {\n type: 'confirm',\n name: 'shareGlobal',\n message: 'Share global context across worktrees?',\n default: false,\n },\n {\n type: 'number',\n name: 'syncInterval',\n message: 'Context sync interval in minutes (0 to disable):',\n default: 15,\n validate: (input: number) => input >= 0 || 'Must be 0 or positive',\n },\n ]);\n\n config = { ...config, ...advancedAnswers, ...worktreeAnswers };\n }\n\n const projectAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableProjects',\n message: 'Enable automatic project management?',\n default: true,\n },\n ]);\n\n if (projectAnswers.enableProjects) {\n const projectDetailAnswers: any = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'scanProjects',\n message: 'Scan for existing projects now?',\n default: true,\n },\n {\n type: 'checkbox',\n name: 'scanPaths',\n message: 'Select directories to scan:',\n choices: [\n { name: '~/Dev', value: join(homedir(), 'Dev'), checked: true },\n { name: '~/dev', value: join(homedir(), 'dev'), checked: true },\n {\n name: '~/Projects',\n value: join(homedir(), 'Projects'),\n checked: true,\n },\n {\n name: '~/projects',\n value: join(homedir(), 'projects'),\n checked: true,\n },\n { name: '~/Work', value: join(homedir(), 'Work'), checked: false },\n { name: '~/code', value: join(homedir(), 'code'), checked: true },\n {\n name: '~/Documents/GitHub',\n value: join(homedir(), 'Documents/GitHub'),\n checked: false,\n },\n ],\n when: (): boolean => projectDetailAnswers.scanProjects,\n },\n ]);\n\n config = { ...config, ...projectAnswers, ...projectDetailAnswers };\n }\n\n const integrationAnswers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enableLinear',\n message: 'Enable Linear integration?',\n default: false,\n },\n {\n type: 'password',\n name: 'linearApiKey',\n message: 'Linear API key:',\n when: (answers: any) => answers.enableLinear,\n validate: (input: string) => input.length > 0 || 'API key is required',\n },\n {\n type: 'confirm',\n name: 'enableAnalytics',\n message: 'Enable usage analytics? (Local only)',\n default: true,\n },\n {\n type: 'input',\n name: 'defaultContextPath',\n message: 'Default context storage path:',\n default: join(homedir(), '.stackmemory'),\n validate: (input: string) => input.length > 0 || 'Path is required',\n },\n ]);\n\n config = { ...config, ...integrationAnswers };\n }\n\n return config;\n}\n\nasync function applyConfiguration(config: OnboardingConfig): Promise<void> {\n const configPath = join(homedir(), '.stackmemory');\n\n // Create base directory structure\n console.log(chalk.gray('\\nCreating directory structure...'));\n const dirs = [\n configPath,\n join(configPath, 'contexts'),\n join(configPath, 'projects'),\n join(configPath, 'worktrees'),\n join(configPath, 'bin'),\n join(configPath, 'logs'),\n join(configPath, 'analytics'),\n ];\n\n for (const dir of dirs) {\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n\n // Configure git worktree support\n if (config.enableWorktrees) {\n console.log(chalk.gray('Configuring worktree support...'));\n const worktreeManager = WorktreeManager.getInstance();\n worktreeManager.saveConfig({\n enabled: true,\n autoDetect: true,\n isolateContexts: config.worktreeIsolation,\n shareGlobalContext: false,\n syncInterval: 15,\n });\n\n // Detect current worktrees\n const worktrees = worktreeManager.detectWorktrees();\n if (worktrees.length > 0) {\n console.log(chalk.green(` \u2713 Found ${worktrees.length} worktree(s)`));\n worktrees.forEach((wt) => {\n console.log(chalk.gray(` - ${wt.branch} at ${wt.path}`));\n });\n }\n }\n\n // Scan and organize projects\n if (config.enableProjects && config.scanProjects) {\n console.log(chalk.gray('Scanning for projects...'));\n const projectManager = ProjectManager.getInstance();\n\n const scanPaths = (config as any).scanPaths || [\n join(homedir(), 'Dev'),\n join(homedir(), 'dev'),\n join(homedir(), 'Projects'),\n join(homedir(), 'projects'),\n join(homedir(), 'code'),\n ];\n\n await projectManager.scanAndCategorizeAllProjects(\n scanPaths.filter((p: string) => existsSync(p))\n );\n\n const projects = projectManager.getAllProjects();\n console.log(chalk.green(` \u2713 Found ${projects.length} project(s)`));\n\n // Show summary\n const byType: Record<string, number> = {};\n projects.forEach((p) => {\n byType[p.accountType] = (byType[p.accountType] || 0) + 1;\n });\n\n Object.entries(byType).forEach(([type, count]) => {\n console.log(chalk.gray(` - ${type}: ${count} project(s)`));\n });\n }\n\n // Configure Linear integration\n if (config.enableLinear && config.linearApiKey) {\n console.log(chalk.gray('Configuring Linear integration...'));\n const linearConfig = {\n apiKey: config.linearApiKey,\n autoSync: true,\n syncInterval: 300000, // 5 minutes\n };\n\n writeFileSync(\n join(configPath, 'linear-config.json'),\n JSON.stringify(linearConfig, null, 2)\n );\n console.log(chalk.green(' \u2713 Linear configured'));\n }\n\n // Save main configuration\n const mainConfig = {\n version: '1.0.0',\n setupCompleted: new Date().toISOString(),\n features: {\n worktrees: config.enableWorktrees,\n projects: config.enableProjects,\n linear: config.enableLinear,\n analytics: config.enableAnalytics,\n },\n paths: {\n default: config.defaultContextPath,\n },\n };\n\n writeFileSync(\n join(configPath, 'config.json'),\n JSON.stringify(mainConfig, null, 2)\n );\n\n // Create claude-sm symlink for easy access\n const binPath = '/usr/local/bin/claude-sm';\n const sourcePath = join(configPath, 'bin', 'stackmemory');\n\n try {\n // Create wrapper script\n const wrapperScript = `#!/bin/bash\n# StackMemory CLI wrapper with worktree support\nCURRENT_DIR=$(pwd)\n\n# Auto-detect worktree if enabled\nif [ -f ~/.stackmemory/worktree-config.json ]; then\n WORKTREE_ENABLED=$(grep '\"enabled\": true' ~/.stackmemory/worktree-config.json)\n if [ ! -z \"$WORKTREE_ENABLED\" ]; then\n # Check if we're in a git worktree\n if git worktree list &>/dev/null; then\n export SM_WORKTREE_PATH=\"$CURRENT_DIR\"\n fi\n fi\nfi\n\n# Run StackMemory with context\nexec stackmemory \"$@\"\n`;\n\n writeFileSync(sourcePath, wrapperScript);\n execFileSync('chmod', ['+x', sourcePath]);\n\n // Create symlink if it doesn't exist\n if (!existsSync(binPath)) {\n execFileSync('ln', ['-s', sourcePath, binPath]);\n console.log(chalk.green(' \u2713 Created claude-sm command'));\n }\n } catch (error: unknown) {\n console.log(\n chalk.yellow(' \u26A0 Could not create claude-sm symlink (may need sudo)')\n );\n }\n}\n\nfunction showNextSteps(config: OnboardingConfig): void {\n console.log(chalk.cyan('\uD83C\uDF89 Next Steps:\\n'));\n\n console.log('1. Initialize StackMemory in your project:');\n console.log(chalk.gray(' cd your-project'));\n console.log(chalk.gray(' stackmemory init\\n'));\n\n if (config.enableWorktrees) {\n console.log('2. Create a new worktree:');\n console.log(\n chalk.gray(\n ' git worktree add -b feature/new-feature ../project-feature'\n )\n );\n console.log(chalk.gray(' cd ../project-feature'));\n console.log(\n chalk.gray(\n ' stackmemory status # Isolated context for this worktree\\n'\n )\n );\n }\n\n console.log('3. Use with Claude:');\n console.log(chalk.gray(' claude-sm # Or use stackmemory directly\\n'));\n\n if (config.enableLinear) {\n console.log('4. Sync with Linear:');\n console.log(chalk.gray(' stackmemory linear sync\\n'));\n }\n\n console.log('For more help:');\n console.log(chalk.gray(' stackmemory --help'));\n console.log(chalk.gray(' stackmemory projects --help'));\n if (config.enableWorktrees) {\n console.log(chalk.gray(' stackmemory worktree --help'));\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -383,8 +383,8 @@ async function getRecentQualityResults(frameManager) {
383
383
  }
384
384
  async function getRecentlyModifiedFiles(projectRoot) {
385
385
  try {
386
- const { execSync } = await import("child_process");
387
- const output = execSync("git diff --name-only HEAD~1", {
386
+ const { execFileSync } = await import("child_process");
387
+ const output = execFileSync("git", ["diff", "--name-only", "HEAD~1"], {
388
388
  cwd: projectRoot,
389
389
  encoding: "utf-8"
390
390
  });
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/commands/quality.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n\n/**\n * Quality command for StackMemory\n * Manages post-task quality gates and code review automation\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport inquirer from 'inquirer';\nimport {\n PostTaskHooks,\n PostTaskConfig,\n QualityGateResult,\n} from '../../integrations/claude-code/post-task-hooks.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\n\nexport function createQualityCommand(): Command {\n const cmd = new Command('quality')\n .description('Manage post-task quality gates and automation')\n .option('--enable', 'Enable quality gates')\n .option('--disable', 'Disable quality gates')\n .option('--status', 'Show quality gate status')\n .option('--config', 'Configure quality gates')\n .option('--run', 'Run quality gates manually')\n .option('--history', 'Show quality gate history')\n .option('--setup', 'Interactive setup wizard')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db);\n\n if (options.enable) {\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.disable) {\n await disableQualityGates(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot, frameManager, db);\n } else if (options.config) {\n await configureQualityGates(projectRoot);\n } else if (options.run) {\n await runQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.history) {\n await showHistory(frameManager);\n } else if (options.setup) {\n await setupWizard(projectRoot, frameManager, db);\n } else {\n // Default: show status\n await showStatus(projectRoot, frameManager, db);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Enable quality gates\n */\nasync function enableQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Enabling quality gates...');\n\n try {\n // Load or create config\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: true,\n runCodeReview: true,\n runLinter: true,\n };\n\n // Initialize hooks\n const hooks = new PostTaskHooks(frameManager, db, config);\n await hooks.initialize();\n\n // Save config\n await saveConfig(projectRoot, config);\n\n // Create systemd-style service file for persistence\n await createServiceFile(projectRoot);\n\n spinner.succeed(chalk.green('\u2705 Quality gates enabled'));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Quality Gates Active:'));\n console.log(' \u2022 Auto-run tests after code changes');\n console.log(' \u2022 Auto-run linter on file saves');\n console.log(' \u2022 Auto-trigger code review on task completion');\n console.log(' \u2022 Real-time file change monitoring');\n\n console.log(chalk.gray('\\nDisable with: stackmemory quality --disable'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to enable quality gates: ${error}`));\n }\n}\n\n/**\n * Disable quality gates\n */\nasync function disableQualityGates(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Disabling quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: false,\n runCodeReview: false,\n runLinter: false,\n };\n\n await saveConfig(projectRoot, config);\n\n // Remove service file\n const serviceFile = path.join(\n projectRoot,\n '.stackmemory',\n 'quality.service'\n );\n try {\n await fs.unlink(serviceFile);\n } catch {\n // Service file doesn't exist\n }\n\n spinner.succeed(chalk.green('\u2705 Quality gates disabled'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to disable quality gates: ${error}`));\n }\n}\n\n/**\n * Show quality gate status\n */\nasync function showStatus(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\\n\uD83D\uDCCA Quality Gates Status\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n // Overall status\n const isEnabled =\n config.qualityGates?.runTests ||\n config.qualityGates?.runCodeReview ||\n config.qualityGates?.runLinter;\n console.log(\n `Status: ${isEnabled ? chalk.green('\u2705 Enabled') : chalk.yellow('\u26A0\uFE0F Disabled')}`\n );\n\n // Individual gates\n console.log('\\nGates:');\n console.log(\n ` Tests: ${config.qualityGates?.runTests ? '\u2705' : '\u274C'} ${getTestCommand(config)}`\n );\n console.log(\n ` Linter: ${config.qualityGates?.runLinter ? '\u2705' : '\u274C'} ${getLintCommand(config)}`\n );\n console.log(\n ` Code Review: ${config.qualityGates?.runCodeReview ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Coverage: ${config.qualityGates?.requireTestCoverage ? '\u2705' : '\u274C'}`\n );\n\n // Detected frameworks\n if (config.testFrameworks?.detected.length) {\n console.log('\\nDetected Frameworks:');\n config.testFrameworks.detected.forEach((fw) => {\n console.log(` \u2022 ${fw}`);\n });\n }\n\n // Recent quality results\n const recentResults = await getRecentQualityResults(frameManager);\n if (recentResults.length > 0) {\n console.log('\\nRecent Results:');\n recentResults.slice(0, 3).forEach((result) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n console.log(\n ` ${icon} ${result.frameName} (${new Date(result.timestamp).toLocaleString()})`\n );\n });\n }\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get status:', error));\n }\n}\n\n/**\n * Configure quality gates\n */\nasync function configureQualityGates(projectRoot: string) {\n console.log(chalk.bold('\\n\u2699\uFE0F Quality Gates Configuration\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'runTests',\n message: 'Auto-run tests after code changes?',\n default: config.qualityGates?.runTests ?? true,\n },\n {\n type: 'confirm',\n name: 'runLinter',\n message: 'Auto-run linter on file changes?',\n default: config.qualityGates?.runLinter ?? true,\n },\n {\n type: 'confirm',\n name: 'runCodeReview',\n message: 'Auto-trigger code review on task completion?',\n default: config.qualityGates?.runCodeReview ?? true,\n },\n {\n type: 'confirm',\n name: 'requireTestCoverage',\n message: 'Require test coverage checks?',\n default: config.qualityGates?.requireTestCoverage ?? false,\n },\n {\n type: 'confirm',\n name: 'blockOnFailure',\n message: 'Block further work when quality gates fail?',\n default: config.qualityGates?.blockOnFailure ?? false,\n },\n {\n type: 'input',\n name: 'testCommand',\n message: 'Custom test command (leave empty for auto-detect):',\n default: config.testFrameworks?.testCommand || '',\n },\n {\n type: 'input',\n name: 'lintCommand',\n message: 'Custom lint command (leave empty for auto-detect):',\n default: config.testFrameworks?.lintCommand || '',\n },\n ]);\n\n // Update config\n config.qualityGates = {\n runTests: answers.runTests,\n runLinter: answers.runLinter,\n runCodeReview: answers.runCodeReview,\n requireTestCoverage: answers.requireTestCoverage,\n blockOnFailure: answers.blockOnFailure,\n };\n\n config.testFrameworks = {\n ...config.testFrameworks,\n testCommand: answers.testCommand || config.testFrameworks?.testCommand,\n lintCommand: answers.lintCommand || config.testFrameworks?.lintCommand,\n };\n\n await saveConfig(projectRoot, config);\n\n console.log(chalk.green('\\n\u2705 Configuration saved'));\n console.log(chalk.gray('Enable with: stackmemory quality --enable'));\n } catch (error: unknown) {\n console.error(chalk.red('Configuration failed:', error));\n }\n}\n\n/**\n * Run quality gates manually\n */\nasync function runQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Running quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n const hooks = new PostTaskHooks(frameManager, db, config);\n\n // Simulate a task completion event\n const mockEvent = {\n taskType: 'task_complete' as const,\n frameId: 'manual-run',\n frameName: 'Manual quality gate run',\n files: await getRecentlyModifiedFiles(projectRoot),\n changes: { added: 0, removed: 0, modified: 1 },\n metadata: { trigger: 'manual' },\n };\n\n // Run quality gates\n const results = await (hooks as any).runQualityGates(mockEvent);\n\n spinner.succeed(chalk.green('\u2705 Quality gates completed'));\n\n // Show results\n console.log(chalk.bold('\\n\uD83D\uDCCB Quality Gate Results:\\n'));\n\n results.forEach((result: QualityGateResult) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const duration =\n result.duration < 1000\n ? `${result.duration}ms`\n : `${Math.round(result.duration / 1000)}s`;\n\n console.log(`${icon} ${result.gate} (${duration})`);\n\n if (!result.passed && result.issues) {\n result.issues.slice(0, 3).forEach((issue) => {\n console.log(\n ` ${issue.severity === 'error' ? '\u274C' : '\u26A0\uFE0F'} ${issue.message}`\n );\n });\n if (result.issues.length > 3) {\n console.log(\n chalk.gray(` ... and ${result.issues.length - 3} more issues`)\n );\n }\n }\n });\n\n const allPassed = results.every((r: QualityGateResult) => r.passed);\n if (allPassed) {\n console.log(chalk.green('\\n\uD83C\uDF89 All quality gates passed!'));\n } else {\n console.log(\n chalk.yellow('\\n\u26A0\uFE0F Some quality gates failed. See details above.')\n );\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Quality gates failed: ${error}`));\n }\n}\n\n/**\n * Show quality gate history\n */\nasync function showHistory(frameManager: FrameManager) {\n console.log(chalk.bold('\\n\uD83D\uDCC8 Quality Gate History\\n'));\n\n try {\n const results = await getRecentQualityResults(frameManager);\n\n if (results.length === 0) {\n console.log(chalk.gray('No quality gate history found'));\n return;\n }\n\n results.slice(0, 10).forEach((result, index) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const date = new Date(result.timestamp).toLocaleDateString();\n const time = new Date(result.timestamp).toLocaleTimeString();\n\n console.log(`${icon} ${result.frameName}`);\n console.log(chalk.gray(` ${date} ${time} - ${result.duration}ms`));\n\n if (result.gates) {\n result.gates.forEach((gate: any) => {\n const gateIcon = gate.passed ? ' \u2713' : ' \u2717';\n console.log(chalk.gray(`${gateIcon} ${gate.gate}`));\n });\n }\n\n if (index < results.length - 1) console.log('');\n });\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get history:', error));\n }\n}\n\n/**\n * Setup wizard\n */\nasync function setupWizard(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\uD83E\uDDD9 Quality Gates Setup Wizard\\n'));\n\n console.log(\n 'This wizard will help you configure automatic quality gates for your project.'\n );\n console.log(\n 'Quality gates run automatically after Claude completes tasks.\\n'\n );\n\n // Detect project type\n const packageJsonPath = path.join(projectRoot, 'package.json');\n let projectType = 'unknown';\n const detectedFrameworks: string[] = [];\n\n try {\n const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf-8'));\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps.react) projectType = 'React';\n else if (deps.vue) projectType = 'Vue';\n else if (deps.angular) projectType = 'Angular';\n else if (deps.express) projectType = 'Node.js API';\n else if (deps.nextjs) projectType = 'Next.js';\n\n if (deps.jest) detectedFrameworks.push('Jest');\n if (deps.vitest) detectedFrameworks.push('Vitest');\n if (deps.playwright) detectedFrameworks.push('Playwright');\n if (deps.eslint) detectedFrameworks.push('ESLint');\n } catch {\n // No package.json or invalid\n }\n\n console.log(`\uD83D\uDCE6 Detected project: ${chalk.cyan(projectType)}`);\n if (detectedFrameworks.length) {\n console.log(\n `\uD83D\uDD27 Detected tools: ${chalk.cyan(detectedFrameworks.join(', '))}`\n );\n }\n console.log('');\n\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message: 'Continue with setup?',\n default: true,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.gray('Setup cancelled'));\n return;\n }\n\n // Configure quality gates\n await configureQualityGates(projectRoot);\n\n // Enable quality gates\n const { enable } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enable',\n message: 'Enable quality gates now?',\n default: true,\n },\n ]);\n\n if (enable) {\n const spinner = ora();\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n }\n\n console.log(chalk.bold('\\n\uD83C\uDF89 Setup Complete!\\n'));\n console.log(\n 'Quality gates will now run automatically after Claude completes tasks.'\n );\n console.log('Check status with: stackmemory quality --status');\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nasync function loadConfig(\n projectRoot: string\n): Promise<Partial<PostTaskConfig>> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n\n try {\n const content = await fs.readFile(configPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return {};\n }\n}\n\nasync function saveConfig(\n projectRoot: string,\n config: Partial<PostTaskConfig>\n): Promise<void> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n await fs.mkdir(path.dirname(configPath), { recursive: true });\n await fs.writeFile(configPath, JSON.stringify(config, null, 2), 'utf-8');\n}\n\nfunction getTestCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.testCommand) {\n return chalk.gray(`(${config.testFrameworks.testCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nfunction getLintCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.lintCommand) {\n return chalk.gray(`(${config.testFrameworks.lintCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nasync function getRecentQualityResults(\n frameManager: FrameManager\n): Promise<any[]> {\n // This would query the frame metadata for quality gate results\n // For now, return empty array\n return [];\n}\n\nasync function getRecentlyModifiedFiles(\n projectRoot: string\n): Promise<string[]> {\n try {\n const { execSync } = await import('child_process');\n const output = execSync('git diff --name-only HEAD~1', {\n cwd: projectRoot,\n encoding: 'utf-8',\n });\n return output\n .trim()\n .split('\\n')\n .filter((f) => f.length > 0);\n } catch {\n return [];\n }\n}\n\nasync function createServiceFile(projectRoot: string): Promise<void> {\n const serviceContent = `# StackMemory Quality Gates Service\n# This file indicates quality gates are enabled\n# Created: ${new Date().toISOString()}\n`;\n\n const servicePath = path.join(projectRoot, '.stackmemory', 'quality.service');\n await fs.writeFile(servicePath, serviceContent, 'utf-8');\n}\n\n// Export for use in main CLI\nexport default createQualityCommand();\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env node\n\n/**\n * Quality command for StackMemory\n * Manages post-task quality gates and code review automation\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport inquirer from 'inquirer';\nimport {\n PostTaskHooks,\n PostTaskConfig,\n QualityGateResult,\n} from '../../integrations/claude-code/post-task-hooks.js';\nimport { FrameManager } from '../../core/context/frame-manager.js';\nimport Database from 'better-sqlite3';\n// getProjectRoot function will be defined below\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\n\nexport function createQualityCommand(): Command {\n const cmd = new Command('quality')\n .description('Manage post-task quality gates and automation')\n .option('--enable', 'Enable quality gates')\n .option('--disable', 'Disable quality gates')\n .option('--status', 'Show quality gate status')\n .option('--config', 'Configure quality gates')\n .option('--run', 'Run quality gates manually')\n .option('--history', 'Show quality gate history')\n .option('--setup', 'Interactive setup wizard')\n .action(async (options) => {\n const spinner = ora();\n\n try {\n const projectRoot = await getProjectRoot();\n const dbPath = path.join(\n projectRoot,\n '.stackmemory',\n 'db',\n 'stackmemory.db'\n );\n\n // Check if StackMemory is initialized\n try {\n await fs.access(dbPath);\n } catch {\n console.error(chalk.red('\u2717 StackMemory not initialized'));\n console.log(chalk.yellow('Run: stackmemory init'));\n process.exit(1);\n }\n\n const db = new Database(dbPath);\n const frameManager = new FrameManager(db);\n\n if (options.enable) {\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.disable) {\n await disableQualityGates(projectRoot, spinner);\n } else if (options.status) {\n await showStatus(projectRoot, frameManager, db);\n } else if (options.config) {\n await configureQualityGates(projectRoot);\n } else if (options.run) {\n await runQualityGates(projectRoot, frameManager, db, spinner);\n } else if (options.history) {\n await showHistory(frameManager);\n } else if (options.setup) {\n await setupWizard(projectRoot, frameManager, db);\n } else {\n // Default: show status\n await showStatus(projectRoot, frameManager, db);\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Error: ${error}`));\n process.exit(1);\n }\n });\n\n return cmd;\n}\n\n/**\n * Enable quality gates\n */\nasync function enableQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Enabling quality gates...');\n\n try {\n // Load or create config\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: true,\n runCodeReview: true,\n runLinter: true,\n };\n\n // Initialize hooks\n const hooks = new PostTaskHooks(frameManager, db, config);\n await hooks.initialize();\n\n // Save config\n await saveConfig(projectRoot, config);\n\n // Create systemd-style service file for persistence\n await createServiceFile(projectRoot);\n\n spinner.succeed(chalk.green('\u2705 Quality gates enabled'));\n\n console.log(chalk.bold('\\n\uD83D\uDD0D Quality Gates Active:'));\n console.log(' \u2022 Auto-run tests after code changes');\n console.log(' \u2022 Auto-run linter on file saves');\n console.log(' \u2022 Auto-trigger code review on task completion');\n console.log(' \u2022 Real-time file change monitoring');\n\n console.log(chalk.gray('\\nDisable with: stackmemory quality --disable'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to enable quality gates: ${error}`));\n }\n}\n\n/**\n * Disable quality gates\n */\nasync function disableQualityGates(projectRoot: string, spinner: ora.Ora) {\n spinner.start('Disabling quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n config.qualityGates = {\n ...config.qualityGates,\n runTests: false,\n runCodeReview: false,\n runLinter: false,\n };\n\n await saveConfig(projectRoot, config);\n\n // Remove service file\n const serviceFile = path.join(\n projectRoot,\n '.stackmemory',\n 'quality.service'\n );\n try {\n await fs.unlink(serviceFile);\n } catch {\n // Service file doesn't exist\n }\n\n spinner.succeed(chalk.green('\u2705 Quality gates disabled'));\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Failed to disable quality gates: ${error}`));\n }\n}\n\n/**\n * Show quality gate status\n */\nasync function showStatus(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\\n\uD83D\uDCCA Quality Gates Status\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n // Overall status\n const isEnabled =\n config.qualityGates?.runTests ||\n config.qualityGates?.runCodeReview ||\n config.qualityGates?.runLinter;\n console.log(\n `Status: ${isEnabled ? chalk.green('\u2705 Enabled') : chalk.yellow('\u26A0\uFE0F Disabled')}`\n );\n\n // Individual gates\n console.log('\\nGates:');\n console.log(\n ` Tests: ${config.qualityGates?.runTests ? '\u2705' : '\u274C'} ${getTestCommand(config)}`\n );\n console.log(\n ` Linter: ${config.qualityGates?.runLinter ? '\u2705' : '\u274C'} ${getLintCommand(config)}`\n );\n console.log(\n ` Code Review: ${config.qualityGates?.runCodeReview ? '\u2705' : '\u274C'}`\n );\n console.log(\n ` Coverage: ${config.qualityGates?.requireTestCoverage ? '\u2705' : '\u274C'}`\n );\n\n // Detected frameworks\n if (config.testFrameworks?.detected.length) {\n console.log('\\nDetected Frameworks:');\n config.testFrameworks.detected.forEach((fw) => {\n console.log(` \u2022 ${fw}`);\n });\n }\n\n // Recent quality results\n const recentResults = await getRecentQualityResults(frameManager);\n if (recentResults.length > 0) {\n console.log('\\nRecent Results:');\n recentResults.slice(0, 3).forEach((result) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n console.log(\n ` ${icon} ${result.frameName} (${new Date(result.timestamp).toLocaleString()})`\n );\n });\n }\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get status:', error));\n }\n}\n\n/**\n * Configure quality gates\n */\nasync function configureQualityGates(projectRoot: string) {\n console.log(chalk.bold('\\n\u2699\uFE0F Quality Gates Configuration\\n'));\n\n try {\n const config = await loadConfig(projectRoot);\n\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'runTests',\n message: 'Auto-run tests after code changes?',\n default: config.qualityGates?.runTests ?? true,\n },\n {\n type: 'confirm',\n name: 'runLinter',\n message: 'Auto-run linter on file changes?',\n default: config.qualityGates?.runLinter ?? true,\n },\n {\n type: 'confirm',\n name: 'runCodeReview',\n message: 'Auto-trigger code review on task completion?',\n default: config.qualityGates?.runCodeReview ?? true,\n },\n {\n type: 'confirm',\n name: 'requireTestCoverage',\n message: 'Require test coverage checks?',\n default: config.qualityGates?.requireTestCoverage ?? false,\n },\n {\n type: 'confirm',\n name: 'blockOnFailure',\n message: 'Block further work when quality gates fail?',\n default: config.qualityGates?.blockOnFailure ?? false,\n },\n {\n type: 'input',\n name: 'testCommand',\n message: 'Custom test command (leave empty for auto-detect):',\n default: config.testFrameworks?.testCommand || '',\n },\n {\n type: 'input',\n name: 'lintCommand',\n message: 'Custom lint command (leave empty for auto-detect):',\n default: config.testFrameworks?.lintCommand || '',\n },\n ]);\n\n // Update config\n config.qualityGates = {\n runTests: answers.runTests,\n runLinter: answers.runLinter,\n runCodeReview: answers.runCodeReview,\n requireTestCoverage: answers.requireTestCoverage,\n blockOnFailure: answers.blockOnFailure,\n };\n\n config.testFrameworks = {\n ...config.testFrameworks,\n testCommand: answers.testCommand || config.testFrameworks?.testCommand,\n lintCommand: answers.lintCommand || config.testFrameworks?.lintCommand,\n };\n\n await saveConfig(projectRoot, config);\n\n console.log(chalk.green('\\n\u2705 Configuration saved'));\n console.log(chalk.gray('Enable with: stackmemory quality --enable'));\n } catch (error: unknown) {\n console.error(chalk.red('Configuration failed:', error));\n }\n}\n\n/**\n * Run quality gates manually\n */\nasync function runQualityGates(\n projectRoot: string,\n frameManager: FrameManager,\n db: any,\n spinner: any\n) {\n spinner.start('Running quality gates...');\n\n try {\n const config = await loadConfig(projectRoot);\n const hooks = new PostTaskHooks(frameManager, db, config);\n\n // Simulate a task completion event\n const mockEvent = {\n taskType: 'task_complete' as const,\n frameId: 'manual-run',\n frameName: 'Manual quality gate run',\n files: await getRecentlyModifiedFiles(projectRoot),\n changes: { added: 0, removed: 0, modified: 1 },\n metadata: { trigger: 'manual' },\n };\n\n // Run quality gates\n const results = await (hooks as any).runQualityGates(mockEvent);\n\n spinner.succeed(chalk.green('\u2705 Quality gates completed'));\n\n // Show results\n console.log(chalk.bold('\\n\uD83D\uDCCB Quality Gate Results:\\n'));\n\n results.forEach((result: QualityGateResult) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const duration =\n result.duration < 1000\n ? `${result.duration}ms`\n : `${Math.round(result.duration / 1000)}s`;\n\n console.log(`${icon} ${result.gate} (${duration})`);\n\n if (!result.passed && result.issues) {\n result.issues.slice(0, 3).forEach((issue) => {\n console.log(\n ` ${issue.severity === 'error' ? '\u274C' : '\u26A0\uFE0F'} ${issue.message}`\n );\n });\n if (result.issues.length > 3) {\n console.log(\n chalk.gray(` ... and ${result.issues.length - 3} more issues`)\n );\n }\n }\n });\n\n const allPassed = results.every((r: QualityGateResult) => r.passed);\n if (allPassed) {\n console.log(chalk.green('\\n\uD83C\uDF89 All quality gates passed!'));\n } else {\n console.log(\n chalk.yellow('\\n\u26A0\uFE0F Some quality gates failed. See details above.')\n );\n }\n } catch (error: unknown) {\n spinner.fail(chalk.red(`Quality gates failed: ${error}`));\n }\n}\n\n/**\n * Show quality gate history\n */\nasync function showHistory(frameManager: FrameManager) {\n console.log(chalk.bold('\\n\uD83D\uDCC8 Quality Gate History\\n'));\n\n try {\n const results = await getRecentQualityResults(frameManager);\n\n if (results.length === 0) {\n console.log(chalk.gray('No quality gate history found'));\n return;\n }\n\n results.slice(0, 10).forEach((result, index) => {\n const icon = result.passed ? '\u2705' : '\u274C';\n const date = new Date(result.timestamp).toLocaleDateString();\n const time = new Date(result.timestamp).toLocaleTimeString();\n\n console.log(`${icon} ${result.frameName}`);\n console.log(chalk.gray(` ${date} ${time} - ${result.duration}ms`));\n\n if (result.gates) {\n result.gates.forEach((gate: any) => {\n const gateIcon = gate.passed ? ' \u2713' : ' \u2717';\n console.log(chalk.gray(`${gateIcon} ${gate.gate}`));\n });\n }\n\n if (index < results.length - 1) console.log('');\n });\n } catch (error: unknown) {\n console.error(chalk.red('Failed to get history:', error));\n }\n}\n\n/**\n * Setup wizard\n */\nasync function setupWizard(\n projectRoot: string,\n frameManager: FrameManager,\n db: Database\n) {\n console.log(chalk.bold('\uD83E\uDDD9 Quality Gates Setup Wizard\\n'));\n\n console.log(\n 'This wizard will help you configure automatic quality gates for your project.'\n );\n console.log(\n 'Quality gates run automatically after Claude completes tasks.\\n'\n );\n\n // Detect project type\n const packageJsonPath = path.join(projectRoot, 'package.json');\n let projectType = 'unknown';\n const detectedFrameworks: string[] = [];\n\n try {\n const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf-8'));\n const deps = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies,\n };\n\n if (deps.react) projectType = 'React';\n else if (deps.vue) projectType = 'Vue';\n else if (deps.angular) projectType = 'Angular';\n else if (deps.express) projectType = 'Node.js API';\n else if (deps.nextjs) projectType = 'Next.js';\n\n if (deps.jest) detectedFrameworks.push('Jest');\n if (deps.vitest) detectedFrameworks.push('Vitest');\n if (deps.playwright) detectedFrameworks.push('Playwright');\n if (deps.eslint) detectedFrameworks.push('ESLint');\n } catch {\n // No package.json or invalid\n }\n\n console.log(`\uD83D\uDCE6 Detected project: ${chalk.cyan(projectType)}`);\n if (detectedFrameworks.length) {\n console.log(\n `\uD83D\uDD27 Detected tools: ${chalk.cyan(detectedFrameworks.join(', '))}`\n );\n }\n console.log('');\n\n const { proceed } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'proceed',\n message: 'Continue with setup?',\n default: true,\n },\n ]);\n\n if (!proceed) {\n console.log(chalk.gray('Setup cancelled'));\n return;\n }\n\n // Configure quality gates\n await configureQualityGates(projectRoot);\n\n // Enable quality gates\n const { enable } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'enable',\n message: 'Enable quality gates now?',\n default: true,\n },\n ]);\n\n if (enable) {\n const spinner = ora();\n await enableQualityGates(projectRoot, frameManager, db, spinner);\n }\n\n console.log(chalk.bold('\\n\uD83C\uDF89 Setup Complete!\\n'));\n console.log(\n 'Quality gates will now run automatically after Claude completes tasks.'\n );\n console.log('Check status with: stackmemory quality --status');\n}\n\n// Helper functions\n\nasync function getProjectRoot(): Promise<string> {\n return process.cwd();\n}\n\nasync function loadConfig(\n projectRoot: string\n): Promise<Partial<PostTaskConfig>> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n\n try {\n const content = await fs.readFile(configPath, 'utf-8');\n return JSON.parse(content);\n } catch {\n return {};\n }\n}\n\nasync function saveConfig(\n projectRoot: string,\n config: Partial<PostTaskConfig>\n): Promise<void> {\n const configPath = path.join(projectRoot, '.stackmemory', 'config.json');\n await fs.mkdir(path.dirname(configPath), { recursive: true });\n await fs.writeFile(configPath, JSON.stringify(config, null, 2), 'utf-8');\n}\n\nfunction getTestCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.testCommand) {\n return chalk.gray(`(${config.testFrameworks.testCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nfunction getLintCommand(config: Partial<PostTaskConfig>): string {\n if (config.testFrameworks?.lintCommand) {\n return chalk.gray(`(${config.testFrameworks.lintCommand})`);\n }\n return chalk.gray('(auto-detect)');\n}\n\nasync function getRecentQualityResults(\n frameManager: FrameManager\n): Promise<any[]> {\n // This would query the frame metadata for quality gate results\n // For now, return empty array\n return [];\n}\n\nasync function getRecentlyModifiedFiles(\n projectRoot: string\n): Promise<string[]> {\n try {\n const { execFileSync } = await import('child_process');\n const output = execFileSync('git', ['diff', '--name-only', 'HEAD~1'], {\n cwd: projectRoot,\n encoding: 'utf-8',\n });\n return output\n .trim()\n .split('\\n')\n .filter((f) => f.length > 0);\n } catch {\n return [];\n }\n}\n\nasync function createServiceFile(projectRoot: string): Promise<void> {\n const serviceContent = `# StackMemory Quality Gates Service\n# This file indicates quality gates are enabled\n# Created: ${new Date().toISOString()}\n`;\n\n const servicePath = path.join(projectRoot, '.stackmemory', 'quality.service');\n await fs.writeFile(servicePath, serviceContent, 'utf-8');\n}\n\n// Export for use in main CLI\nexport default createQualityCommand();\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -3,12 +3,14 @@ import { Command } from "commander";
3
3
  import chalk from "chalk";
4
4
  import ora from "ora";
5
5
  import {
6
- ClaudeSkillsManager
7
- } from "../../skills/claude-skills.js";
6
+ initializeUnifiedOrchestrator
7
+ } from "../../skills/unified-rlm-orchestrator.js";
8
8
  import { DualStackManager } from "../../core/context/dual-stack-manager.js";
9
9
  import { FrameHandoffManager } from "../../core/context/frame-handoff-manager.js";
10
+ import { FrameManager } from "../../core/context/frame-manager.js";
10
11
  import { ContextRetriever } from "../../core/retrieval/context-retriever.js";
11
12
  import { SQLiteAdapter } from "../../core/database/sqlite-adapter.js";
13
+ import { LinearTaskManager } from "../../features/tasks/linear-task-manager.js";
12
14
  import { ConfigManager } from "../../core/config/config-manager.js";
13
15
  import * as path from "path";
14
16
  import * as os from "os";
@@ -25,7 +27,7 @@ function getOptionalEnv(key) {
25
27
  }
26
28
  async function initializeSkillContext() {
27
29
  const config = ConfigManager.getInstance();
28
- const projectId = config.get("project.id");
30
+ const projectId = config.get("project.id") || "default-project";
29
31
  const userId = config.get("user.id") || process.env["USER"] || "default";
30
32
  const dbPath = path.join(
31
33
  os.homedir(),
@@ -39,7 +41,9 @@ async function initializeSkillContext() {
39
41
  const dualStackManager = new DualStackManager(database, projectId, userId);
40
42
  const handoffManager = new FrameHandoffManager(dualStackManager);
41
43
  const contextRetriever = new ContextRetriever(database);
42
- return {
44
+ const frameManager = new FrameManager(database);
45
+ const taskStore = new LinearTaskManager();
46
+ const context = {
43
47
  projectId,
44
48
  userId,
45
49
  dualStackManager,
@@ -47,6 +51,14 @@ async function initializeSkillContext() {
47
51
  contextRetriever,
48
52
  database
49
53
  };
54
+ const unifiedOrchestrator = initializeUnifiedOrchestrator(
55
+ frameManager,
56
+ dualStackManager,
57
+ contextRetriever,
58
+ taskStore,
59
+ context
60
+ );
61
+ return { context, unifiedOrchestrator };
50
62
  }
51
63
  function createSkillsCommand() {
52
64
  const skillsCmd = new Command("skills").description(
@@ -59,9 +71,8 @@ function createSkillsCommand() {
59
71
  ).option("-f, --frames <frames...>", "Specific frames to handoff").option("--no-auto-detect", "Disable auto-detection of frames").action(async (targetUser, message, options) => {
60
72
  const spinner = ora("Initiating handoff...").start();
61
73
  try {
62
- const context = await initializeSkillContext();
63
- const skillsManager = new ClaudeSkillsManager(context);
64
- const result = await skillsManager.executeSkill(
74
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
75
+ const result = await unifiedOrchestrator.executeSkill(
65
76
  "handoff",
66
77
  [targetUser, message],
67
78
  {
@@ -99,9 +110,8 @@ function createSkillsCommand() {
99
110
  checkpointCmd.command("create <description>").description("Create a new checkpoint").option("--files <files...>", "Include specific files in checkpoint").option("--auto-detect-risky", "Auto-detect risky operations").action(async (description, options) => {
100
111
  const spinner = ora("Creating checkpoint...").start();
101
112
  try {
102
- const context = await initializeSkillContext();
103
- const skillsManager = new ClaudeSkillsManager(context);
104
- const result = await skillsManager.executeSkill(
113
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
114
+ const result = await unifiedOrchestrator.executeSkill(
105
115
  "checkpoint",
106
116
  ["create", description],
107
117
  {
@@ -131,9 +141,8 @@ function createSkillsCommand() {
131
141
  checkpointCmd.command("restore <checkpointId>").description("Restore from a checkpoint").action(async (checkpointId) => {
132
142
  const spinner = ora("Restoring checkpoint...").start();
133
143
  try {
134
- const context = await initializeSkillContext();
135
- const skillsManager = new ClaudeSkillsManager(context);
136
- const result = await skillsManager.executeSkill("checkpoint", [
144
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
145
+ const result = await unifiedOrchestrator.executeSkill("checkpoint", [
137
146
  "restore",
138
147
  checkpointId
139
148
  ]);
@@ -158,9 +167,8 @@ function createSkillsCommand() {
158
167
  checkpointCmd.command("list").description("List available checkpoints").option("-l, --limit <number>", "Limit number of results", "10").option("-s, --since <date>", "Show checkpoints since date").action(async (options) => {
159
168
  const spinner = ora("Loading checkpoints...").start();
160
169
  try {
161
- const context = await initializeSkillContext();
162
- const skillsManager = new ClaudeSkillsManager(context);
163
- const result = await skillsManager.executeSkill(
170
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
171
+ const result = await unifiedOrchestrator.executeSkill(
164
172
  "checkpoint",
165
173
  ["list"],
166
174
  {
@@ -197,9 +205,8 @@ function createSkillsCommand() {
197
205
  checkpointCmd.command("diff <checkpoint1> <checkpoint2>").description("Show differences between two checkpoints").action(async (checkpoint1, checkpoint2) => {
198
206
  const spinner = ora("Comparing checkpoints...").start();
199
207
  try {
200
- const context = await initializeSkillContext();
201
- const skillsManager = new ClaudeSkillsManager(context);
202
- const result = await skillsManager.executeSkill("checkpoint", [
208
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
209
+ const result = await unifiedOrchestrator.executeSkill("checkpoint", [
203
210
  "diff",
204
211
  checkpoint1,
205
212
  checkpoint2
@@ -231,9 +238,8 @@ function createSkillsCommand() {
231
238
  ).option("--patterns", "Extract patterns from results").option("--decisions", "Extract key decisions").option("--timeline", "Generate activity timeline").action(async (query, options) => {
232
239
  const spinner = ora("Digging through context...").start();
233
240
  try {
234
- const context = await initializeSkillContext();
235
- const skillsManager = new ClaudeSkillsManager(context);
236
- const result = await skillsManager.executeSkill("dig", [query], {
241
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
242
+ const result = await unifiedOrchestrator.executeSkill("dig", [query], {
237
243
  depth: options.depth,
238
244
  patterns: options.patterns,
239
245
  decisions: options.decisions,
@@ -292,23 +298,102 @@ Searched ${result.data.timeRange.from} to ${result.data.timeRange.to}`
292
298
  process.exit(1);
293
299
  }
294
300
  });
301
+ skillsCmd.command("rlm <task>").description("Execute complex tasks with recursive agent orchestration").option("--max-parallel <number>", "Maximum concurrent subagents", "5").option("--max-recursion <number>", "Maximum recursion depth", "4").option("--max-tokens-per-agent <number>", "Token budget per subagent", "30000").option("--review-stages <number>", "Number of review iterations", "3").option("--quality-threshold <number>", "Target quality score (0-1)", "0.85").option("--test-mode <mode>", "Test generation mode (unit/integration/e2e/all)", "all").option("--verbose", "Show all recursive operations", false).option("--share-context-realtime", "Share discoveries between agents", true).option("--retry-failed-agents", "Retry on failure", true).option("--timeout-per-agent <number>", "Timeout in seconds", "300").action(async (task, options) => {
302
+ const spinner = ora("Initializing RLM orchestrator...").start();
303
+ try {
304
+ const { context, unifiedOrchestrator } = await initializeSkillContext();
305
+ spinner.text = "Decomposing task...";
306
+ const result = await unifiedOrchestrator.executeSkill("rlm", [task], {
307
+ maxParallel: parseInt(options.maxParallel),
308
+ maxRecursionDepth: parseInt(options.maxRecursion),
309
+ maxTokensPerAgent: parseInt(options.maxTokensPerAgent),
310
+ reviewStages: parseInt(options.reviewStages),
311
+ qualityThreshold: parseFloat(options.qualityThreshold),
312
+ testGenerationMode: options.testMode,
313
+ verboseLogging: options.verbose,
314
+ shareContextRealtime: options.shareContextRealtime,
315
+ retryFailedAgents: options.retryFailedAgents,
316
+ timeoutPerAgent: parseInt(options.timeoutPerAgent) * 1e3
317
+ });
318
+ spinner.stop();
319
+ if (result.success) {
320
+ console.log(chalk.green("\u2713"), "RLM execution completed");
321
+ if (result.data) {
322
+ console.log(chalk.cyan("\nExecution Summary:"));
323
+ console.log(` Total tokens: ${result.data.totalTokens}`);
324
+ console.log(` Estimated cost: $${result.data.totalCost.toFixed(2)}`);
325
+ console.log(` Duration: ${result.data.duration}ms`);
326
+ console.log(` Tests generated: ${result.data.testsGenerated}`);
327
+ console.log(` Issues found: ${result.data.issuesFound}`);
328
+ console.log(` Issues fixed: ${result.data.issuesFixed}`);
329
+ if (result.data.improvements?.length > 0) {
330
+ console.log(chalk.cyan("\nImprovements:"));
331
+ result.data.improvements.forEach((imp) => {
332
+ console.log(` \u2022 ${imp}`);
333
+ });
334
+ }
335
+ }
336
+ } else {
337
+ console.log(chalk.red("\u2717"), result.message);
338
+ }
339
+ await context.database.disconnect();
340
+ } catch (error) {
341
+ spinner.stop();
342
+ console.error(chalk.red("Error:"), error.message);
343
+ process.exit(1);
344
+ }
345
+ });
295
346
  skillsCmd.command("help [skill]").description("Show help for a specific skill").action(async (skill) => {
296
- const context = await initializeSkillContext();
297
- const skillsManager = new ClaudeSkillsManager(context);
298
347
  if (skill) {
299
- console.log(skillsManager.getSkillHelp(skill));
348
+ switch (skill) {
349
+ case "lint":
350
+ console.log(`
351
+ lint (RLM-Orchestrated)
352
+ Primary Agent: linting
353
+ Secondary Agents: improve
354
+
355
+ Comprehensive linting of code: Check syntax, types, formatting, security, performance, and dead code. Provide fixes.
356
+
357
+ This skill is executed through RLM orchestration for:
358
+ - Automatic task decomposition
359
+ - Parallel agent execution
360
+ - Multi-stage quality review
361
+ - Comprehensive result aggregation
362
+
363
+ Usage:
364
+ stackmemory skills lint # Lint current directory
365
+ stackmemory skills lint src/ # Lint specific directory
366
+ stackmemory skills lint src/file.ts # Lint specific file
367
+
368
+ Options:
369
+ --fix Automatically fix issues where possible
370
+ --format Focus on formatting issues
371
+ --security Focus on security vulnerabilities
372
+ --performance Focus on performance issues
373
+ --verbose Show detailed output
374
+ `);
375
+ break;
376
+ default:
377
+ console.log(`Unknown skill: ${skill}. Use "stackmemory skills help" to see all available skills.`);
378
+ }
300
379
  } else {
301
- console.log(chalk.cyan("Available Claude Skills:\n"));
380
+ console.log(chalk.cyan("Available Claude Skills (RLM-Orchestrated):\n"));
302
381
  console.log(
303
382
  " handoff - Streamline frame handoffs between team members"
304
383
  );
305
384
  console.log(" checkpoint - Create and manage recovery points");
306
- console.log(" dig - Deep historical context retrieval\n");
385
+ console.log(" dig - Deep historical context retrieval");
386
+ console.log(" lint - Comprehensive code linting and quality checks");
387
+ console.log(" test - Generate comprehensive test suites");
388
+ console.log(" review - Multi-stage code review and improvements");
389
+ console.log(" refactor - Refactor code for better architecture");
390
+ console.log(" publish - Prepare and execute releases");
391
+ console.log(" rlm - Direct recursive agent orchestration\n");
392
+ console.log(chalk.yellow("\nAll skills now use RLM orchestration for intelligent task decomposition"));
307
393
  console.log(
308
394
  'Use "stackmemory skills help <skill>" for detailed help on each skill'
309
395
  );
310
396
  }
311
- await context.database.disconnect();
312
397
  });
313
398
  return skillsCmd;
314
399
  }