@triedotdev/mcp 1.0.91 → 1.0.92

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 (38) hide show
  1. package/README.md +1 -621
  2. package/dist/{agent-smith-Q52DFQET.js → agent-smith-QYDXPFPJ.js} +2 -2
  3. package/dist/{agent-smith-runner-BMT3FN7T.js → agent-smith-runner-GXGDJTSR.js} +2 -2
  4. package/dist/cache-manager-7SKX3IGO.js +10 -0
  5. package/dist/cache-manager-7SKX3IGO.js.map +1 -0
  6. package/dist/{chunk-LAGXOPXN.js → chunk-3HDWOSLX.js} +39 -18
  7. package/dist/chunk-3HDWOSLX.js.map +1 -0
  8. package/dist/{chunk-7IEGGW4L.js → chunk-5DQLHWTT.js} +114 -342
  9. package/dist/chunk-5DQLHWTT.js.map +1 -0
  10. package/dist/chunk-76Q5DMYV.js +159 -0
  11. package/dist/chunk-76Q5DMYV.js.map +1 -0
  12. package/dist/chunk-HFQ5ORON.js +279 -0
  13. package/dist/chunk-HFQ5ORON.js.map +1 -0
  14. package/dist/{chunk-XEQRB4XX.js → chunk-KWDNYWOR.js} +2 -2
  15. package/dist/chunk-KWDNYWOR.js.map +1 -0
  16. package/dist/chunk-MURGTWG4.js +279 -0
  17. package/dist/chunk-MURGTWG4.js.map +1 -0
  18. package/dist/{chunk-3EZ2ETKG.js → chunk-R6YM6YSV.js} +43 -368
  19. package/dist/chunk-R6YM6YSV.js.map +1 -0
  20. package/dist/{chunk-6OJRG7MM.js → chunk-ZOKQJZKN.js} +6 -4
  21. package/dist/{chunk-6OJRG7MM.js.map → chunk-ZOKQJZKN.js.map} +1 -1
  22. package/dist/cli/main.js +15 -10
  23. package/dist/cli/main.js.map +1 -1
  24. package/dist/cli/yolo-daemon.js +14 -6
  25. package/dist/cli/yolo-daemon.js.map +1 -1
  26. package/dist/git-5WJHCMNO.js +29 -0
  27. package/dist/git-5WJHCMNO.js.map +1 -0
  28. package/dist/index.js +16 -12
  29. package/dist/index.js.map +1 -1
  30. package/dist/workers/agent-worker.js +3 -2
  31. package/dist/workers/agent-worker.js.map +1 -1
  32. package/package.json +2 -2
  33. package/dist/chunk-3EZ2ETKG.js.map +0 -1
  34. package/dist/chunk-7IEGGW4L.js.map +0 -1
  35. package/dist/chunk-LAGXOPXN.js.map +0 -1
  36. package/dist/chunk-XEQRB4XX.js.map +0 -1
  37. /package/dist/{agent-smith-Q52DFQET.js.map → agent-smith-QYDXPFPJ.js.map} +0 -0
  38. /package/dist/{agent-smith-runner-BMT3FN7T.js.map → agent-smith-runner-GXGDJTSR.js.map} +0 -0
@@ -3,21 +3,24 @@ import {
3
3
  InteractiveDashboard,
4
4
  StreamingManager,
5
5
  TrieScanTool
6
- } from "../chunk-LAGXOPXN.js";
6
+ } from "../chunk-3HDWOSLX.js";
7
7
  import "../chunk-PSVRO76R.js";
8
8
  import "../chunk-NMGINYYX.js";
9
9
  import {
10
10
  isTrieInitialized
11
- } from "../chunk-3EZ2ETKG.js";
11
+ } from "../chunk-R6YM6YSV.js";
12
+ import "../chunk-HFQ5ORON.js";
13
+ import "../chunk-76Q5DMYV.js";
12
14
  import "../chunk-P6XMIUD7.js";
13
15
  import "../chunk-FK3DUQ5T.js";
14
16
  import "../chunk-T5UOH56R.js";
15
- import "../chunk-7IEGGW4L.js";
17
+ import "../chunk-5DQLHWTT.js";
18
+ import "../chunk-MURGTWG4.js";
16
19
  import "../chunk-LT7MKIXU.js";
17
20
  import "../chunk-LP4MVJDW.js";
18
21
  import "../chunk-IYMJTY27.js";
19
22
  import "../chunk-6NLHFIYA.js";
20
- import "../chunk-XEQRB4XX.js";
23
+ import "../chunk-KWDNYWOR.js";
21
24
  import "../chunk-74NPKTZV.js";
22
25
  import {
23
26
  getWorkingDirectory
@@ -91,12 +94,12 @@ var WatchDaemon = class {
91
94
  }
92
95
  process.exit(1);
93
96
  }
94
- this.log("info", "Starting Trie Guardian Agent", {
97
+ this.log("info", "Starting Trie Agent", {
95
98
  directory: this.config.directory,
96
99
  debounceMs: this.config.debounceMs
97
100
  });
98
101
  if (!isInteractiveMode()) {
99
- console.error("\nYour guardian agent is watching over your codebase.\n");
102
+ console.error("\nYour Trie agent is watching over your codebase.\n");
100
103
  }
101
104
  if (!existsSync(this.config.directory)) {
102
105
  this.log("error", "Directory not found", { directory: this.config.directory });
@@ -402,6 +405,10 @@ function parseArgs() {
402
405
  case "--no-cache":
403
406
  config2.cache = false;
404
407
  break;
408
+ case "--force-rescan":
409
+ case "--force":
410
+ config2.cache = false;
411
+ break;
405
412
  case "--max-concurrency":
406
413
  config2.maxConcurrency = parseInt(nextArg || "4", 10);
407
414
  i++;
@@ -489,6 +496,7 @@ PERFORMANCE:
489
496
  --no-parallel Disable parallel execution
490
497
  --cache Enable result caching
491
498
  --no-cache Disable result caching
499
+ --force-rescan Force rescan (bypasses cache, same as --no-cache)
492
500
  --max-concurrency <n> Max parallel scouts
493
501
  --streaming Enable streaming updates
494
502
  --no-streaming Disable streaming updates
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/cli/yolo-daemon.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Trie Guardian - File Watcher & Scanner\n * \n * Watches a directory and reports issues as they occur.\n * Also handles one-shot scanning via --once flag.\n * \n * Usage:\n * trie watch [options] # Watch for changes\n * trie scan [options] # Scan once and exit\n * \n * See `trie watch --help` for all options.\n */\n\nimport { watch, existsSync, statSync, readFileSync } from 'fs';\nimport { readdir } from 'fs/promises';\nimport { join, extname, basename, resolve } from 'path';\nimport { TrieScanTool } from '../tools/scan.js';\nimport { StreamingManager } from '../utils/streaming.js';\nimport { InteractiveDashboard } from './interactive-dashboard.js';\nimport { getWorkingDirectory } from '../utils/workspace.js';\nimport { isInteractiveMode, setInteractiveMode } from '../utils/progress.js';\nimport { isTrieInitialized } from '../utils/trie-init.js';\n\n// File extensions to watch\nconst WATCH_EXTENSIONS = new Set([\n '.ts', '.tsx', '.js', '.jsx', '.mjs',\n '.vue', '.svelte', '.astro',\n '.py', '.go', '.rs'\n]);\n\n// Directories to skip\nconst SKIP_DIRS = new Set([\n 'node_modules', '.git', 'dist', 'build', '.next', '.nuxt',\n 'coverage', '.turbo', '.cache', '__pycache__', '.venv'\n]);\n\ninterface DaemonConfig {\n directory: string;\n debounceMs: number;\n jsonOutput: boolean;\n runOnce: boolean;\n format?: 'text' | 'json';\n output?: string;\n parallel?: boolean;\n cache?: boolean;\n maxConcurrency?: number;\n streaming?: boolean;\n interactive?: boolean;\n workers?: boolean;\n timeoutMs?: number;\n files?: string[];\n /** Comma-separated list of scouts to run (e.g., \"security,privacy\") */\n forceScouts?: string[];\n /** User count for cost estimation (default: 250) */\n userCount?: number;\n /** Industry for Moneybags cost scaling */\n industry?: 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce';\n}\n\ninterface DaemonStats {\n filesScanned: number;\n issuesFound: number;\n errors: number;\n startTime: number;\n}\n\nclass WatchDaemon {\n private config: DaemonConfig;\n private stats: DaemonStats;\n private scanTool = new TrieScanTool();\n private watchers: Map<string, ReturnType<typeof watch>> = new Map();\n private pendingFiles: Set<string> = new Set();\n private debounceTimer: NodeJS.Timeout | null = null;\n private isProcessing = false;\n private streamingManager: StreamingManager | undefined = undefined;\n private dashboard: InteractiveDashboard | undefined = undefined;\n\n constructor(config: DaemonConfig) {\n this.config = config;\n this.stats = {\n filesScanned: 0,\n issuesFound: 0,\n errors: 0,\n startTime: Date.now()\n };\n }\n\n /**\n * Start the daemon\n */\n async start(): Promise<void> {\n // Enable global interactive mode when TTY and not explicitly disabled\n if (this.config.interactive !== false && process.stdout.isTTY) {\n setInteractiveMode(true);\n }\n if (!isTrieInitialized(this.config.directory)) {\n if (!isInteractiveMode()) {\n console.error('Trie is not initialized for this project.');\n console.error('Run `trie init` first.');\n }\n process.exit(1);\n }\n\n this.log('info', 'Starting Trie Guardian Agent', {\n directory: this.config.directory,\n debounceMs: this.config.debounceMs\n });\n if (!isInteractiveMode()) {\n console.error('\\nYour guardian agent is watching over your codebase.\\n');\n }\n\n // Validate directory\n if (!existsSync(this.config.directory)) {\n this.log('error', 'Directory not found', { directory: this.config.directory });\n process.exit(1);\n }\n\n // Start interactive dashboard if enabled\n if (isInteractiveMode()) {\n this.streamingManager = new StreamingManager();\n this.dashboard = new InteractiveDashboard();\n this.streamingManager.subscribe(update => this.dashboard?.handleStreamUpdate(update));\n \n // Register callback for Moneybags settings changes\n this.dashboard.onMoneybagsChange(() => {\n this.recalculateMoneybags();\n });\n \n await this.dashboard.start();\n this.streamingManager.reportWatchStatus({\n watching: !this.config.runOnce,\n directories: 0,\n debounceMs: this.config.debounceMs\n });\n }\n\n // Run initial scan\n this.log('info', 'Running initial scan...');\n await this.runScan(this.config.files);\n\n // If run-once mode, exit after initial scan\n if (this.config.runOnce) {\n this.log('info', 'Run-once mode: exiting after initial scan', { ...this.stats });\n process.exit(this.stats.issuesFound > 0 ? 1 : 0);\n }\n\n // Start watching\n await this.watchDirectory(this.config.directory);\n this.streamingManager?.reportWatchStatus({\n watching: true,\n directories: this.watchers.size,\n debounceMs: this.config.debounceMs\n });\n this.log('info', 'Guardian is watching for changes...', { \n directories: this.watchers.size \n });\n\n // Handle graceful shutdown\n process.on('SIGINT', () => this.shutdown('SIGINT'));\n process.on('SIGTERM', () => this.shutdown('SIGTERM'));\n }\n\n /**\n * Run a scan on all files or specific files\n */\n private async runScan(files?: string[]): Promise<void> {\n try {\n const scanArgs: Record<string, unknown> = files\n ? { files }\n : { directory: this.config.directory };\n\n if (this.config.format) scanArgs.format = this.config.format;\n if (this.config.output) scanArgs.output = this.config.output;\n if (this.config.parallel !== undefined) scanArgs.parallel = this.config.parallel;\n if (this.config.cache !== undefined) scanArgs.cache = this.config.cache;\n if (this.config.maxConcurrency) scanArgs.maxConcurrency = this.config.maxConcurrency;\n if (this.config.streaming !== undefined) scanArgs.streaming = this.config.streaming;\n if (this.config.interactive !== undefined) scanArgs.interactive = this.config.interactive;\n if (this.config.workers !== undefined) scanArgs.workers = this.config.workers;\n if (this.config.timeoutMs) scanArgs.timeoutMs = this.config.timeoutMs;\n if (this.config.forceScouts) scanArgs.forceAgents = this.config.forceScouts;\n // Get Guardian config from dashboard if available, otherwise use CLI args\n if (this.dashboard && typeof this.dashboard.getGuardianConfig === 'function') {\n const guardianConfig = this.dashboard.getGuardianConfig();\n\n // Moneybags config (CLI args can override dashboard config)\n scanArgs.userCount = this.config.userCount || guardianConfig.moneybags.userCount;\n scanArgs.moneybagsConfig = {\n userCount: this.config.userCount || guardianConfig.moneybags.userCount,\n payingUsers: guardianConfig.moneybags.payingUsers,\n revenuePerUser: guardianConfig.moneybags.revenuePerUser,\n developerRate: guardianConfig.moneybags.developerRate,\n industry: this.config.industry || guardianConfig.moneybags.industry as 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce' | undefined\n };\n \n // Agent Smith config\n scanArgs.agentSmithConfig = {\n aiEnhancement: guardianConfig.agentSmith.aiEnhancement,\n minSeverity: guardianConfig.agentSmith.minSeverity,\n enabledCategories: { ...guardianConfig.agentSmith.enabledCategories },\n memoryRetentionDays: guardianConfig.agentSmith.memoryRetentionDays\n };\n \n // Performance config\n scanArgs.parallel = guardianConfig.performance.parallel;\n scanArgs.cache = guardianConfig.performance.cache;\n scanArgs.maxConcurrency = guardianConfig.performance.maxConcurrency;\n scanArgs.timeoutMs = guardianConfig.performance.timeoutMs;\n scanArgs.workers = guardianConfig.performance.workers;\n scanArgs.streaming = guardianConfig.performance.streaming;\n } else {\n // Use CLI args when not in interactive dashboard mode\n if (this.config.userCount || this.config.industry) {\n scanArgs.userCount = this.config.userCount;\n scanArgs.moneybagsConfig = {\n userCount: this.config.userCount || 250,\n ...(this.config.industry && { industry: this.config.industry })\n };\n }\n }\n\n if (this.streamingManager) scanArgs.streamingManager = this.streamingManager;\n if (this.dashboard) scanArgs.dashboard = this.dashboard;\n\n const result = await this.scanTool.execute(scanArgs);\n const resultText = result.content?.[0]?.text || '';\n\n // PRINT THE FULL REPORT TO STDOUT (for terminal/chat display)\n if (resultText && this.config.runOnce && !isInteractiveMode()) {\n console.log(resultText);\n }\n\n // Parse results - try multiple patterns to extract issue count\n let issueCount = 0;\n if (this.config.format === 'json' && this.config.output && existsSync(this.config.output)) {\n try {\n const report = JSON.parse(readFileSync(this.config.output, 'utf-8'));\n issueCount = report?.results?.totalIssues ?? 0;\n } catch {\n issueCount = 0;\n }\n } else {\n // Try multiple patterns to catch issue counts\n const patterns = [\n /(\\d+)\\s+actionable\\s+issues?\\s+found/i, // \"30 actionable issues found\"\n /(\\d+)\\s+Issues?\\s+Found/i, // \"30 Issues Found\"\n /Found\\s+(\\d+)\\s+issues?/i, // \"Found 30 issues\"\n /\\[COMPLETE\\]\\s+(\\d+)\\s+issues?/i, // \"[COMPLETE] 30 issues\"\n /(\\d+)\\s+total/i, // \"30 total\" (fallback)\n ];\n \n for (const pattern of patterns) {\n const match = resultText.match(pattern);\n if (match && match[1]) {\n issueCount = parseInt(match[1], 10);\n break;\n }\n }\n }\n\n this.stats.filesScanned += files?.length || 1;\n this.stats.issuesFound += issueCount;\n\n // Don't log \"No issues found\" after a full scan that displayed a report\n // The report already shows the issue count prominently\n if (issueCount > 0) {\n // Parse severity breakdown for additional logging\n const criticalMatch = resultText.match(/(\\d+)\\s+critical/i);\n const seriousMatch = resultText.match(/(\\d+)\\s+serious|(\\d+)\\s+important/i);\n\n if (criticalMatch && criticalMatch[1] && parseInt(criticalMatch[1], 10) > 0) {\n this.log('error', 'Critical issues detected', { count: parseInt(criticalMatch[1], 10) });\n }\n if (seriousMatch && (seriousMatch[1] || seriousMatch[2])) {\n const count = parseInt(seriousMatch[1] || seriousMatch[2] || '0', 10);\n if (count > 0) {\n this.log('warn', 'Serious issues detected', { count });\n }\n }\n }\n // NOTE: Removed the \"No issues found\" log because it was confusing\n // when printed after a full scan report that already shows issue counts\n } catch (error) {\n this.stats.errors++;\n this.log('error', 'Scan failed', { \n error: error instanceof Error ? error.message : String(error) \n });\n }\n }\n\n /**\n * Watch a directory recursively\n */\n private async watchDirectory(dir: string): Promise<void> {\n if (!existsSync(dir)) return;\n\n try {\n const stat = statSync(dir);\n if (!stat.isDirectory()) return;\n\n const dirName = basename(dir);\n if (SKIP_DIRS.has(dirName) || dirName.startsWith('.')) return;\n\n // Watch this directory\n const watcher = watch(dir, { persistent: true }, (_eventType, filename) => {\n if (!filename) return;\n\n const fullPath = join(dir, filename);\n const ext = extname(filename).toLowerCase();\n\n if (!WATCH_EXTENSIONS.has(ext)) return;\n if (!existsSync(fullPath)) return;\n\n this.pendingFiles.add(fullPath);\n this.streamingManager?.reportWatchChange(fullPath);\n this.scheduleProcessing();\n });\n\n this.watchers.set(dir, watcher);\n\n // Recursively watch subdirectories\n const entries = await readdir(dir, { withFileTypes: true });\n for (const entry of entries) {\n if (entry.isDirectory()) {\n await this.watchDirectory(join(dir, entry.name));\n }\n }\n } catch (error) {\n // Skip inaccessible directories\n }\n }\n\n /**\n * Schedule processing of pending files (debounced)\n */\n private scheduleProcessing(): void {\n if (this.debounceTimer) {\n clearTimeout(this.debounceTimer);\n }\n\n this.debounceTimer = setTimeout(() => {\n this.processPendingFiles();\n }, this.config.debounceMs);\n }\n\n /**\n * Process all pending files\n */\n private async processPendingFiles(): Promise<void> {\n if (this.isProcessing || this.pendingFiles.size === 0) return;\n\n this.isProcessing = true;\n const files = Array.from(this.pendingFiles);\n this.pendingFiles.clear();\n\n this.log('info', 'Processing changed files', { \n count: files.length,\n files: files.map(f => basename(f))\n });\n\n await this.runScan(files);\n this.isProcessing = false;\n }\n\n /**\n * Recalculate Moneybags costs with updated settings\n * This re-runs only the Moneybags agent on previously scanned issues\n */\n private recalculateMoneybags(): void {\n // Trigger a rescan with Moneybags-only focus\n // We re-use the existing scan infrastructure but the dashboard will \n // already have the new config values ready\n this.log('info', 'Recalculating Moneybags costs with new settings...');\n \n // Run a full scan with updated Moneybags config\n // The scan will pick up the new config from dashboard.getGuardianConfig()\n void this.runScan(this.config.files);\n }\n\n /**\n * Log a message\n */\n private log(level: 'info' | 'warn' | 'error', message: string, data?: Record<string, unknown>): void {\n const timestamp = new Date().toISOString();\n const uptime = Math.round((Date.now() - this.stats.startTime) / 1000);\n\n // Suppress human-readable logs when interactive dashboard is active\n if (!this.config.jsonOutput && isInteractiveMode()) {\n return;\n }\n\n if (this.config.jsonOutput) {\n console.log(JSON.stringify({\n timestamp,\n level,\n message,\n uptime,\n ...data,\n stats: this.stats\n }));\n } else {\n const levelEmoji = { info: '[i]', warn: '[!]', error: '[X]' }[level];\n const dataStr = data ? ` ${JSON.stringify(data)}` : '';\n console.log(`[${timestamp}] ${levelEmoji} ${message}${dataStr}`);\n }\n }\n\n /**\n * Graceful shutdown\n */\n private shutdown(signal: string): void {\n this.log('info', 'Shutting down', { signal, stats: this.stats });\n\n // Close all watchers\n for (const watcher of this.watchers.values()) {\n watcher.close();\n }\n\n // Clear timers\n if (this.debounceTimer) {\n clearTimeout(this.debounceTimer);\n }\n\n if (this.streamingManager) {\n this.streamingManager.reportWatchStatus({\n watching: false,\n directories: 0\n });\n }\n if (this.dashboard) {\n this.dashboard.stop();\n }\n\n process.exit(0);\n }\n}\n\n/**\n * Parse command line arguments\n */\nfunction parseArgs(): DaemonConfig {\n const args = process.argv.slice(2);\n const config: DaemonConfig = {\n // Silent mode for initial workspace detection (TUI will handle display)\n directory: getWorkingDirectory(undefined, true),\n debounceMs: 1000,\n jsonOutput: false,\n runOnce: false,\n // Default to interactive mode for TTY terminals\n interactive: process.stdout.isTTY === true\n };\n\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n const nextArg = args[i + 1];\n\n switch (arg) {\n case '--dir':\n case '-d':\n config.directory = resolve(nextArg || '.');\n i++;\n break;\n case '--debounce':\n case '-D':\n config.debounceMs = parseInt(nextArg || '1000', 10);\n i++;\n break;\n case '--json':\n config.jsonOutput = true;\n break;\n case '--format':\n if (nextArg) {\n config.format = nextArg === 'json' ? 'json' : 'text';\n i++;\n }\n break;\n case '--output':\n if (nextArg) {\n config.output = nextArg;\n i++;\n }\n break;\n case '--parallel':\n config.parallel = true;\n break;\n case '--no-parallel':\n config.parallel = false;\n break;\n case '--cache':\n config.cache = true;\n break;\n case '--no-cache':\n config.cache = false;\n break;\n case '--max-concurrency':\n config.maxConcurrency = parseInt(nextArg || '4', 10);\n i++;\n break;\n case '--streaming':\n config.streaming = true;\n break;\n case '--no-streaming':\n config.streaming = false;\n break;\n case '--interactive':\n config.interactive = true;\n break;\n case '--no-interactive':\n config.interactive = false;\n break;\n case '--workers':\n config.workers = true;\n break;\n case '--no-workers':\n config.workers = false;\n break;\n case '--timeout':\n config.timeoutMs = parseInt(nextArg || '120000', 10);\n i++;\n break;\n case '--files':\n if (nextArg) {\n config.files = nextArg.split(',').map(f => f.trim()).filter(Boolean);\n i++;\n }\n break;\n case '--scouts':\n case '--agents': // Alias for backward compatibility\n if (nextArg) {\n config.forceScouts = nextArg.split(',').map(s => s.trim()).filter(Boolean);\n i++;\n }\n break;\n case '--once':\n config.runOnce = true;\n break;\n case '--users':\n case '-u':\n config.userCount = parseInt(nextArg || '250', 10);\n i++;\n break;\n case '--industry':\n if (nextArg && ['solopreneur', 'startup', 'fintech', 'healthcare', 'enterprise', 'saas', 'ecommerce'].includes(nextArg)) {\n config.industry = nextArg as 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce';\n i++;\n } else {\n if (!process.stdout.isTTY || process.argv.includes('--non-interactive')) {\n console.error(`Invalid industry: ${nextArg || '(none)'}`);\n console.error('Valid options: solopreneur, startup, fintech, healthcare, enterprise, saas, ecommerce');\n }\n process.exit(1);\n }\n break;\n case '--help':\n case '-h':\n console.log(`\nTrie Guardian - File Watcher & Scanner\n\nUSAGE:\n trie watch [options] Watch for changes and scan continuously\n trie scan [options] Scan once and exit\n\nOPTIONS:\n --dir, -d <path> Directory to watch/scan (default: current directory)\n --debounce, -D <ms> Debounce time in ms (default: 1000)\n --scouts <list> Comma-separated scouts to run (e.g., security,privacy)\n --agents <list> Alias for --scouts (backward compatibility)\n --files <list> Comma-separated file list to scan\n --users, -u <count> User count for cost estimation (default: 250)\n --industry <type> Industry type for cost scaling (solopreneur, startup, fintech, healthcare, enterprise, saas, ecommerce)\n\nOUTPUT:\n --json Output as JSON (for log aggregation)\n --format <text|json> Scan output format\n --output <path> Output file path for json format\n\nPERFORMANCE:\n --parallel Enable parallel execution\n --no-parallel Disable parallel execution\n --cache Enable result caching\n --no-cache Disable result caching\n --max-concurrency <n> Max parallel scouts\n --streaming Enable streaming updates\n --no-streaming Disable streaming updates\n --workers Use worker threads for scouts\n --no-workers Disable worker threads\n --timeout <ms> Scout timeout in ms\n\nDISPLAY:\n --interactive Enable interactive dashboard (default for TTY)\n --no-interactive Disable interactive dashboard (for CI/scripts)\n\nEXAMPLES:\n trie watch # Watch current directory\n trie scan # Scan once and exit\n trie scan --scouts security,privacy # Scan with specific scouts\n trie scan --users 1000 --industry fintech # Scale for fintech with 1K users\n trie watch --no-interactive # CI mode: watch without dashboard\n trie scan --json --output report.json\n`);\n process.exit(0);\n }\n }\n\n return config;\n}\n\n// Run the daemon\nconst config = parseArgs();\nconst daemon = new WatchDaemon(config);\ndaemon.start().catch(error => {\n if (!process.stdout.isTTY || process.argv.includes('--non-interactive')) {\n console.error('Failed to start daemon:', error);\n }\n process.exit(1);\n});\n"],"mappings":"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","names":["config"]}
1
+ {"version":3,"sources":["../../src/cli/yolo-daemon.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Trie Guardian - File Watcher & Scanner\n * \n * Watches a directory and reports issues as they occur.\n * Also handles one-shot scanning via --once flag.\n * \n * Usage:\n * trie watch [options] # Watch for changes\n * trie scan [options] # Scan once and exit\n * \n * See `trie watch --help` for all options.\n */\n\nimport { watch, existsSync, statSync, readFileSync } from 'fs';\nimport { readdir } from 'fs/promises';\nimport { join, extname, basename, resolve } from 'path';\nimport { TrieScanTool } from '../tools/scan.js';\nimport { StreamingManager } from '../utils/streaming.js';\nimport { InteractiveDashboard } from './interactive-dashboard.js';\nimport { getWorkingDirectory } from '../utils/workspace.js';\nimport { isInteractiveMode, setInteractiveMode } from '../utils/progress.js';\nimport { isTrieInitialized } from '../utils/trie-init.js';\n\n// File extensions to watch\nconst WATCH_EXTENSIONS = new Set([\n '.ts', '.tsx', '.js', '.jsx', '.mjs',\n '.vue', '.svelte', '.astro',\n '.py', '.go', '.rs'\n]);\n\n// Directories to skip\nconst SKIP_DIRS = new Set([\n 'node_modules', '.git', 'dist', 'build', '.next', '.nuxt',\n 'coverage', '.turbo', '.cache', '__pycache__', '.venv'\n]);\n\ninterface DaemonConfig {\n directory: string;\n debounceMs: number;\n jsonOutput: boolean;\n runOnce: boolean;\n format?: 'text' | 'json';\n output?: string;\n parallel?: boolean;\n cache?: boolean;\n maxConcurrency?: number;\n streaming?: boolean;\n interactive?: boolean;\n workers?: boolean;\n timeoutMs?: number;\n files?: string[];\n /** Comma-separated list of scouts to run (e.g., \"security,privacy\") */\n forceScouts?: string[];\n /** User count for cost estimation (default: 250) */\n userCount?: number;\n /** Industry for Moneybags cost scaling */\n industry?: 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce';\n}\n\ninterface DaemonStats {\n filesScanned: number;\n issuesFound: number;\n errors: number;\n startTime: number;\n}\n\nclass WatchDaemon {\n private config: DaemonConfig;\n private stats: DaemonStats;\n private scanTool = new TrieScanTool();\n private watchers: Map<string, ReturnType<typeof watch>> = new Map();\n private pendingFiles: Set<string> = new Set();\n private debounceTimer: NodeJS.Timeout | null = null;\n private isProcessing = false;\n private streamingManager: StreamingManager | undefined = undefined;\n private dashboard: InteractiveDashboard | undefined = undefined;\n\n constructor(config: DaemonConfig) {\n this.config = config;\n this.stats = {\n filesScanned: 0,\n issuesFound: 0,\n errors: 0,\n startTime: Date.now()\n };\n }\n\n /**\n * Start the daemon\n */\n async start(): Promise<void> {\n // Enable global interactive mode when TTY and not explicitly disabled\n if (this.config.interactive !== false && process.stdout.isTTY) {\n setInteractiveMode(true);\n }\n if (!isTrieInitialized(this.config.directory)) {\n if (!isInteractiveMode()) {\n console.error('Trie is not initialized for this project.');\n console.error('Run `trie init` first.');\n }\n process.exit(1);\n }\n\n this.log('info', 'Starting Trie Agent', {\n directory: this.config.directory,\n debounceMs: this.config.debounceMs\n });\n if (!isInteractiveMode()) {\n console.error('\\nYour Trie agent is watching over your codebase.\\n');\n }\n\n // Validate directory\n if (!existsSync(this.config.directory)) {\n this.log('error', 'Directory not found', { directory: this.config.directory });\n process.exit(1);\n }\n\n // Start interactive dashboard if enabled\n if (isInteractiveMode()) {\n this.streamingManager = new StreamingManager();\n this.dashboard = new InteractiveDashboard();\n this.streamingManager.subscribe(update => this.dashboard?.handleStreamUpdate(update));\n \n // Register callback for Moneybags settings changes\n this.dashboard.onMoneybagsChange(() => {\n this.recalculateMoneybags();\n });\n \n await this.dashboard.start();\n this.streamingManager.reportWatchStatus({\n watching: !this.config.runOnce,\n directories: 0,\n debounceMs: this.config.debounceMs\n });\n }\n\n // Run initial scan\n this.log('info', 'Running initial scan...');\n await this.runScan(this.config.files);\n\n // If run-once mode, exit after initial scan\n if (this.config.runOnce) {\n this.log('info', 'Run-once mode: exiting after initial scan', { ...this.stats });\n process.exit(this.stats.issuesFound > 0 ? 1 : 0);\n }\n\n // Start watching\n await this.watchDirectory(this.config.directory);\n this.streamingManager?.reportWatchStatus({\n watching: true,\n directories: this.watchers.size,\n debounceMs: this.config.debounceMs\n });\n this.log('info', 'Guardian is watching for changes...', { \n directories: this.watchers.size \n });\n\n // Handle graceful shutdown\n process.on('SIGINT', () => this.shutdown('SIGINT'));\n process.on('SIGTERM', () => this.shutdown('SIGTERM'));\n }\n\n /**\n * Run a scan on all files or specific files\n */\n private async runScan(files?: string[]): Promise<void> {\n try {\n const scanArgs: Record<string, unknown> = files\n ? { files }\n : { directory: this.config.directory };\n\n if (this.config.format) scanArgs.format = this.config.format;\n if (this.config.output) scanArgs.output = this.config.output;\n if (this.config.parallel !== undefined) scanArgs.parallel = this.config.parallel;\n if (this.config.cache !== undefined) scanArgs.cache = this.config.cache;\n if (this.config.maxConcurrency) scanArgs.maxConcurrency = this.config.maxConcurrency;\n if (this.config.streaming !== undefined) scanArgs.streaming = this.config.streaming;\n if (this.config.interactive !== undefined) scanArgs.interactive = this.config.interactive;\n if (this.config.workers !== undefined) scanArgs.workers = this.config.workers;\n if (this.config.timeoutMs) scanArgs.timeoutMs = this.config.timeoutMs;\n if (this.config.forceScouts) scanArgs.forceAgents = this.config.forceScouts;\n // Get Guardian config from dashboard if available, otherwise use CLI args\n if (this.dashboard && typeof this.dashboard.getGuardianConfig === 'function') {\n const guardianConfig = this.dashboard.getGuardianConfig();\n\n // Moneybags config (CLI args can override dashboard config)\n scanArgs.userCount = this.config.userCount || guardianConfig.moneybags.userCount;\n scanArgs.moneybagsConfig = {\n userCount: this.config.userCount || guardianConfig.moneybags.userCount,\n payingUsers: guardianConfig.moneybags.payingUsers,\n revenuePerUser: guardianConfig.moneybags.revenuePerUser,\n developerRate: guardianConfig.moneybags.developerRate,\n industry: this.config.industry || guardianConfig.moneybags.industry as 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce' | undefined\n };\n \n // Agent Smith config\n scanArgs.agentSmithConfig = {\n aiEnhancement: guardianConfig.agentSmith.aiEnhancement,\n minSeverity: guardianConfig.agentSmith.minSeverity,\n enabledCategories: { ...guardianConfig.agentSmith.enabledCategories },\n memoryRetentionDays: guardianConfig.agentSmith.memoryRetentionDays\n };\n \n // Performance config\n scanArgs.parallel = guardianConfig.performance.parallel;\n scanArgs.cache = guardianConfig.performance.cache;\n scanArgs.maxConcurrency = guardianConfig.performance.maxConcurrency;\n scanArgs.timeoutMs = guardianConfig.performance.timeoutMs;\n scanArgs.workers = guardianConfig.performance.workers;\n scanArgs.streaming = guardianConfig.performance.streaming;\n } else {\n // Use CLI args when not in interactive dashboard mode\n if (this.config.userCount || this.config.industry) {\n scanArgs.userCount = this.config.userCount;\n scanArgs.moneybagsConfig = {\n userCount: this.config.userCount || 250,\n ...(this.config.industry && { industry: this.config.industry })\n };\n }\n }\n\n if (this.streamingManager) scanArgs.streamingManager = this.streamingManager;\n if (this.dashboard) scanArgs.dashboard = this.dashboard;\n\n const result = await this.scanTool.execute(scanArgs);\n const resultText = result.content?.[0]?.text || '';\n\n // PRINT THE FULL REPORT TO STDOUT (for terminal/chat display)\n if (resultText && this.config.runOnce && !isInteractiveMode()) {\n console.log(resultText);\n }\n\n // Parse results - try multiple patterns to extract issue count\n let issueCount = 0;\n if (this.config.format === 'json' && this.config.output && existsSync(this.config.output)) {\n try {\n const report = JSON.parse(readFileSync(this.config.output, 'utf-8'));\n issueCount = report?.results?.totalIssues ?? 0;\n } catch {\n issueCount = 0;\n }\n } else {\n // Try multiple patterns to catch issue counts\n const patterns = [\n /(\\d+)\\s+actionable\\s+issues?\\s+found/i, // \"30 actionable issues found\"\n /(\\d+)\\s+Issues?\\s+Found/i, // \"30 Issues Found\"\n /Found\\s+(\\d+)\\s+issues?/i, // \"Found 30 issues\"\n /\\[COMPLETE\\]\\s+(\\d+)\\s+issues?/i, // \"[COMPLETE] 30 issues\"\n /(\\d+)\\s+total/i, // \"30 total\" (fallback)\n ];\n \n for (const pattern of patterns) {\n const match = resultText.match(pattern);\n if (match && match[1]) {\n issueCount = parseInt(match[1], 10);\n break;\n }\n }\n }\n\n this.stats.filesScanned += files?.length || 1;\n this.stats.issuesFound += issueCount;\n\n // Don't log \"No issues found\" after a full scan that displayed a report\n // The report already shows the issue count prominently\n if (issueCount > 0) {\n // Parse severity breakdown for additional logging\n const criticalMatch = resultText.match(/(\\d+)\\s+critical/i);\n const seriousMatch = resultText.match(/(\\d+)\\s+serious|(\\d+)\\s+important/i);\n\n if (criticalMatch && criticalMatch[1] && parseInt(criticalMatch[1], 10) > 0) {\n this.log('error', 'Critical issues detected', { count: parseInt(criticalMatch[1], 10) });\n }\n if (seriousMatch && (seriousMatch[1] || seriousMatch[2])) {\n const count = parseInt(seriousMatch[1] || seriousMatch[2] || '0', 10);\n if (count > 0) {\n this.log('warn', 'Serious issues detected', { count });\n }\n }\n }\n // NOTE: Removed the \"No issues found\" log because it was confusing\n // when printed after a full scan report that already shows issue counts\n } catch (error) {\n this.stats.errors++;\n this.log('error', 'Scan failed', { \n error: error instanceof Error ? error.message : String(error) \n });\n }\n }\n\n /**\n * Watch a directory recursively\n */\n private async watchDirectory(dir: string): Promise<void> {\n if (!existsSync(dir)) return;\n\n try {\n const stat = statSync(dir);\n if (!stat.isDirectory()) return;\n\n const dirName = basename(dir);\n if (SKIP_DIRS.has(dirName) || dirName.startsWith('.')) return;\n\n // Watch this directory\n const watcher = watch(dir, { persistent: true }, (_eventType, filename) => {\n if (!filename) return;\n\n const fullPath = join(dir, filename);\n const ext = extname(filename).toLowerCase();\n\n if (!WATCH_EXTENSIONS.has(ext)) return;\n if (!existsSync(fullPath)) return;\n\n this.pendingFiles.add(fullPath);\n this.streamingManager?.reportWatchChange(fullPath);\n this.scheduleProcessing();\n });\n\n this.watchers.set(dir, watcher);\n\n // Recursively watch subdirectories\n const entries = await readdir(dir, { withFileTypes: true });\n for (const entry of entries) {\n if (entry.isDirectory()) {\n await this.watchDirectory(join(dir, entry.name));\n }\n }\n } catch (error) {\n // Skip inaccessible directories\n }\n }\n\n /**\n * Schedule processing of pending files (debounced)\n */\n private scheduleProcessing(): void {\n if (this.debounceTimer) {\n clearTimeout(this.debounceTimer);\n }\n\n this.debounceTimer = setTimeout(() => {\n this.processPendingFiles();\n }, this.config.debounceMs);\n }\n\n /**\n * Process all pending files\n */\n private async processPendingFiles(): Promise<void> {\n if (this.isProcessing || this.pendingFiles.size === 0) return;\n\n this.isProcessing = true;\n const files = Array.from(this.pendingFiles);\n this.pendingFiles.clear();\n\n this.log('info', 'Processing changed files', { \n count: files.length,\n files: files.map(f => basename(f))\n });\n\n await this.runScan(files);\n this.isProcessing = false;\n }\n\n /**\n * Recalculate Moneybags costs with updated settings\n * This re-runs only the Moneybags agent on previously scanned issues\n */\n private recalculateMoneybags(): void {\n // Trigger a rescan with Moneybags-only focus\n // We re-use the existing scan infrastructure but the dashboard will \n // already have the new config values ready\n this.log('info', 'Recalculating Moneybags costs with new settings...');\n \n // Run a full scan with updated Moneybags config\n // The scan will pick up the new config from dashboard.getGuardianConfig()\n void this.runScan(this.config.files);\n }\n\n /**\n * Log a message\n */\n private log(level: 'info' | 'warn' | 'error', message: string, data?: Record<string, unknown>): void {\n const timestamp = new Date().toISOString();\n const uptime = Math.round((Date.now() - this.stats.startTime) / 1000);\n\n // Suppress human-readable logs when interactive dashboard is active\n if (!this.config.jsonOutput && isInteractiveMode()) {\n return;\n }\n\n if (this.config.jsonOutput) {\n console.log(JSON.stringify({\n timestamp,\n level,\n message,\n uptime,\n ...data,\n stats: this.stats\n }));\n } else {\n const levelEmoji = { info: '[i]', warn: '[!]', error: '[X]' }[level];\n const dataStr = data ? ` ${JSON.stringify(data)}` : '';\n console.log(`[${timestamp}] ${levelEmoji} ${message}${dataStr}`);\n }\n }\n\n /**\n * Graceful shutdown\n */\n private shutdown(signal: string): void {\n this.log('info', 'Shutting down', { signal, stats: this.stats });\n\n // Close all watchers\n for (const watcher of this.watchers.values()) {\n watcher.close();\n }\n\n // Clear timers\n if (this.debounceTimer) {\n clearTimeout(this.debounceTimer);\n }\n\n if (this.streamingManager) {\n this.streamingManager.reportWatchStatus({\n watching: false,\n directories: 0\n });\n }\n if (this.dashboard) {\n this.dashboard.stop();\n }\n\n process.exit(0);\n }\n}\n\n/**\n * Parse command line arguments\n */\nfunction parseArgs(): DaemonConfig {\n const args = process.argv.slice(2);\n const config: DaemonConfig = {\n // Silent mode for initial workspace detection (TUI will handle display)\n directory: getWorkingDirectory(undefined, true),\n debounceMs: 1000,\n jsonOutput: false,\n runOnce: false,\n // Default to interactive mode for TTY terminals\n interactive: process.stdout.isTTY === true\n };\n\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n const nextArg = args[i + 1];\n\n switch (arg) {\n case '--dir':\n case '-d':\n config.directory = resolve(nextArg || '.');\n i++;\n break;\n case '--debounce':\n case '-D':\n config.debounceMs = parseInt(nextArg || '1000', 10);\n i++;\n break;\n case '--json':\n config.jsonOutput = true;\n break;\n case '--format':\n if (nextArg) {\n config.format = nextArg === 'json' ? 'json' : 'text';\n i++;\n }\n break;\n case '--output':\n if (nextArg) {\n config.output = nextArg;\n i++;\n }\n break;\n case '--parallel':\n config.parallel = true;\n break;\n case '--no-parallel':\n config.parallel = false;\n break;\n case '--cache':\n config.cache = true;\n break;\n case '--no-cache':\n config.cache = false;\n break;\n case '--force-rescan':\n case '--force':\n config.cache = false; // Force rescan by disabling cache\n break;\n case '--max-concurrency':\n config.maxConcurrency = parseInt(nextArg || '4', 10);\n i++;\n break;\n case '--streaming':\n config.streaming = true;\n break;\n case '--no-streaming':\n config.streaming = false;\n break;\n case '--interactive':\n config.interactive = true;\n break;\n case '--no-interactive':\n config.interactive = false;\n break;\n case '--workers':\n config.workers = true;\n break;\n case '--no-workers':\n config.workers = false;\n break;\n case '--timeout':\n config.timeoutMs = parseInt(nextArg || '120000', 10);\n i++;\n break;\n case '--files':\n if (nextArg) {\n config.files = nextArg.split(',').map(f => f.trim()).filter(Boolean);\n i++;\n }\n break;\n case '--scouts':\n case '--agents': // Alias for backward compatibility\n if (nextArg) {\n config.forceScouts = nextArg.split(',').map(s => s.trim()).filter(Boolean);\n i++;\n }\n break;\n case '--once':\n config.runOnce = true;\n break;\n case '--users':\n case '-u':\n config.userCount = parseInt(nextArg || '250', 10);\n i++;\n break;\n case '--industry':\n if (nextArg && ['solopreneur', 'startup', 'fintech', 'healthcare', 'enterprise', 'saas', 'ecommerce'].includes(nextArg)) {\n config.industry = nextArg as 'solopreneur' | 'startup' | 'fintech' | 'healthcare' | 'enterprise' | 'saas' | 'ecommerce';\n i++;\n } else {\n if (!process.stdout.isTTY || process.argv.includes('--non-interactive')) {\n console.error(`Invalid industry: ${nextArg || '(none)'}`);\n console.error('Valid options: solopreneur, startup, fintech, healthcare, enterprise, saas, ecommerce');\n }\n process.exit(1);\n }\n break;\n case '--help':\n case '-h':\n console.log(`\nTrie Guardian - File Watcher & Scanner\n\nUSAGE:\n trie watch [options] Watch for changes and scan continuously\n trie scan [options] Scan once and exit\n\nOPTIONS:\n --dir, -d <path> Directory to watch/scan (default: current directory)\n --debounce, -D <ms> Debounce time in ms (default: 1000)\n --scouts <list> Comma-separated scouts to run (e.g., security,privacy)\n --agents <list> Alias for --scouts (backward compatibility)\n --files <list> Comma-separated file list to scan\n --users, -u <count> User count for cost estimation (default: 250)\n --industry <type> Industry type for cost scaling (solopreneur, startup, fintech, healthcare, enterprise, saas, ecommerce)\n\nOUTPUT:\n --json Output as JSON (for log aggregation)\n --format <text|json> Scan output format\n --output <path> Output file path for json format\n\nPERFORMANCE:\n --parallel Enable parallel execution\n --no-parallel Disable parallel execution\n --cache Enable result caching\n --no-cache Disable result caching\n --force-rescan Force rescan (bypasses cache, same as --no-cache)\n --max-concurrency <n> Max parallel scouts\n --streaming Enable streaming updates\n --no-streaming Disable streaming updates\n --workers Use worker threads for scouts\n --no-workers Disable worker threads\n --timeout <ms> Scout timeout in ms\n\nDISPLAY:\n --interactive Enable interactive dashboard (default for TTY)\n --no-interactive Disable interactive dashboard (for CI/scripts)\n\nEXAMPLES:\n trie watch # Watch current directory\n trie scan # Scan once and exit\n trie scan --scouts security,privacy # Scan with specific scouts\n trie scan --users 1000 --industry fintech # Scale for fintech with 1K users\n trie watch --no-interactive # CI mode: watch without dashboard\n trie scan --json --output report.json\n`);\n process.exit(0);\n }\n }\n\n return config;\n}\n\n// Run the daemon\nconst config = parseArgs();\nconst daemon = new WatchDaemon(config);\ndaemon.start().catch(error => {\n if (!process.stdout.isTTY || process.argv.includes('--non-interactive')) {\n console.error('Failed to start daemon:', error);\n }\n process.exit(1);\n});\n"],"mappings":"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","names":["config"]}
@@ -0,0 +1,29 @@
1
+ import {
2
+ getChangedFilesSinceTimestamp,
3
+ getDiff,
4
+ getLastCommit,
5
+ getRecentCommits,
6
+ getStagedChanges,
7
+ getUncommittedChanges,
8
+ getUnpushedCommits,
9
+ getWorkingTreeDiff,
10
+ isGitRepo,
11
+ resolveRepoPath
12
+ } from "./chunk-76Q5DMYV.js";
13
+ import "./chunk-MURGTWG4.js";
14
+ import "./chunk-RDOJCRKJ.js";
15
+ import "./chunk-D25EIBPO.js";
16
+ import "./chunk-DGUM43GV.js";
17
+ export {
18
+ getChangedFilesSinceTimestamp,
19
+ getDiff,
20
+ getLastCommit,
21
+ getRecentCommits,
22
+ getStagedChanges,
23
+ getUncommittedChanges,
24
+ getUnpushedCommits,
25
+ getWorkingTreeDiff,
26
+ isGitRepo,
27
+ resolveRepoPath
28
+ };
29
+ //# sourceMappingURL=git-5WJHCMNO.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
package/dist/index.js CHANGED
@@ -24,18 +24,20 @@ import {
24
24
  reasonAboutChangesHumanReadable,
25
25
  saveCheckpoint,
26
26
  trackIssueOccurrence
27
- } from "./chunk-6OJRG7MM.js";
27
+ } from "./chunk-ZOKQJZKN.js";
28
28
  import {
29
29
  InteractiveDashboard,
30
30
  StreamingManager,
31
31
  TrieScanTool
32
- } from "./chunk-LAGXOPXN.js";
32
+ } from "./chunk-3HDWOSLX.js";
33
33
  import "./chunk-PSVRO76R.js";
34
34
  import "./chunk-NMGINYYX.js";
35
35
  import {
36
36
  isTrieInitialized,
37
37
  loadConfig
38
- } from "./chunk-3EZ2ETKG.js";
38
+ } from "./chunk-R6YM6YSV.js";
39
+ import "./chunk-HFQ5ORON.js";
40
+ import "./chunk-76Q5DMYV.js";
39
41
  import {
40
42
  ContextGraph
41
43
  } from "./chunk-P6XMIUD7.js";
@@ -55,9 +57,11 @@ import {
55
57
  loadContextState,
56
58
  loadProjectInfo,
57
59
  projectInfoExists,
58
- runShellCommandSync,
59
60
  updateProjectSection
60
- } from "./chunk-7IEGGW4L.js";
61
+ } from "./chunk-5DQLHWTT.js";
62
+ import {
63
+ runShellCommandSync
64
+ } from "./chunk-MURGTWG4.js";
61
65
  import {
62
66
  findCrossProjectPatterns,
63
67
  getGlobalMemoryStats,
@@ -76,7 +80,7 @@ import "./chunk-IYMJTY27.js";
76
80
  import "./chunk-6NLHFIYA.js";
77
81
  import {
78
82
  getOutputManager
79
- } from "./chunk-XEQRB4XX.js";
83
+ } from "./chunk-KWDNYWOR.js";
80
84
  import "./chunk-74NPKTZV.js";
81
85
  import {
82
86
  getTrieDirectory,
@@ -2626,9 +2630,9 @@ var TrieWatchTool = class {
2626
2630
  this.state.nudges = [];
2627
2631
  if (!isInteractiveMode()) {
2628
2632
  console.error("\n\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501");
2629
- console.error("TRIE GUARDIAN AGENT - NOW WATCHING");
2633
+ console.error("TRIE AGENT - NOW WATCHING");
2630
2634
  console.error("\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\n");
2631
- console.error("Your guardian agent is now watching over your codebase.");
2635
+ console.error("Your Trie agent is now watching over your codebase.");
2632
2636
  console.error(`Watching: ${directory}`);
2633
2637
  console.error(`Debounce: ${debounceMs}ms`);
2634
2638
  console.error("");
@@ -2667,9 +2671,9 @@ var TrieWatchTool = class {
2667
2671
  return {
2668
2672
  content: [{
2669
2673
  type: "text",
2670
- text: `**GUARDIAN AGENT ACTIVATED**
2674
+ text: `**TRIE AGENT ACTIVATED**
2671
2675
 
2672
- Your guardian agent is now watching over your codebase. It will warn you about risky changes, remember what broke before, and nudge you when something looks dangerous.
2676
+ Your Trie agent is now watching over your codebase. It will warn you about risky changes, remember what broke before, and nudge you when something looks dangerous.
2673
2677
 
2674
2678
  **Watching:** \`${directory}\`
2675
2679
  **Debounce:** ${debounceMs}ms (waits for you to stop typing)
@@ -7543,7 +7547,7 @@ npx playwright install chromium
7543
7547
  };
7544
7548
  }
7545
7549
  async handleAgentSmith(smithArgs) {
7546
- const { AgentSmithSkill } = await import("./agent-smith-Q52DFQET.js");
7550
+ const { AgentSmithSkill } = await import("./agent-smith-QYDXPFPJ.js");
7547
7551
  if (smithArgs.clear_memory) {
7548
7552
  const smith = new AgentSmithSkill();
7549
7553
  const result = await smith.clearMemory();
@@ -7571,7 +7575,7 @@ npx playwright install chromium
7571
7575
  }]
7572
7576
  };
7573
7577
  }
7574
- const agentSmithRunner = await import("./agent-smith-runner-BMT3FN7T.js");
7578
+ const agentSmithRunner = await import("./agent-smith-runner-GXGDJTSR.js");
7575
7579
  return await agentSmithRunner.runAgentSmith(smithArgs);
7576
7580
  }
7577
7581
  };