specmem-hardwicksoftware 3.5.99
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +299 -0
- package/LICENSE.md +6406 -0
- package/README.md +539 -0
- package/bin/AegisTheme.cjs +1022 -0
- package/bin/AnsiRenderer.cjs +1055 -0
- package/bin/BoxRenderer.cjs +605 -0
- package/bin/ClaudeLiveScreen.cjs +1299 -0
- package/bin/DashboardModules.cjs +733 -0
- package/bin/LiveScreenCapture.cjs +1012 -0
- package/bin/MemoryBrowserScreen.cjs +1595 -0
- package/bin/TabManager.cjs +1414 -0
- package/bin/checkAgentStatus-fix.patch +30 -0
- package/bin/mcp-socket-client.cjs +462 -0
- package/bin/screen-utils.cjs +106 -0
- package/bin/specmem-autoclaude.cjs +663 -0
- package/bin/specmem-cleanup.cjs +421 -0
- package/bin/specmem-cli.cjs +794 -0
- package/bin/specmem-console-teamcomms-class.cjs +428 -0
- package/bin/specmem-console.cjs +8104 -0
- package/bin/specmem-statusbar.cjs +530 -0
- package/bootstrap.cjs +5065 -0
- package/claude-hooks/agent-chooser-hook.js +179 -0
- package/claude-hooks/agent-chooser-inject.js +121 -0
- package/claude-hooks/agent-loading-hook.js +990 -0
- package/claude-hooks/agent-output-fader.cjs +542 -0
- package/claude-hooks/agent-output-interceptor.js +193 -0
- package/claude-hooks/agent-type-matcher.js +419 -0
- package/claude-hooks/auto-bypass.py +74 -0
- package/claude-hooks/background-completion-silencer.js +134 -0
- package/claude-hooks/bash-auto-background.js +182 -0
- package/claude-hooks/build-cedict-dictionary.mjs +167 -0
- package/claude-hooks/bullshit-radar.cjs +323 -0
- package/claude-hooks/cedict-codes.json +270 -0
- package/claude-hooks/cedict-extracted.json +22632 -0
- package/claude-hooks/claude-watchdog.sh +401 -0
- package/claude-hooks/context-dedup.cjs +144 -0
- package/claude-hooks/context-yeeter.cjs +244 -0
- package/claude-hooks/debug-suffix.cjs +15 -0
- package/claude-hooks/debug2.cjs +7 -0
- package/claude-hooks/drilldown-enforcer.js +242 -0
- package/claude-hooks/english-morphology-standalone.cjs +149 -0
- package/claude-hooks/english-morphology.cjs +152 -0
- package/claude-hooks/extract-translations.mjs +193 -0
- package/claude-hooks/file-claim-enforcer.cjs +293 -0
- package/claude-hooks/file-claim-enforcer.js +293 -0
- package/claude-hooks/find-collisions.cjs +39 -0
- package/claude-hooks/fix-abbreviations.cjs +60 -0
- package/claude-hooks/fix-collisions.cjs +60 -0
- package/claude-hooks/fix-decompressor.cjs +79 -0
- package/claude-hooks/fix-suffixes.cjs +66 -0
- package/claude-hooks/grammar-engine.cjs +159 -0
- package/claude-hooks/input-aware-improver.js +231 -0
- package/claude-hooks/is-agent.cjs +64 -0
- package/claude-hooks/mega-test.cjs +213 -0
- package/claude-hooks/merge-dictionaries.mjs +207 -0
- package/claude-hooks/merged-codes.cjs +22675 -0
- package/claude-hooks/merged-codes.json +22676 -0
- package/claude-hooks/output-cleaner.cjs +388 -0
- package/claude-hooks/post-write-memory-hook.cjs +430 -0
- package/claude-hooks/quick-test.cjs +24 -0
- package/claude-hooks/quick-test2.cjs +24 -0
- package/claude-hooks/remove-bad-codes.cjs +23 -0
- package/claude-hooks/search-reminder-hook.js +90 -0
- package/claude-hooks/semantic-test.cjs +93 -0
- package/claude-hooks/settings.json +445 -0
- package/claude-hooks/smart-context-hook.cjs +547 -0
- package/claude-hooks/smart-context-hook.js +539 -0
- package/claude-hooks/smart-search-interceptor.js +364 -0
- package/claude-hooks/socket-connect-helper.cjs +235 -0
- package/claude-hooks/specmem/sockets/session-start.lock +1 -0
- package/claude-hooks/specmem-context-hook.cjs +357 -0
- package/claude-hooks/specmem-context-hook.js +357 -0
- package/claude-hooks/specmem-drilldown-hook.cjs +480 -0
- package/claude-hooks/specmem-drilldown-hook.js +480 -0
- package/claude-hooks/specmem-drilldown-setter.js +210 -0
- package/claude-hooks/specmem-paths.cjs +213 -0
- package/claude-hooks/specmem-precompact.js +183 -0
- package/claude-hooks/specmem-session-init.sh +33 -0
- package/claude-hooks/specmem-session-start.cjs +498 -0
- package/claude-hooks/specmem-stop-hook.cjs +73 -0
- package/claude-hooks/specmem-stop-hook.js +5 -0
- package/claude-hooks/specmem-team-comms.cjs +434 -0
- package/claude-hooks/specmem-team-member-inject.js +271 -0
- package/claude-hooks/specmem-unified-hook.py +670 -0
- package/claude-hooks/subagent-loading-hook.js +194 -0
- package/claude-hooks/sysprompt-squisher.cjs +167 -0
- package/claude-hooks/task-progress-hook.js +204 -0
- package/claude-hooks/team-comms-enforcer.cjs +585 -0
- package/claude-hooks/test-accuracy.cjs +27 -0
- package/claude-hooks/test-big.cjs +28 -0
- package/claude-hooks/test-inflectors.cjs +39 -0
- package/claude-hooks/test-pluralize.cjs +37 -0
- package/claude-hooks/test-quick.cjs +8 -0
- package/claude-hooks/test-wink.cjs +20 -0
- package/claude-hooks/token-compressor.cjs +940 -0
- package/claude-hooks/use-code-pointers.cjs +279 -0
- package/commands/COMMAND_TOOL_MAP.md +299 -0
- package/commands/specmem-agents.md +412 -0
- package/commands/specmem-autoclaude.md +295 -0
- package/commands/specmem-changes.md +247 -0
- package/commands/specmem-code.md +103 -0
- package/commands/specmem-configteammembercomms.md +322 -0
- package/commands/specmem-drilldown.md +208 -0
- package/commands/specmem-find.md +195 -0
- package/commands/specmem-getdashboard.md +243 -0
- package/commands/specmem-hooks.md +219 -0
- package/commands/specmem-pointers.md +149 -0
- package/commands/specmem-progress.md +287 -0
- package/commands/specmem-remember.md +123 -0
- package/commands/specmem-service.md +349 -0
- package/commands/specmem-stats.md +189 -0
- package/commands/specmem-team-member.md +409 -0
- package/commands/specmem-webdev.md +583 -0
- package/commands/specmem.md +363 -0
- package/dist/autoStart/index.d.ts +214 -0
- package/dist/autoStart/index.d.ts.map +1 -0
- package/dist/autoStart/index.js +883 -0
- package/dist/autoStart/index.js.map +1 -0
- package/dist/claude-sessions/contextRestorationParser.d.ts +74 -0
- package/dist/claude-sessions/contextRestorationParser.d.ts.map +1 -0
- package/dist/claude-sessions/contextRestorationParser.js +570 -0
- package/dist/claude-sessions/contextRestorationParser.js.map +1 -0
- package/dist/claude-sessions/index.d.ts +13 -0
- package/dist/claude-sessions/index.d.ts.map +1 -0
- package/dist/claude-sessions/index.js +11 -0
- package/dist/claude-sessions/index.js.map +1 -0
- package/dist/claude-sessions/sessionIntegration.d.ts +48 -0
- package/dist/claude-sessions/sessionIntegration.d.ts.map +1 -0
- package/dist/claude-sessions/sessionIntegration.js +146 -0
- package/dist/claude-sessions/sessionIntegration.js.map +1 -0
- package/dist/claude-sessions/sessionParser.d.ts +293 -0
- package/dist/claude-sessions/sessionParser.d.ts.map +1 -0
- package/dist/claude-sessions/sessionParser.js +1028 -0
- package/dist/claude-sessions/sessionParser.js.map +1 -0
- package/dist/claude-sessions/sessionWatcher.d.ts +139 -0
- package/dist/claude-sessions/sessionWatcher.d.ts.map +1 -0
- package/dist/claude-sessions/sessionWatcher.js +722 -0
- package/dist/claude-sessions/sessionWatcher.js.map +1 -0
- package/dist/cli/deploy-to-claude.d.ts +56 -0
- package/dist/cli/deploy-to-claude.d.ts.map +1 -0
- package/dist/cli/deploy-to-claude.js +576 -0
- package/dist/cli/deploy-to-claude.js.map +1 -0
- package/dist/code-explanations/explainCode.d.ts +86 -0
- package/dist/code-explanations/explainCode.d.ts.map +1 -0
- package/dist/code-explanations/explainCode.js +286 -0
- package/dist/code-explanations/explainCode.js.map +1 -0
- package/dist/code-explanations/feedback.d.ts +87 -0
- package/dist/code-explanations/feedback.d.ts.map +1 -0
- package/dist/code-explanations/feedback.js +212 -0
- package/dist/code-explanations/feedback.js.map +1 -0
- package/dist/code-explanations/getRelatedCode.d.ts +80 -0
- package/dist/code-explanations/getRelatedCode.d.ts.map +1 -0
- package/dist/code-explanations/getRelatedCode.js +262 -0
- package/dist/code-explanations/getRelatedCode.js.map +1 -0
- package/dist/code-explanations/index.d.ts +284 -0
- package/dist/code-explanations/index.d.ts.map +1 -0
- package/dist/code-explanations/index.js +249 -0
- package/dist/code-explanations/index.js.map +1 -0
- package/dist/code-explanations/linkCodeToPrompt.d.ts +79 -0
- package/dist/code-explanations/linkCodeToPrompt.d.ts.map +1 -0
- package/dist/code-explanations/linkCodeToPrompt.js +213 -0
- package/dist/code-explanations/linkCodeToPrompt.js.map +1 -0
- package/dist/code-explanations/recallExplanation.d.ts +88 -0
- package/dist/code-explanations/recallExplanation.d.ts.map +1 -0
- package/dist/code-explanations/recallExplanation.js +218 -0
- package/dist/code-explanations/recallExplanation.js.map +1 -0
- package/dist/code-explanations/schema.d.ts +32 -0
- package/dist/code-explanations/schema.d.ts.map +1 -0
- package/dist/code-explanations/schema.js +221 -0
- package/dist/code-explanations/schema.js.map +1 -0
- package/dist/code-explanations/semanticSearch.d.ts +75 -0
- package/dist/code-explanations/semanticSearch.d.ts.map +1 -0
- package/dist/code-explanations/semanticSearch.js +203 -0
- package/dist/code-explanations/semanticSearch.js.map +1 -0
- package/dist/code-explanations/types.d.ts +328 -0
- package/dist/code-explanations/types.d.ts.map +1 -0
- package/dist/code-explanations/types.js +122 -0
- package/dist/code-explanations/types.js.map +1 -0
- package/dist/codebase/codeAnalyzer.d.ts +272 -0
- package/dist/codebase/codeAnalyzer.d.ts.map +1 -0
- package/dist/codebase/codeAnalyzer.js +1353 -0
- package/dist/codebase/codeAnalyzer.js.map +1 -0
- package/dist/codebase/codebaseIndexer.d.ts +360 -0
- package/dist/codebase/codebaseIndexer.d.ts.map +1 -0
- package/dist/codebase/codebaseIndexer.js +1735 -0
- package/dist/codebase/codebaseIndexer.js.map +1 -0
- package/dist/codebase/codebaseTools.d.ts +853 -0
- package/dist/codebase/codebaseTools.d.ts.map +1 -0
- package/dist/codebase/codebaseTools.js +1279 -0
- package/dist/codebase/codebaseTools.js.map +1 -0
- package/dist/codebase/exclusions.d.ts +111 -0
- package/dist/codebase/exclusions.d.ts.map +1 -0
- package/dist/codebase/exclusions.js +771 -0
- package/dist/codebase/exclusions.js.map +1 -0
- package/dist/codebase/fileWatcher.d.ts +135 -0
- package/dist/codebase/fileWatcher.d.ts.map +1 -0
- package/dist/codebase/fileWatcher.js +309 -0
- package/dist/codebase/fileWatcher.js.map +1 -0
- package/dist/codebase/index.d.ts +33 -0
- package/dist/codebase/index.d.ts.map +1 -0
- package/dist/codebase/index.js +77 -0
- package/dist/codebase/index.js.map +1 -0
- package/dist/codebase/ingestion.d.ts +177 -0
- package/dist/codebase/ingestion.d.ts.map +1 -0
- package/dist/codebase/ingestion.js +690 -0
- package/dist/codebase/ingestion.js.map +1 -0
- package/dist/codebase/languageDetection.d.ts +75 -0
- package/dist/codebase/languageDetection.d.ts.map +1 -0
- package/dist/codebase/languageDetection.js +768 -0
- package/dist/codebase/languageDetection.js.map +1 -0
- package/dist/commands/codebaseCommands.d.ts +101 -0
- package/dist/commands/codebaseCommands.d.ts.map +1 -0
- package/dist/commands/codebaseCommands.js +911 -0
- package/dist/commands/codebaseCommands.js.map +1 -0
- package/dist/commands/commandHandler.d.ts +126 -0
- package/dist/commands/commandHandler.d.ts.map +1 -0
- package/dist/commands/commandHandler.js +296 -0
- package/dist/commands/commandHandler.js.map +1 -0
- package/dist/commands/commandLoader.d.ts +103 -0
- package/dist/commands/commandLoader.d.ts.map +1 -0
- package/dist/commands/commandLoader.js +223 -0
- package/dist/commands/commandLoader.js.map +1 -0
- package/dist/commands/contextCommands.d.ts +83 -0
- package/dist/commands/contextCommands.d.ts.map +1 -0
- package/dist/commands/contextCommands.js +512 -0
- package/dist/commands/contextCommands.js.map +1 -0
- package/dist/commands/index.d.ts +24 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +28 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/mcpResources.d.ts +50 -0
- package/dist/commands/mcpResources.d.ts.map +1 -0
- package/dist/commands/mcpResources.js +372 -0
- package/dist/commands/mcpResources.js.map +1 -0
- package/dist/commands/memoryCommands.d.ts +74 -0
- package/dist/commands/memoryCommands.d.ts.map +1 -0
- package/dist/commands/memoryCommands.js +609 -0
- package/dist/commands/memoryCommands.js.map +1 -0
- package/dist/commands/promptCommands.d.ts +91 -0
- package/dist/commands/promptCommands.d.ts.map +1 -0
- package/dist/commands/promptCommands.js +801 -0
- package/dist/commands/promptCommands.js.map +1 -0
- package/dist/commands/teamMemberCommands.d.ts +21 -0
- package/dist/commands/teamMemberCommands.d.ts.map +1 -0
- package/dist/commands/teamMemberCommands.js +137 -0
- package/dist/commands/teamMemberCommands.js.map +1 -0
- package/dist/comms/fileCommsTransport.d.ts +91 -0
- package/dist/comms/fileCommsTransport.d.ts.map +1 -0
- package/dist/comms/fileCommsTransport.js +244 -0
- package/dist/comms/fileCommsTransport.js.map +1 -0
- package/dist/comms/index.d.ts +7 -0
- package/dist/comms/index.d.ts.map +1 -0
- package/dist/comms/index.js +7 -0
- package/dist/comms/index.js.map +1 -0
- package/dist/config/apiKeyDetection.d.ts +41 -0
- package/dist/config/apiKeyDetection.d.ts.map +1 -0
- package/dist/config/apiKeyDetection.js +211 -0
- package/dist/config/apiKeyDetection.js.map +1 -0
- package/dist/config/autoConfig.d.ts +188 -0
- package/dist/config/autoConfig.d.ts.map +1 -0
- package/dist/config/autoConfig.js +850 -0
- package/dist/config/autoConfig.js.map +1 -0
- package/dist/config/configSync.d.ts +119 -0
- package/dist/config/configSync.d.ts.map +1 -0
- package/dist/config/configSync.js +878 -0
- package/dist/config/configSync.js.map +1 -0
- package/dist/config/embeddingTimeouts.d.ts +145 -0
- package/dist/config/embeddingTimeouts.d.ts.map +1 -0
- package/dist/config/embeddingTimeouts.js +255 -0
- package/dist/config/embeddingTimeouts.js.map +1 -0
- package/dist/config/index.d.ts +5 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +7 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/languageConfig.d.ts +68 -0
- package/dist/config/languageConfig.d.ts.map +1 -0
- package/dist/config/languageConfig.js +473 -0
- package/dist/config/languageConfig.js.map +1 -0
- package/dist/config/password.d.ts +145 -0
- package/dist/config/password.d.ts.map +1 -0
- package/dist/config/password.js +428 -0
- package/dist/config/password.js.map +1 -0
- package/dist/config.d.ts +338 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +1177 -0
- package/dist/config.js.map +1 -0
- package/dist/consolidation.d.ts +44 -0
- package/dist/consolidation.d.ts.map +1 -0
- package/dist/consolidation.js +447 -0
- package/dist/consolidation.js.map +1 -0
- package/dist/constants.d.ts +371 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +552 -0
- package/dist/constants.js.map +1 -0
- package/dist/coordination/TeamMemberRegistry.d.ts +192 -0
- package/dist/coordination/TeamMemberRegistry.d.ts.map +1 -0
- package/dist/coordination/TeamMemberRegistry.js +415 -0
- package/dist/coordination/TeamMemberRegistry.js.map +1 -0
- package/dist/coordination/events.d.ts +369 -0
- package/dist/coordination/events.d.ts.map +1 -0
- package/dist/coordination/events.js +232 -0
- package/dist/coordination/events.js.map +1 -0
- package/dist/coordination/handlers.d.ts +116 -0
- package/dist/coordination/handlers.d.ts.map +1 -0
- package/dist/coordination/handlers.js +400 -0
- package/dist/coordination/handlers.js.map +1 -0
- package/dist/coordination/index.d.ts +14 -0
- package/dist/coordination/index.d.ts.map +1 -0
- package/dist/coordination/index.js +31 -0
- package/dist/coordination/index.js.map +1 -0
- package/dist/coordination/integration.d.ts +260 -0
- package/dist/coordination/integration.d.ts.map +1 -0
- package/dist/coordination/integration.js +472 -0
- package/dist/coordination/integration.js.map +1 -0
- package/dist/coordination/server.d.ts +266 -0
- package/dist/coordination/server.d.ts.map +1 -0
- package/dist/coordination/server.js +995 -0
- package/dist/coordination/server.js.map +1 -0
- package/dist/coordination/serviceProvider.d.ts +70 -0
- package/dist/coordination/serviceProvider.d.ts.map +1 -0
- package/dist/coordination/serviceProvider.js +273 -0
- package/dist/coordination/serviceProvider.js.map +1 -0
- package/dist/dashboard/api/claudeControl.d.ts +44 -0
- package/dist/dashboard/api/claudeControl.d.ts.map +1 -0
- package/dist/dashboard/api/claudeControl.js +650 -0
- package/dist/dashboard/api/claudeControl.js.map +1 -0
- package/dist/dashboard/api/claudeHistory.d.ts +4 -0
- package/dist/dashboard/api/claudeHistory.d.ts.map +1 -0
- package/dist/dashboard/api/claudeHistory.js +319 -0
- package/dist/dashboard/api/claudeHistory.js.map +1 -0
- package/dist/dashboard/api/dataExport.d.ts +23 -0
- package/dist/dashboard/api/dataExport.d.ts.map +1 -0
- package/dist/dashboard/api/dataExport.js +509 -0
- package/dist/dashboard/api/dataExport.js.map +1 -0
- package/dist/dashboard/api/fileManager.d.ts +39 -0
- package/dist/dashboard/api/fileManager.d.ts.map +1 -0
- package/dist/dashboard/api/fileManager.js +814 -0
- package/dist/dashboard/api/fileManager.js.map +1 -0
- package/dist/dashboard/api/hooks.d.ts +16 -0
- package/dist/dashboard/api/hooks.d.ts.map +1 -0
- package/dist/dashboard/api/hooks.js +342 -0
- package/dist/dashboard/api/hooks.js.map +1 -0
- package/dist/dashboard/api/hotReload.d.ts +14 -0
- package/dist/dashboard/api/hotReload.d.ts.map +1 -0
- package/dist/dashboard/api/hotReload.js +219 -0
- package/dist/dashboard/api/hotReload.js.map +1 -0
- package/dist/dashboard/api/liveSessionStream.d.ts +19 -0
- package/dist/dashboard/api/liveSessionStream.d.ts.map +1 -0
- package/dist/dashboard/api/liveSessionStream.js +430 -0
- package/dist/dashboard/api/liveSessionStream.js.map +1 -0
- package/dist/dashboard/api/memoryRecall.d.ts +20 -0
- package/dist/dashboard/api/memoryRecall.d.ts.map +1 -0
- package/dist/dashboard/api/memoryRecall.js +524 -0
- package/dist/dashboard/api/memoryRecall.js.map +1 -0
- package/dist/dashboard/api/promptSend.d.ts +33 -0
- package/dist/dashboard/api/promptSend.d.ts.map +1 -0
- package/dist/dashboard/api/promptSend.js +544 -0
- package/dist/dashboard/api/promptSend.js.map +1 -0
- package/dist/dashboard/api/settings.d.ts +10 -0
- package/dist/dashboard/api/settings.d.ts.map +1 -0
- package/dist/dashboard/api/settings.js +656 -0
- package/dist/dashboard/api/settings.js.map +1 -0
- package/dist/dashboard/api/setup.d.ts +21 -0
- package/dist/dashboard/api/setup.d.ts.map +1 -0
- package/dist/dashboard/api/setup.js +663 -0
- package/dist/dashboard/api/setup.js.map +1 -0
- package/dist/dashboard/api/specmemTools.d.ts +14 -0
- package/dist/dashboard/api/specmemTools.d.ts.map +1 -0
- package/dist/dashboard/api/specmemTools.js +1059 -0
- package/dist/dashboard/api/specmemTools.js.map +1 -0
- package/dist/dashboard/api/taskTeamMembers.d.ts +8 -0
- package/dist/dashboard/api/taskTeamMembers.d.ts.map +1 -0
- package/dist/dashboard/api/taskTeamMembers.js +136 -0
- package/dist/dashboard/api/taskTeamMembers.js.map +1 -0
- package/dist/dashboard/api/teamMemberDeploy.d.ts +15 -0
- package/dist/dashboard/api/teamMemberDeploy.d.ts.map +1 -0
- package/dist/dashboard/api/teamMemberDeploy.js +421 -0
- package/dist/dashboard/api/teamMemberDeploy.js.map +1 -0
- package/dist/dashboard/api/teamMemberHistory.d.ts +38 -0
- package/dist/dashboard/api/teamMemberHistory.d.ts.map +1 -0
- package/dist/dashboard/api/teamMemberHistory.js +583 -0
- package/dist/dashboard/api/teamMemberHistory.js.map +1 -0
- package/dist/dashboard/api/terminal.d.ts +12 -0
- package/dist/dashboard/api/terminal.d.ts.map +1 -0
- package/dist/dashboard/api/terminal.js +344 -0
- package/dist/dashboard/api/terminal.js.map +1 -0
- package/dist/dashboard/api/terminalInject.d.ts +17 -0
- package/dist/dashboard/api/terminalInject.d.ts.map +1 -0
- package/dist/dashboard/api/terminalInject.js +322 -0
- package/dist/dashboard/api/terminalInject.js.map +1 -0
- package/dist/dashboard/api/terminalStream.d.ts +12 -0
- package/dist/dashboard/api/terminalStream.d.ts.map +1 -0
- package/dist/dashboard/api/terminalStream.js +482 -0
- package/dist/dashboard/api/terminalStream.js.map +1 -0
- package/dist/dashboard/index.d.ts +7 -0
- package/dist/dashboard/index.d.ts.map +1 -0
- package/dist/dashboard/index.js +7 -0
- package/dist/dashboard/index.js.map +1 -0
- package/dist/dashboard/ptyStreamer.d.ts +173 -0
- package/dist/dashboard/ptyStreamer.d.ts.map +1 -0
- package/dist/dashboard/ptyStreamer.js +661 -0
- package/dist/dashboard/ptyStreamer.js.map +1 -0
- package/dist/dashboard/public/DASHBOARD-README.md +378 -0
- package/dist/dashboard/public/INTEGRATION-GUIDE.md +395 -0
- package/dist/dashboard/public/codebase-config.html +1247 -0
- package/dist/dashboard/public/dashboard-v2.html +1942 -0
- package/dist/dashboard/public/data-export.html +819 -0
- package/dist/dashboard/public/example-page.html +164 -0
- package/dist/dashboard/public/file-explorer.html +1023 -0
- package/dist/dashboard/public/hooks.html +1103 -0
- package/dist/dashboard/public/index-improvements.css +499 -0
- package/dist/dashboard/public/index.html +5534 -0
- package/dist/dashboard/public/memory-controls.html +1959 -0
- package/dist/dashboard/public/memory-recall.html +1495 -0
- package/dist/dashboard/public/previews/skeleton-memory-graph.html +361 -0
- package/dist/dashboard/public/previews/skeleton-memory-list.html +366 -0
- package/dist/dashboard/public/previews/skeleton-search-results.html +609 -0
- package/dist/dashboard/public/previews/skeleton-stats-dashboard.html +556 -0
- package/dist/dashboard/public/prompt-console.html +2763 -0
- package/dist/dashboard/public/react-dist/assets/index-CkjobT5B.js +871 -0
- package/dist/dashboard/public/react-dist/assets/index-iRclxMst.css +1 -0
- package/dist/dashboard/public/react-dist/index.html +16 -0
- package/dist/dashboard/public/shared-header.js +325 -0
- package/dist/dashboard/public/shared-language-selector.js +626 -0
- package/dist/dashboard/public/shared-logger.js +66 -0
- package/dist/dashboard/public/shared-nav.js +325 -0
- package/dist/dashboard/public/shared-theme-blue.css +331 -0
- package/dist/dashboard/public/shared-theme.css +813 -0
- package/dist/dashboard/public/shared-toast.js +415 -0
- package/dist/dashboard/public/team-member-history.html +1291 -0
- package/dist/dashboard/public/team-member-spy.html +1199 -0
- package/dist/dashboard/public/team-members.html +3756 -0
- package/dist/dashboard/public/terminal-output.html +1013 -0
- package/dist/dashboard/public/terminal.html +372 -0
- package/dist/dashboard/sessionStore.d.ts +86 -0
- package/dist/dashboard/sessionStore.d.ts.map +1 -0
- package/dist/dashboard/sessionStore.js +262 -0
- package/dist/dashboard/sessionStore.js.map +1 -0
- package/dist/dashboard/standalone.d.ts +27 -0
- package/dist/dashboard/standalone.d.ts.map +1 -0
- package/dist/dashboard/standalone.js +380 -0
- package/dist/dashboard/standalone.js.map +1 -0
- package/dist/dashboard/webServer.d.ts +390 -0
- package/dist/dashboard/webServer.d.ts.map +1 -0
- package/dist/dashboard/webServer.js +4297 -0
- package/dist/dashboard/webServer.js.map +1 -0
- package/dist/dashboard/websocket/teamMemberStream.d.ts +87 -0
- package/dist/dashboard/websocket/teamMemberStream.d.ts.map +1 -0
- package/dist/dashboard/websocket/teamMemberStream.js +366 -0
- package/dist/dashboard/websocket/teamMemberStream.js.map +1 -0
- package/dist/dashboard/websocket/terminalStream.d.ts +130 -0
- package/dist/dashboard/websocket/terminalStream.d.ts.map +1 -0
- package/dist/dashboard/websocket/terminalStream.js +456 -0
- package/dist/dashboard/websocket/terminalStream.js.map +1 -0
- package/dist/database/embeddedPostgres.d.ts +187 -0
- package/dist/database/embeddedPostgres.d.ts.map +1 -0
- package/dist/database/embeddedPostgres.js +763 -0
- package/dist/database/embeddedPostgres.js.map +1 -0
- package/dist/database/index.d.ts +12 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +20 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/initEmbeddedPostgres.d.ts +124 -0
- package/dist/database/initEmbeddedPostgres.d.ts.map +1 -0
- package/dist/database/initEmbeddedPostgres.js +855 -0
- package/dist/database/initEmbeddedPostgres.js.map +1 -0
- package/dist/database.d.ts +256 -0
- package/dist/database.d.ts.map +1 -0
- package/dist/database.js +1209 -0
- package/dist/database.js.map +1 -0
- package/dist/db/apiDataManager.d.ts +334 -0
- package/dist/db/apiDataManager.d.ts.map +1 -0
- package/dist/db/apiDataManager.js +631 -0
- package/dist/db/apiDataManager.js.map +1 -0
- package/dist/db/batchOperations.d.ts +154 -0
- package/dist/db/batchOperations.d.ts.map +1 -0
- package/dist/db/batchOperations.js +564 -0
- package/dist/db/batchOperations.js.map +1 -0
- package/dist/db/bigBrainMigrations.d.ts +48 -0
- package/dist/db/bigBrainMigrations.d.ts.map +1 -0
- package/dist/db/bigBrainMigrations.js +4266 -0
- package/dist/db/bigBrainMigrations.js.map +1 -0
- package/dist/db/connectionPoolGoBrrr.d.ts +94 -0
- package/dist/db/connectionPoolGoBrrr.d.ts.map +1 -0
- package/dist/db/connectionPoolGoBrrr.js +548 -0
- package/dist/db/connectionPoolGoBrrr.js.map +1 -0
- package/dist/db/dashboardQueries.d.ts +182 -0
- package/dist/db/dashboardQueries.d.ts.map +1 -0
- package/dist/db/dashboardQueries.js +821 -0
- package/dist/db/dashboardQueries.js.map +1 -0
- package/dist/db/deploymentBootstrap.d.ts +43 -0
- package/dist/db/deploymentBootstrap.d.ts.map +1 -0
- package/dist/db/deploymentBootstrap.js +329 -0
- package/dist/db/deploymentBootstrap.js.map +1 -0
- package/dist/db/dimensionService.d.ts +140 -0
- package/dist/db/dimensionService.d.ts.map +1 -0
- package/dist/db/dimensionService.js +261 -0
- package/dist/db/dimensionService.js.map +1 -0
- package/dist/db/embeddingOverflow.d.ts +69 -0
- package/dist/db/embeddingOverflow.d.ts.map +1 -0
- package/dist/db/embeddingOverflow.js +332 -0
- package/dist/db/embeddingOverflow.js.map +1 -0
- package/dist/db/embeddingOverflow.sql +221 -0
- package/dist/db/findThatShit.d.ts +145 -0
- package/dist/db/findThatShit.d.ts.map +1 -0
- package/dist/db/findThatShit.js +782 -0
- package/dist/db/findThatShit.js.map +1 -0
- package/dist/db/hotPathManager.d.ts +187 -0
- package/dist/db/hotPathManager.d.ts.map +1 -0
- package/dist/db/hotPathManager.js +504 -0
- package/dist/db/hotPathManager.js.map +1 -0
- package/dist/db/index.d.ts +85 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +219 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/memoryDrilldown.sql +99 -0
- package/dist/db/migrate.d.ts +3 -0
- package/dist/db/migrate.d.ts.map +1 -0
- package/dist/db/migrate.js +97 -0
- package/dist/db/migrate.js.map +1 -0
- package/dist/db/migrateJsonToPostgres.d.ts +43 -0
- package/dist/db/migrateJsonToPostgres.d.ts.map +1 -0
- package/dist/db/migrateJsonToPostgres.js +465 -0
- package/dist/db/migrateJsonToPostgres.js.map +1 -0
- package/dist/db/nukeFromOrbit.d.ts +63 -0
- package/dist/db/nukeFromOrbit.d.ts.map +1 -0
- package/dist/db/nukeFromOrbit.js +499 -0
- package/dist/db/nukeFromOrbit.js.map +1 -0
- package/dist/db/processedTraining.sql +60 -0
- package/dist/db/projectNamespacing.d.ts +258 -0
- package/dist/db/projectNamespacing.d.ts.map +1 -0
- package/dist/db/projectNamespacing.js +920 -0
- package/dist/db/projectNamespacing.js.map +1 -0
- package/dist/db/projectNamespacing.sql +374 -0
- package/dist/db/projectSchemaInit.sql +271 -0
- package/dist/db/spatialMemory.d.ts +296 -0
- package/dist/db/spatialMemory.d.ts.map +1 -0
- package/dist/db/spatialMemory.js +818 -0
- package/dist/db/spatialMemory.js.map +1 -0
- package/dist/db/streamingQuery.d.ts +143 -0
- package/dist/db/streamingQuery.d.ts.map +1 -0
- package/dist/db/streamingQuery.js +350 -0
- package/dist/db/streamingQuery.js.map +1 -0
- package/dist/db/teamComms.sql +224 -0
- package/dist/db/yeetStuffInDb.d.ts +72 -0
- package/dist/db/yeetStuffInDb.d.ts.map +1 -0
- package/dist/db/yeetStuffInDb.js +473 -0
- package/dist/db/yeetStuffInDb.js.map +1 -0
- package/dist/embedding-providers/index.d.ts +10 -0
- package/dist/embedding-providers/index.d.ts.map +1 -0
- package/dist/embedding-providers/index.js +12 -0
- package/dist/embedding-providers/index.js.map +1 -0
- package/dist/embeddings/projectionLayer.d.ts +114 -0
- package/dist/embeddings/projectionLayer.d.ts.map +1 -0
- package/dist/embeddings/projectionLayer.js +345 -0
- package/dist/embeddings/projectionLayer.js.map +1 -0
- package/dist/events/Publisher.d.ts +193 -0
- package/dist/events/Publisher.d.ts.map +1 -0
- package/dist/events/Publisher.js +439 -0
- package/dist/events/Publisher.js.map +1 -0
- package/dist/events/config.d.ts +139 -0
- package/dist/events/config.d.ts.map +1 -0
- package/dist/events/config.js +266 -0
- package/dist/events/config.js.map +1 -0
- package/dist/events/index.d.ts +19 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +31 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/integration.d.ts +206 -0
- package/dist/events/integration.d.ts.map +1 -0
- package/dist/events/integration.js +348 -0
- package/dist/events/integration.js.map +1 -0
- package/dist/events/metrics.d.ts +147 -0
- package/dist/events/metrics.d.ts.map +1 -0
- package/dist/events/metrics.js +343 -0
- package/dist/events/metrics.js.map +1 -0
- package/dist/hooks/cli.d.ts +28 -0
- package/dist/hooks/cli.d.ts.map +1 -0
- package/dist/hooks/cli.js +118 -0
- package/dist/hooks/cli.js.map +1 -0
- package/dist/hooks/contextInjectionHook.d.ts +60 -0
- package/dist/hooks/contextInjectionHook.d.ts.map +1 -0
- package/dist/hooks/contextInjectionHook.js +294 -0
- package/dist/hooks/contextInjectionHook.js.map +1 -0
- package/dist/hooks/drilldownHook.d.ts +125 -0
- package/dist/hooks/drilldownHook.d.ts.map +1 -0
- package/dist/hooks/drilldownHook.js +181 -0
- package/dist/hooks/drilldownHook.js.map +1 -0
- package/dist/hooks/hookManager.d.ts +180 -0
- package/dist/hooks/hookManager.d.ts.map +1 -0
- package/dist/hooks/hookManager.js +782 -0
- package/dist/hooks/hookManager.js.map +1 -0
- package/dist/hooks/index.d.ts +62 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +66 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/lowContextHook.d.ts +71 -0
- package/dist/hooks/lowContextHook.d.ts.map +1 -0
- package/dist/hooks/lowContextHook.js +258 -0
- package/dist/hooks/lowContextHook.js.map +1 -0
- package/dist/hooks/simpleContextHook.d.ts +65 -0
- package/dist/hooks/simpleContextHook.d.ts.map +1 -0
- package/dist/hooks/simpleContextHook.js +194 -0
- package/dist/hooks/simpleContextHook.js.map +1 -0
- package/dist/hooks/teamFramingCli.d.ts +56 -0
- package/dist/hooks/teamFramingCli.d.ts.map +1 -0
- package/dist/hooks/teamFramingCli.js +264 -0
- package/dist/hooks/teamFramingCli.js.map +1 -0
- package/dist/hooks/teamMemberPrepromptHook.d.ts +150 -0
- package/dist/hooks/teamMemberPrepromptHook.d.ts.map +1 -0
- package/dist/hooks/teamMemberPrepromptHook.js +308 -0
- package/dist/hooks/teamMemberPrepromptHook.js.map +1 -0
- package/dist/index.d.ts +42 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4433 -0
- package/dist/index.js.map +1 -0
- package/dist/init/claudeConfigInjector.d.ts +116 -0
- package/dist/init/claudeConfigInjector.d.ts.map +1 -0
- package/dist/init/claudeConfigInjector.js +1154 -0
- package/dist/init/claudeConfigInjector.js.map +1 -0
- package/dist/installer/autoInstall.d.ts +72 -0
- package/dist/installer/autoInstall.d.ts.map +1 -0
- package/dist/installer/autoInstall.js +617 -0
- package/dist/installer/autoInstall.js.map +1 -0
- package/dist/installer/dbSetup.d.ts +84 -0
- package/dist/installer/dbSetup.d.ts.map +1 -0
- package/dist/installer/dbSetup.js +350 -0
- package/dist/installer/dbSetup.js.map +1 -0
- package/dist/installer/firstRun.d.ts +49 -0
- package/dist/installer/firstRun.d.ts.map +1 -0
- package/dist/installer/firstRun.js +207 -0
- package/dist/installer/firstRun.js.map +1 -0
- package/dist/installer/index.d.ts +10 -0
- package/dist/installer/index.d.ts.map +1 -0
- package/dist/installer/index.js +10 -0
- package/dist/installer/index.js.map +1 -0
- package/dist/installer/silentAutoInstall.d.ts +99 -0
- package/dist/installer/silentAutoInstall.d.ts.map +1 -0
- package/dist/installer/silentAutoInstall.js +491 -0
- package/dist/installer/silentAutoInstall.js.map +1 -0
- package/dist/installer/systemDeps.d.ts +54 -0
- package/dist/installer/systemDeps.d.ts.map +1 -0
- package/dist/installer/systemDeps.js +322 -0
- package/dist/installer/systemDeps.js.map +1 -0
- package/dist/mcp/cliNotifications.d.ts +133 -0
- package/dist/mcp/cliNotifications.d.ts.map +1 -0
- package/dist/mcp/cliNotifications.js +289 -0
- package/dist/mcp/cliNotifications.js.map +1 -0
- package/dist/mcp/embeddingServerManager.d.ts +307 -0
- package/dist/mcp/embeddingServerManager.d.ts.map +1 -0
- package/dist/mcp/embeddingServerManager.js +2081 -0
- package/dist/mcp/embeddingServerManager.js.map +1 -0
- package/dist/mcp/healthMonitor.d.ts +196 -0
- package/dist/mcp/healthMonitor.d.ts.map +1 -0
- package/dist/mcp/healthMonitor.js +685 -0
- package/dist/mcp/healthMonitor.js.map +1 -0
- package/dist/mcp/hotReloadManager.d.ts +101 -0
- package/dist/mcp/hotReloadManager.d.ts.map +1 -0
- package/dist/mcp/hotReloadManager.js +251 -0
- package/dist/mcp/hotReloadManager.js.map +1 -0
- package/dist/mcp/index.d.ts +16 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +22 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/mcpProtocolHandler.d.ts +64 -0
- package/dist/mcp/mcpProtocolHandler.d.ts.map +1 -0
- package/dist/mcp/mcpProtocolHandler.js +253 -0
- package/dist/mcp/mcpProtocolHandler.js.map +1 -0
- package/dist/mcp/miniCOTServerManager.d.ts +336 -0
- package/dist/mcp/miniCOTServerManager.d.ts.map +1 -0
- package/dist/mcp/miniCOTServerManager.js +1384 -0
- package/dist/mcp/miniCOTServerManager.js.map +1 -0
- package/dist/mcp/promptExecutor.d.ts +188 -0
- package/dist/mcp/promptExecutor.d.ts.map +1 -0
- package/dist/mcp/promptExecutor.js +469 -0
- package/dist/mcp/promptExecutor.js.map +1 -0
- package/dist/mcp/reloadBroadcast.d.ts +127 -0
- package/dist/mcp/reloadBroadcast.d.ts.map +1 -0
- package/dist/mcp/reloadBroadcast.js +275 -0
- package/dist/mcp/reloadBroadcast.js.map +1 -0
- package/dist/mcp/resilientTransport.d.ts +249 -0
- package/dist/mcp/resilientTransport.d.ts.map +1 -0
- package/dist/mcp/resilientTransport.js +931 -0
- package/dist/mcp/resilientTransport.js.map +1 -0
- package/dist/mcp/samplingHandler.d.ts +129 -0
- package/dist/mcp/samplingHandler.d.ts.map +1 -0
- package/dist/mcp/samplingHandler.js +276 -0
- package/dist/mcp/samplingHandler.js.map +1 -0
- package/dist/mcp/specMemServer.d.ts +305 -0
- package/dist/mcp/specMemServer.d.ts.map +1 -0
- package/dist/mcp/specMemServer.js +2048 -0
- package/dist/mcp/specMemServer.js.map +1 -0
- package/dist/mcp/toolRegistry.d.ts +122 -0
- package/dist/mcp/toolRegistry.d.ts.map +1 -0
- package/dist/mcp/toolRegistry.js +609 -0
- package/dist/mcp/toolRegistry.js.map +1 -0
- package/dist/mcp/tools/embeddingControl.d.ts +114 -0
- package/dist/mcp/tools/embeddingControl.d.ts.map +1 -0
- package/dist/mcp/tools/embeddingControl.js +222 -0
- package/dist/mcp/tools/embeddingControl.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +10 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +17 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mcp/tools/teamComms.d.ts +444 -0
- package/dist/mcp/tools/teamComms.d.ts.map +1 -0
- package/dist/mcp/tools/teamComms.js +1953 -0
- package/dist/mcp/tools/teamComms.js.map +1 -0
- package/dist/mcp/triggerSystem.d.ts +129 -0
- package/dist/mcp/triggerSystem.d.ts.map +1 -0
- package/dist/mcp/triggerSystem.js +363 -0
- package/dist/mcp/triggerSystem.js.map +1 -0
- package/dist/mcp/watcherIntegration.d.ts +77 -0
- package/dist/mcp/watcherIntegration.d.ts.map +1 -0
- package/dist/mcp/watcherIntegration.js +428 -0
- package/dist/mcp/watcherIntegration.js.map +1 -0
- package/dist/mcp/watcherToolWrappers.d.ts +89 -0
- package/dist/mcp/watcherToolWrappers.d.ts.map +1 -0
- package/dist/mcp/watcherToolWrappers.js +91 -0
- package/dist/mcp/watcherToolWrappers.js.map +1 -0
- package/dist/memorization/claudeCodeMigration.d.ts +34 -0
- package/dist/memorization/claudeCodeMigration.d.ts.map +1 -0
- package/dist/memorization/claudeCodeMigration.js +210 -0
- package/dist/memorization/claudeCodeMigration.js.map +1 -0
- package/dist/memorization/claudeCodeTracker.d.ts +147 -0
- package/dist/memorization/claudeCodeTracker.d.ts.map +1 -0
- package/dist/memorization/claudeCodeTracker.js +424 -0
- package/dist/memorization/claudeCodeTracker.js.map +1 -0
- package/dist/memorization/codeMemorizer.d.ts +158 -0
- package/dist/memorization/codeMemorizer.d.ts.map +1 -0
- package/dist/memorization/codeMemorizer.js +357 -0
- package/dist/memorization/codeMemorizer.js.map +1 -0
- package/dist/memorization/codeRecall.d.ts +156 -0
- package/dist/memorization/codeRecall.d.ts.map +1 -0
- package/dist/memorization/codeRecall.js +499 -0
- package/dist/memorization/codeRecall.js.map +1 -0
- package/dist/memorization/index.d.ts +55 -0
- package/dist/memorization/index.d.ts.map +1 -0
- package/dist/memorization/index.js +64 -0
- package/dist/memorization/index.js.map +1 -0
- package/dist/memorization/memorizationTools.d.ts +413 -0
- package/dist/memorization/memorizationTools.d.ts.map +1 -0
- package/dist/memorization/memorizationTools.js +513 -0
- package/dist/memorization/memorizationTools.js.map +1 -0
- package/dist/memorization/watcherIntegration.d.ts +100 -0
- package/dist/memorization/watcherIntegration.d.ts.map +1 -0
- package/dist/memorization/watcherIntegration.js +196 -0
- package/dist/memorization/watcherIntegration.js.map +1 -0
- package/dist/memory/humanLikeMemory.d.ts +206 -0
- package/dist/memory/humanLikeMemory.d.ts.map +1 -0
- package/dist/memory/humanLikeMemory.js +603 -0
- package/dist/memory/humanLikeMemory.js.map +1 -0
- package/dist/memory/index.d.ts +22 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +24 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/memoryEvolutionMigration.d.ts +36 -0
- package/dist/memory/memoryEvolutionMigration.d.ts.map +1 -0
- package/dist/memory/memoryEvolutionMigration.js +371 -0
- package/dist/memory/memoryEvolutionMigration.js.map +1 -0
- package/dist/memory/quadrantSearch.d.ts +221 -0
- package/dist/memory/quadrantSearch.d.ts.map +1 -0
- package/dist/memory/quadrantSearch.js +897 -0
- package/dist/memory/quadrantSearch.js.map +1 -0
- package/dist/middleware/apiVersioning.d.ts +83 -0
- package/dist/middleware/apiVersioning.d.ts.map +1 -0
- package/dist/middleware/apiVersioning.js +152 -0
- package/dist/middleware/apiVersioning.js.map +1 -0
- package/dist/middleware/compression.d.ts +48 -0
- package/dist/middleware/compression.d.ts.map +1 -0
- package/dist/middleware/compression.js +240 -0
- package/dist/middleware/compression.js.map +1 -0
- package/dist/middleware/csrf.d.ts +118 -0
- package/dist/middleware/csrf.d.ts.map +1 -0
- package/dist/middleware/csrf.js +300 -0
- package/dist/middleware/csrf.js.map +1 -0
- package/dist/middleware/index.d.ts +13 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +17 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/wsRateLimiter.d.ts +129 -0
- package/dist/middleware/wsRateLimiter.d.ts.map +1 -0
- package/dist/middleware/wsRateLimiter.js +279 -0
- package/dist/middleware/wsRateLimiter.js.map +1 -0
- package/dist/migrations/run.d.ts +2 -0
- package/dist/migrations/run.d.ts.map +1 -0
- package/dist/migrations/run.js +25 -0
- package/dist/migrations/run.js.map +1 -0
- package/dist/migrations/syncDimensions.d.ts +24 -0
- package/dist/migrations/syncDimensions.d.ts.map +1 -0
- package/dist/migrations/syncDimensions.js +140 -0
- package/dist/migrations/syncDimensions.js.map +1 -0
- package/dist/migrations/teamComms.d.ts +16 -0
- package/dist/migrations/teamComms.d.ts.map +1 -0
- package/dist/migrations/teamComms.js +210 -0
- package/dist/migrations/teamComms.js.map +1 -0
- package/dist/openapi/index.d.ts +10 -0
- package/dist/openapi/index.d.ts.map +1 -0
- package/dist/openapi/index.js +10 -0
- package/dist/openapi/index.js.map +1 -0
- package/dist/openapi/spec.d.ts +902 -0
- package/dist/openapi/spec.d.ts.map +1 -0
- package/dist/openapi/spec.js +733 -0
- package/dist/openapi/spec.js.map +1 -0
- package/dist/packages/dependencyHistory.d.ts +113 -0
- package/dist/packages/dependencyHistory.d.ts.map +1 -0
- package/dist/packages/dependencyHistory.js +360 -0
- package/dist/packages/dependencyHistory.js.map +1 -0
- package/dist/packages/index.d.ts +30 -0
- package/dist/packages/index.d.ts.map +1 -0
- package/dist/packages/index.js +65 -0
- package/dist/packages/index.js.map +1 -0
- package/dist/packages/packageTools.d.ts +255 -0
- package/dist/packages/packageTools.d.ts.map +1 -0
- package/dist/packages/packageTools.js +242 -0
- package/dist/packages/packageTools.js.map +1 -0
- package/dist/packages/packageTracker.d.ts +98 -0
- package/dist/packages/packageTracker.d.ts.map +1 -0
- package/dist/packages/packageTracker.js +268 -0
- package/dist/packages/packageTracker.js.map +1 -0
- package/dist/packages/packageWatcher.d.ts +62 -0
- package/dist/packages/packageWatcher.d.ts.map +1 -0
- package/dist/packages/packageWatcher.js +146 -0
- package/dist/packages/packageWatcher.js.map +1 -0
- package/dist/providers/MiniCOTProvider.d.ts +48 -0
- package/dist/providers/MiniCOTProvider.d.ts.map +1 -0
- package/dist/providers/MiniCOTProvider.js +98 -0
- package/dist/providers/MiniCOTProvider.js.map +1 -0
- package/dist/reminders/index.d.ts +5 -0
- package/dist/reminders/index.d.ts.map +1 -0
- package/dist/reminders/index.js +5 -0
- package/dist/reminders/index.js.map +1 -0
- package/dist/reminders/skillReminder.d.ts +131 -0
- package/dist/reminders/skillReminder.d.ts.map +1 -0
- package/dist/reminders/skillReminder.js +386 -0
- package/dist/reminders/skillReminder.js.map +1 -0
- package/dist/search.d.ts +35 -0
- package/dist/search.d.ts.map +1 -0
- package/dist/search.js +574 -0
- package/dist/search.js.map +1 -0
- package/dist/security/localhostOnly.d.ts +36 -0
- package/dist/security/localhostOnly.d.ts.map +1 -0
- package/dist/security/localhostOnly.js +101 -0
- package/dist/security/localhostOnly.js.map +1 -0
- package/dist/services/CameraZoomSearch.d.ts +206 -0
- package/dist/services/CameraZoomSearch.d.ts.map +1 -0
- package/dist/services/CameraZoomSearch.js +669 -0
- package/dist/services/CameraZoomSearch.js.map +1 -0
- package/dist/services/DataFlowPipeline.d.ts +111 -0
- package/dist/services/DataFlowPipeline.d.ts.map +1 -0
- package/dist/services/DataFlowPipeline.js +379 -0
- package/dist/services/DataFlowPipeline.js.map +1 -0
- package/dist/services/DimensionAdapter.d.ts +194 -0
- package/dist/services/DimensionAdapter.d.ts.map +1 -0
- package/dist/services/DimensionAdapter.js +566 -0
- package/dist/services/DimensionAdapter.js.map +1 -0
- package/dist/services/DimensionService.d.ts +252 -0
- package/dist/services/DimensionService.d.ts.map +1 -0
- package/dist/services/DimensionService.js +564 -0
- package/dist/services/DimensionService.js.map +1 -0
- package/dist/services/EmbeddingQueue.d.ts +71 -0
- package/dist/services/EmbeddingQueue.d.ts.map +1 -0
- package/dist/services/EmbeddingQueue.js +258 -0
- package/dist/services/EmbeddingQueue.js.map +1 -0
- package/dist/services/MemoryDrilldown.d.ts +226 -0
- package/dist/services/MemoryDrilldown.d.ts.map +1 -0
- package/dist/services/MemoryDrilldown.js +479 -0
- package/dist/services/MemoryDrilldown.js.map +1 -0
- package/dist/services/MiniCOTScorer.d.ts +140 -0
- package/dist/services/MiniCOTScorer.d.ts.map +1 -0
- package/dist/services/MiniCOTScorer.js +292 -0
- package/dist/services/MiniCOTScorer.js.map +1 -0
- package/dist/services/ProjectContext.d.ts +342 -0
- package/dist/services/ProjectContext.d.ts.map +1 -0
- package/dist/services/ProjectContext.js +667 -0
- package/dist/services/ProjectContext.js.map +1 -0
- package/dist/services/ResponseCompactor.d.ts +135 -0
- package/dist/services/ResponseCompactor.d.ts.map +1 -0
- package/dist/services/ResponseCompactor.js +501 -0
- package/dist/services/ResponseCompactor.js.map +1 -0
- package/dist/services/TeamCommsDbService.d.ts +202 -0
- package/dist/services/TeamCommsDbService.d.ts.map +1 -0
- package/dist/services/TeamCommsDbService.js +526 -0
- package/dist/services/TeamCommsDbService.js.map +1 -0
- package/dist/services/UnifiedPasswordService.d.ts +166 -0
- package/dist/services/UnifiedPasswordService.d.ts.map +1 -0
- package/dist/services/UnifiedPasswordService.js +587 -0
- package/dist/services/UnifiedPasswordService.js.map +1 -0
- package/dist/services/adaptiveSearchConfig.d.ts +64 -0
- package/dist/services/adaptiveSearchConfig.d.ts.map +1 -0
- package/dist/services/adaptiveSearchConfig.js +187 -0
- package/dist/services/adaptiveSearchConfig.js.map +1 -0
- package/dist/skills/index.d.ts +8 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +8 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/skillScanner.d.ts +203 -0
- package/dist/skills/skillScanner.d.ts.map +1 -0
- package/dist/skills/skillScanner.js +559 -0
- package/dist/skills/skillScanner.js.map +1 -0
- package/dist/skills/skillsResource.d.ts +69 -0
- package/dist/skills/skillsResource.d.ts.map +1 -0
- package/dist/skills/skillsResource.js +257 -0
- package/dist/skills/skillsResource.js.map +1 -0
- package/dist/startup/index.d.ts +9 -0
- package/dist/startup/index.d.ts.map +1 -0
- package/dist/startup/index.js +12 -0
- package/dist/startup/index.js.map +1 -0
- package/dist/startup/startupIndexing.d.ts +80 -0
- package/dist/startup/startupIndexing.d.ts.map +1 -0
- package/dist/startup/startupIndexing.js +463 -0
- package/dist/startup/startupIndexing.js.map +1 -0
- package/dist/startup/validation.d.ts +89 -0
- package/dist/startup/validation.d.ts.map +1 -0
- package/dist/startup/validation.js +590 -0
- package/dist/startup/validation.js.map +1 -0
- package/dist/storage/index.d.ts +4 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +4 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/overflowManager.d.ts +80 -0
- package/dist/storage/overflowManager.d.ts.map +1 -0
- package/dist/storage/overflowManager.js +317 -0
- package/dist/storage/overflowManager.js.map +1 -0
- package/dist/storage/overflowStorage.d.ts +69 -0
- package/dist/storage/overflowStorage.d.ts.map +1 -0
- package/dist/storage/overflowStorage.js +379 -0
- package/dist/storage/overflowStorage.js.map +1 -0
- package/dist/storage/toonFormat.d.ts +50 -0
- package/dist/storage/toonFormat.d.ts.map +1 -0
- package/dist/storage/toonFormat.js +224 -0
- package/dist/storage/toonFormat.js.map +1 -0
- package/dist/team-members/communication.d.ts +237 -0
- package/dist/team-members/communication.d.ts.map +1 -0
- package/dist/team-members/communication.js +650 -0
- package/dist/team-members/communication.js.map +1 -0
- package/dist/team-members/index.d.ts +14 -0
- package/dist/team-members/index.d.ts.map +1 -0
- package/dist/team-members/index.js +22 -0
- package/dist/team-members/index.js.map +1 -0
- package/dist/team-members/taskOrchestrator.d.ts +224 -0
- package/dist/team-members/taskOrchestrator.d.ts.map +1 -0
- package/dist/team-members/taskOrchestrator.js +574 -0
- package/dist/team-members/taskOrchestrator.js.map +1 -0
- package/dist/team-members/taskTeamMemberLogger.d.ts +157 -0
- package/dist/team-members/taskTeamMemberLogger.d.ts.map +1 -0
- package/dist/team-members/taskTeamMemberLogger.js +478 -0
- package/dist/team-members/taskTeamMemberLogger.js.map +1 -0
- package/dist/team-members/teamCommsService.d.ts +221 -0
- package/dist/team-members/teamCommsService.d.ts.map +1 -0
- package/dist/team-members/teamCommsService.js +628 -0
- package/dist/team-members/teamCommsService.js.map +1 -0
- package/dist/team-members/teamMemberChannels.d.ts +217 -0
- package/dist/team-members/teamMemberChannels.d.ts.map +1 -0
- package/dist/team-members/teamMemberChannels.js +687 -0
- package/dist/team-members/teamMemberChannels.js.map +1 -0
- package/dist/team-members/teamMemberDashboard.d.ts +222 -0
- package/dist/team-members/teamMemberDashboard.d.ts.map +1 -0
- package/dist/team-members/teamMemberDashboard.js +610 -0
- package/dist/team-members/teamMemberDashboard.js.map +1 -0
- package/dist/team-members/teamMemberDeployment.d.ts +60 -0
- package/dist/team-members/teamMemberDeployment.d.ts.map +1 -0
- package/dist/team-members/teamMemberDeployment.js +429 -0
- package/dist/team-members/teamMemberDeployment.js.map +1 -0
- package/dist/team-members/teamMemberDiscovery.d.ts +178 -0
- package/dist/team-members/teamMemberDiscovery.d.ts.map +1 -0
- package/dist/team-members/teamMemberDiscovery.js +446 -0
- package/dist/team-members/teamMemberDiscovery.js.map +1 -0
- package/dist/team-members/teamMemberHistory.d.ts +80 -0
- package/dist/team-members/teamMemberHistory.d.ts.map +1 -0
- package/dist/team-members/teamMemberHistory.js +426 -0
- package/dist/team-members/teamMemberHistory.js.map +1 -0
- package/dist/team-members/teamMemberLimits.d.ts +66 -0
- package/dist/team-members/teamMemberLimits.d.ts.map +1 -0
- package/dist/team-members/teamMemberLimits.js +259 -0
- package/dist/team-members/teamMemberLimits.js.map +1 -0
- package/dist/team-members/teamMemberRegistry.d.ts +199 -0
- package/dist/team-members/teamMemberRegistry.d.ts.map +1 -0
- package/dist/team-members/teamMemberRegistry.js +572 -0
- package/dist/team-members/teamMemberRegistry.js.map +1 -0
- package/dist/team-members/teamMemberTracker.d.ts +148 -0
- package/dist/team-members/teamMemberTracker.d.ts.map +1 -0
- package/dist/team-members/teamMemberTracker.js +828 -0
- package/dist/team-members/teamMemberTracker.js.map +1 -0
- package/dist/team-members/workers/aiWorker.d.ts +53 -0
- package/dist/team-members/workers/aiWorker.d.ts.map +1 -0
- package/dist/team-members/workers/aiWorker.js +322 -0
- package/dist/team-members/workers/aiWorker.js.map +1 -0
- package/dist/team-members/workers/baseWorker.d.ts +101 -0
- package/dist/team-members/workers/baseWorker.d.ts.map +1 -0
- package/dist/team-members/workers/baseWorker.js +179 -0
- package/dist/team-members/workers/baseWorker.js.map +1 -0
- package/dist/team-members/workers/codeReviewWorker.d.ts +3 -0
- package/dist/team-members/workers/codeReviewWorker.d.ts.map +1 -0
- package/dist/team-members/workers/codeReviewWorker.js +144 -0
- package/dist/team-members/workers/codeReviewWorker.js.map +1 -0
- package/dist/team-members/workers/index.d.ts +7 -0
- package/dist/team-members/workers/index.d.ts.map +1 -0
- package/dist/team-members/workers/index.js +7 -0
- package/dist/team-members/workers/index.js.map +1 -0
- package/dist/team-members/workers/repairWorker.d.ts +9 -0
- package/dist/team-members/workers/repairWorker.d.ts.map +1 -0
- package/dist/team-members/workers/repairWorker.js +102 -0
- package/dist/team-members/workers/repairWorker.js.map +1 -0
- package/dist/team-members/workers/sendToTeamMemberB.d.ts +9 -0
- package/dist/team-members/workers/sendToTeamMemberB.d.ts.map +1 -0
- package/dist/team-members/workers/sendToTeamMemberB.js +105 -0
- package/dist/team-members/workers/sendToTeamMemberB.js.map +1 -0
- package/dist/team-members/workers/specmemClient.d.ts +179 -0
- package/dist/team-members/workers/specmemClient.d.ts.map +1 -0
- package/dist/team-members/workers/specmemClient.js +421 -0
- package/dist/team-members/workers/specmemClient.js.map +1 -0
- package/dist/team-members/workers/testCommunication.d.ts +8 -0
- package/dist/team-members/workers/testCommunication.d.ts.map +1 -0
- package/dist/team-members/workers/testCommunication.js +136 -0
- package/dist/team-members/workers/testCommunication.js.map +1 -0
- package/dist/team-members/workers/testCommunicationSuite.d.ts +26 -0
- package/dist/team-members/workers/testCommunicationSuite.d.ts.map +1 -0
- package/dist/team-members/workers/testCommunicationSuite.js +415 -0
- package/dist/team-members/workers/testCommunicationSuite.js.map +1 -0
- package/dist/team-members/workers/testWorker.d.ts +9 -0
- package/dist/team-members/workers/testWorker.d.ts.map +1 -0
- package/dist/team-members/workers/testWorker.js +107 -0
- package/dist/team-members/workers/testWorker.js.map +1 -0
- package/dist/tools/agentDefinitions.d.ts +30 -0
- package/dist/tools/agentDefinitions.d.ts.map +1 -0
- package/dist/tools/agentDefinitions.js +166 -0
- package/dist/tools/agentDefinitions.js.map +1 -0
- package/dist/tools/goofy/checkSyncStatus.d.ts +68 -0
- package/dist/tools/goofy/checkSyncStatus.d.ts.map +1 -0
- package/dist/tools/goofy/checkSyncStatus.js +112 -0
- package/dist/tools/goofy/checkSyncStatus.js.map +1 -0
- package/dist/tools/goofy/codeMemoryLink.d.ts +82 -0
- package/dist/tools/goofy/codeMemoryLink.d.ts.map +1 -0
- package/dist/tools/goofy/codeMemoryLink.js +212 -0
- package/dist/tools/goofy/codeMemoryLink.js.map +1 -0
- package/dist/tools/goofy/compareInstanceMemory.d.ts +97 -0
- package/dist/tools/goofy/compareInstanceMemory.d.ts.map +1 -0
- package/dist/tools/goofy/compareInstanceMemory.js +218 -0
- package/dist/tools/goofy/compareInstanceMemory.js.map +1 -0
- package/dist/tools/goofy/createReasoningChain.d.ts +135 -0
- package/dist/tools/goofy/createReasoningChain.d.ts.map +1 -0
- package/dist/tools/goofy/createReasoningChain.js +257 -0
- package/dist/tools/goofy/createReasoningChain.js.map +1 -0
- package/dist/tools/goofy/deployTeamMember.d.ts +63 -0
- package/dist/tools/goofy/deployTeamMember.d.ts.map +1 -0
- package/dist/tools/goofy/deployTeamMember.js +103 -0
- package/dist/tools/goofy/deployTeamMember.js.map +1 -0
- package/dist/tools/goofy/drillDown.d.ts +143 -0
- package/dist/tools/goofy/drillDown.d.ts.map +1 -0
- package/dist/tools/goofy/drillDown.js +288 -0
- package/dist/tools/goofy/drillDown.js.map +1 -0
- package/dist/tools/goofy/extractClaudeSessions.d.ts +90 -0
- package/dist/tools/goofy/extractClaudeSessions.d.ts.map +1 -0
- package/dist/tools/goofy/extractClaudeSessions.js +277 -0
- package/dist/tools/goofy/extractClaudeSessions.js.map +1 -0
- package/dist/tools/goofy/extractContextRestorations.d.ts +70 -0
- package/dist/tools/goofy/extractContextRestorations.d.ts.map +1 -0
- package/dist/tools/goofy/extractContextRestorations.js +100 -0
- package/dist/tools/goofy/extractContextRestorations.js.map +1 -0
- package/dist/tools/goofy/findCodePointers.d.ts +364 -0
- package/dist/tools/goofy/findCodePointers.d.ts.map +1 -0
- package/dist/tools/goofy/findCodePointers.js +1764 -0
- package/dist/tools/goofy/findCodePointers.js.map +1 -0
- package/dist/tools/goofy/findMemoryGallery.d.ts +40 -0
- package/dist/tools/goofy/findMemoryGallery.d.ts.map +1 -0
- package/dist/tools/goofy/findMemoryGallery.js +66 -0
- package/dist/tools/goofy/findMemoryGallery.js.map +1 -0
- package/dist/tools/goofy/findWhatISaid.d.ts +300 -0
- package/dist/tools/goofy/findWhatISaid.d.ts.map +1 -0
- package/dist/tools/goofy/findWhatISaid.js +2547 -0
- package/dist/tools/goofy/findWhatISaid.js.map +1 -0
- package/dist/tools/goofy/forceResync.d.ts +57 -0
- package/dist/tools/goofy/forceResync.d.ts.map +1 -0
- package/dist/tools/goofy/forceResync.js +100 -0
- package/dist/tools/goofy/forceResync.js.map +1 -0
- package/dist/tools/goofy/getActiveTeamMembers.d.ts +48 -0
- package/dist/tools/goofy/getActiveTeamMembers.d.ts.map +1 -0
- package/dist/tools/goofy/getActiveTeamMembers.js +136 -0
- package/dist/tools/goofy/getActiveTeamMembers.js.map +1 -0
- package/dist/tools/goofy/getMemoryFull.d.ts +34 -0
- package/dist/tools/goofy/getMemoryFull.d.ts.map +1 -0
- package/dist/tools/goofy/getMemoryFull.js +58 -0
- package/dist/tools/goofy/getMemoryFull.js.map +1 -0
- package/dist/tools/goofy/getSessionWatcherStatus.d.ts +43 -0
- package/dist/tools/goofy/getSessionWatcherStatus.d.ts.map +1 -0
- package/dist/tools/goofy/getSessionWatcherStatus.js +92 -0
- package/dist/tools/goofy/getSessionWatcherStatus.js.map +1 -0
- package/dist/tools/goofy/getTeamMemberOutput.d.ts +35 -0
- package/dist/tools/goofy/getTeamMemberOutput.d.ts.map +1 -0
- package/dist/tools/goofy/getTeamMemberOutput.js +62 -0
- package/dist/tools/goofy/getTeamMemberOutput.js.map +1 -0
- package/dist/tools/goofy/getTeamMemberScreen.d.ts +28 -0
- package/dist/tools/goofy/getTeamMemberScreen.d.ts.map +1 -0
- package/dist/tools/goofy/getTeamMemberScreen.js +59 -0
- package/dist/tools/goofy/getTeamMemberScreen.js.map +1 -0
- package/dist/tools/goofy/getTeamMemberStatus.d.ts +33 -0
- package/dist/tools/goofy/getTeamMemberStatus.d.ts.map +1 -0
- package/dist/tools/goofy/getTeamMemberStatus.js +56 -0
- package/dist/tools/goofy/getTeamMemberStatus.js.map +1 -0
- package/dist/tools/goofy/index.d.ts +39 -0
- package/dist/tools/goofy/index.d.ts.map +1 -0
- package/dist/tools/goofy/index.js +51 -0
- package/dist/tools/goofy/index.js.map +1 -0
- package/dist/tools/goofy/interveneTeamMember.d.ts +33 -0
- package/dist/tools/goofy/interveneTeamMember.d.ts.map +1 -0
- package/dist/tools/goofy/interveneTeamMember.js +69 -0
- package/dist/tools/goofy/interveneTeamMember.js.map +1 -0
- package/dist/tools/goofy/killDeployedTeamMember.d.ts +29 -0
- package/dist/tools/goofy/killDeployedTeamMember.d.ts.map +1 -0
- package/dist/tools/goofy/killDeployedTeamMember.js +56 -0
- package/dist/tools/goofy/killDeployedTeamMember.js.map +1 -0
- package/dist/tools/goofy/linkTheVibes.d.ts +125 -0
- package/dist/tools/goofy/linkTheVibes.d.ts.map +1 -0
- package/dist/tools/goofy/linkTheVibes.js +354 -0
- package/dist/tools/goofy/linkTheVibes.js.map +1 -0
- package/dist/tools/goofy/listDeployedTeamMembers.d.ts +26 -0
- package/dist/tools/goofy/listDeployedTeamMembers.d.ts.map +1 -0
- package/dist/tools/goofy/listDeployedTeamMembers.js +52 -0
- package/dist/tools/goofy/listDeployedTeamMembers.js.map +1 -0
- package/dist/tools/goofy/listenForMessages.d.ts +56 -0
- package/dist/tools/goofy/listenForMessages.d.ts.map +1 -0
- package/dist/tools/goofy/listenForMessages.js +122 -0
- package/dist/tools/goofy/listenForMessages.js.map +1 -0
- package/dist/tools/goofy/memoryHealthCheck.d.ts +159 -0
- package/dist/tools/goofy/memoryHealthCheck.d.ts.map +1 -0
- package/dist/tools/goofy/memoryHealthCheck.js +443 -0
- package/dist/tools/goofy/memoryHealthCheck.js.map +1 -0
- package/dist/tools/goofy/rememberThisShit.d.ts +103 -0
- package/dist/tools/goofy/rememberThisShit.d.ts.map +1 -0
- package/dist/tools/goofy/rememberThisShit.js +291 -0
- package/dist/tools/goofy/rememberThisShit.js.map +1 -0
- package/dist/tools/goofy/sayToTeamMember.d.ts +55 -0
- package/dist/tools/goofy/sayToTeamMember.d.ts.map +1 -0
- package/dist/tools/goofy/sayToTeamMember.js +116 -0
- package/dist/tools/goofy/sayToTeamMember.js.map +1 -0
- package/dist/tools/goofy/selfMessage.d.ts +54 -0
- package/dist/tools/goofy/selfMessage.d.ts.map +1 -0
- package/dist/tools/goofy/selfMessage.js +111 -0
- package/dist/tools/goofy/selfMessage.js.map +1 -0
- package/dist/tools/goofy/sendHeartbeat.d.ts +53 -0
- package/dist/tools/goofy/sendHeartbeat.d.ts.map +1 -0
- package/dist/tools/goofy/sendHeartbeat.js +119 -0
- package/dist/tools/goofy/sendHeartbeat.js.map +1 -0
- package/dist/tools/goofy/showMeTheStats.d.ts +216 -0
- package/dist/tools/goofy/showMeTheStats.d.ts.map +1 -0
- package/dist/tools/goofy/showMeTheStats.js +535 -0
- package/dist/tools/goofy/showMeTheStats.js.map +1 -0
- package/dist/tools/goofy/smartRecall.d.ts +136 -0
- package/dist/tools/goofy/smartRecall.d.ts.map +1 -0
- package/dist/tools/goofy/smartRecall.js +286 -0
- package/dist/tools/goofy/smartRecall.js.map +1 -0
- package/dist/tools/goofy/smartSearch.d.ts +64 -0
- package/dist/tools/goofy/smartSearch.d.ts.map +1 -0
- package/dist/tools/goofy/smartSearch.js +89 -0
- package/dist/tools/goofy/smartSearch.js.map +1 -0
- package/dist/tools/goofy/smushMemoriesTogether.d.ts +128 -0
- package/dist/tools/goofy/smushMemoriesTogether.d.ts.map +1 -0
- package/dist/tools/goofy/smushMemoriesTogether.js +536 -0
- package/dist/tools/goofy/smushMemoriesTogether.js.map +1 -0
- package/dist/tools/goofy/spatialSearch.d.ts +198 -0
- package/dist/tools/goofy/spatialSearch.d.ts.map +1 -0
- package/dist/tools/goofy/spatialSearch.js +551 -0
- package/dist/tools/goofy/spatialSearch.js.map +1 -0
- package/dist/tools/goofy/spawnResearchTeamMember.d.ts +104 -0
- package/dist/tools/goofy/spawnResearchTeamMember.d.ts.map +1 -0
- package/dist/tools/goofy/spawnResearchTeamMember.js +290 -0
- package/dist/tools/goofy/spawnResearchTeamMember.js.map +1 -0
- package/dist/tools/goofy/spawnResearchTeamMemberTool.d.ts +121 -0
- package/dist/tools/goofy/spawnResearchTeamMemberTool.d.ts.map +1 -0
- package/dist/tools/goofy/spawnResearchTeamMemberTool.js +215 -0
- package/dist/tools/goofy/spawnResearchTeamMemberTool.js.map +1 -0
- package/dist/tools/goofy/startWatchingTheFiles.d.ts +81 -0
- package/dist/tools/goofy/startWatchingTheFiles.d.ts.map +1 -0
- package/dist/tools/goofy/startWatchingTheFiles.js +161 -0
- package/dist/tools/goofy/startWatchingTheFiles.js.map +1 -0
- package/dist/tools/goofy/stopWatchingTheFiles.d.ts +50 -0
- package/dist/tools/goofy/stopWatchingTheFiles.d.ts.map +1 -0
- package/dist/tools/goofy/stopWatchingTheFiles.js +81 -0
- package/dist/tools/goofy/stopWatchingTheFiles.js.map +1 -0
- package/dist/tools/goofy/whatDidIMean.d.ts +113 -0
- package/dist/tools/goofy/whatDidIMean.d.ts.map +1 -0
- package/dist/tools/goofy/whatDidIMean.js +401 -0
- package/dist/tools/goofy/whatDidIMean.js.map +1 -0
- package/dist/tools/goofy/yeahNahDeleteThat.d.ts +109 -0
- package/dist/tools/goofy/yeahNahDeleteThat.d.ts.map +1 -0
- package/dist/tools/goofy/yeahNahDeleteThat.js +319 -0
- package/dist/tools/goofy/yeahNahDeleteThat.js.map +1 -0
- package/dist/tools/index.d.ts +9 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +9 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/teamMemberDeployer.d.ts +117 -0
- package/dist/tools/teamMemberDeployer.d.ts.map +1 -0
- package/dist/tools/teamMemberDeployer.js +613 -0
- package/dist/tools/teamMemberDeployer.js.map +1 -0
- package/dist/trace/index.d.ts +14 -0
- package/dist/trace/index.d.ts.map +1 -0
- package/dist/trace/index.js +16 -0
- package/dist/trace/index.js.map +1 -0
- package/dist/trace/tools/analyzeImpact.d.ts +90 -0
- package/dist/trace/tools/analyzeImpact.d.ts.map +1 -0
- package/dist/trace/tools/analyzeImpact.js +240 -0
- package/dist/trace/tools/analyzeImpact.js.map +1 -0
- package/dist/trace/tools/exploreDependencies.d.ts +81 -0
- package/dist/trace/tools/exploreDependencies.d.ts.map +1 -0
- package/dist/trace/tools/exploreDependencies.js +161 -0
- package/dist/trace/tools/exploreDependencies.js.map +1 -0
- package/dist/trace/tools/findSimilarBugs.d.ts +112 -0
- package/dist/trace/tools/findSimilarBugs.d.ts.map +1 -0
- package/dist/trace/tools/findSimilarBugs.js +216 -0
- package/dist/trace/tools/findSimilarBugs.js.map +1 -0
- package/dist/trace/tools/index.d.ts +22 -0
- package/dist/trace/tools/index.d.ts.map +1 -0
- package/dist/trace/tools/index.js +39 -0
- package/dist/trace/tools/index.js.map +1 -0
- package/dist/trace/tools/smartExplore.d.ts +126 -0
- package/dist/trace/tools/smartExplore.d.ts.map +1 -0
- package/dist/trace/tools/smartExplore.js +303 -0
- package/dist/trace/tools/smartExplore.js.map +1 -0
- package/dist/trace/tools/traceError.d.ts +101 -0
- package/dist/trace/tools/traceError.d.ts.map +1 -0
- package/dist/trace/tools/traceError.js +175 -0
- package/dist/trace/tools/traceError.js.map +1 -0
- package/dist/trace/traceExploreSystem.d.ts +271 -0
- package/dist/trace/traceExploreSystem.d.ts.map +1 -0
- package/dist/trace/traceExploreSystem.js +789 -0
- package/dist/trace/traceExploreSystem.js.map +1 -0
- package/dist/types/index.d.ts +421 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +118 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/circuitBreaker.d.ts +195 -0
- package/dist/utils/circuitBreaker.d.ts.map +1 -0
- package/dist/utils/circuitBreaker.js +374 -0
- package/dist/utils/circuitBreaker.js.map +1 -0
- package/dist/utils/cleanupHandler.d.ts +108 -0
- package/dist/utils/cleanupHandler.d.ts.map +1 -0
- package/dist/utils/cleanupHandler.js +203 -0
- package/dist/utils/cleanupHandler.js.map +1 -0
- package/dist/utils/compactXmlResponse.d.ts +60 -0
- package/dist/utils/compactXmlResponse.d.ts.map +1 -0
- package/dist/utils/compactXmlResponse.js +209 -0
- package/dist/utils/compactXmlResponse.js.map +1 -0
- package/dist/utils/cotBroadcast.d.ts +56 -0
- package/dist/utils/cotBroadcast.d.ts.map +1 -0
- package/dist/utils/cotBroadcast.js +157 -0
- package/dist/utils/cotBroadcast.js.map +1 -0
- package/dist/utils/debugLogger.d.ts +95 -0
- package/dist/utils/debugLogger.d.ts.map +1 -0
- package/dist/utils/debugLogger.js +610 -0
- package/dist/utils/debugLogger.js.map +1 -0
- package/dist/utils/fileProcessingQueue.d.ts +259 -0
- package/dist/utils/fileProcessingQueue.d.ts.map +1 -0
- package/dist/utils/fileProcessingQueue.js +714 -0
- package/dist/utils/fileProcessingQueue.js.map +1 -0
- package/dist/utils/humanReadableOutput.d.ts +124 -0
- package/dist/utils/humanReadableOutput.d.ts.map +1 -0
- package/dist/utils/humanReadableOutput.js +340 -0
- package/dist/utils/humanReadableOutput.js.map +1 -0
- package/dist/utils/index.d.ts +32 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +71 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/instanceManager.d.ts +530 -0
- package/dist/utils/instanceManager.d.ts.map +1 -0
- package/dist/utils/instanceManager.js +1784 -0
- package/dist/utils/instanceManager.js.map +1 -0
- package/dist/utils/logger.d.ts +6 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +49 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/mapCleanup.d.ts +58 -0
- package/dist/utils/mapCleanup.d.ts.map +1 -0
- package/dist/utils/mapCleanup.js +150 -0
- package/dist/utils/mapCleanup.js.map +1 -0
- package/dist/utils/memoryManager.d.ts +349 -0
- package/dist/utils/memoryManager.d.ts.map +1 -0
- package/dist/utils/memoryManager.js +799 -0
- package/dist/utils/memoryManager.js.map +1 -0
- package/dist/utils/metrics.d.ts +160 -0
- package/dist/utils/metrics.d.ts.map +1 -0
- package/dist/utils/metrics.js +558 -0
- package/dist/utils/metrics.js.map +1 -0
- package/dist/utils/pathValidator.d.ts +96 -0
- package/dist/utils/pathValidator.d.ts.map +1 -0
- package/dist/utils/pathValidator.js +320 -0
- package/dist/utils/pathValidator.js.map +1 -0
- package/dist/utils/portAllocator.d.ts +296 -0
- package/dist/utils/portAllocator.d.ts.map +1 -0
- package/dist/utils/portAllocator.js +768 -0
- package/dist/utils/portAllocator.js.map +1 -0
- package/dist/utils/portUtils.d.ts +97 -0
- package/dist/utils/portUtils.d.ts.map +1 -0
- package/dist/utils/portUtils.js +285 -0
- package/dist/utils/portUtils.js.map +1 -0
- package/dist/utils/postgresAutoSetup.d.ts +55 -0
- package/dist/utils/postgresAutoSetup.d.ts.map +1 -0
- package/dist/utils/postgresAutoSetup.js +406 -0
- package/dist/utils/postgresAutoSetup.js.map +1 -0
- package/dist/utils/processHealthCheck.d.ts +61 -0
- package/dist/utils/processHealthCheck.d.ts.map +1 -0
- package/dist/utils/processHealthCheck.js +313 -0
- package/dist/utils/processHealthCheck.js.map +1 -0
- package/dist/utils/progressReporter.d.ts +151 -0
- package/dist/utils/progressReporter.d.ts.map +1 -0
- package/dist/utils/progressReporter.js +345 -0
- package/dist/utils/progressReporter.js.map +1 -0
- package/dist/utils/projectEnv.d.ts +73 -0
- package/dist/utils/projectEnv.d.ts.map +1 -0
- package/dist/utils/projectEnv.js +137 -0
- package/dist/utils/projectEnv.js.map +1 -0
- package/dist/utils/qoms.d.ts +122 -0
- package/dist/utils/qoms.d.ts.map +1 -0
- package/dist/utils/qoms.js +650 -0
- package/dist/utils/qoms.js.map +1 -0
- package/dist/utils/retryHelper.d.ts +122 -0
- package/dist/utils/retryHelper.d.ts.map +1 -0
- package/dist/utils/retryHelper.js +272 -0
- package/dist/utils/retryHelper.js.map +1 -0
- package/dist/utils/safeProcessTermination.d.ts +206 -0
- package/dist/utils/safeProcessTermination.d.ts.map +1 -0
- package/dist/utils/safeProcessTermination.js +552 -0
- package/dist/utils/safeProcessTermination.js.map +1 -0
- package/dist/utils/sessionInjector.d.ts +68 -0
- package/dist/utils/sessionInjector.d.ts.map +1 -0
- package/dist/utils/sessionInjector.js +189 -0
- package/dist/utils/sessionInjector.js.map +1 -0
- package/dist/utils/statsCache.d.ts +134 -0
- package/dist/utils/statsCache.d.ts.map +1 -0
- package/dist/utils/statsCache.js +285 -0
- package/dist/utils/statsCache.js.map +1 -0
- package/dist/utils/timeoutMiddleware.d.ts +81 -0
- package/dist/utils/timeoutMiddleware.d.ts.map +1 -0
- package/dist/utils/timeoutMiddleware.js +155 -0
- package/dist/utils/timeoutMiddleware.js.map +1 -0
- package/dist/utils/timerRegistry.d.ts +91 -0
- package/dist/utils/timerRegistry.d.ts.map +1 -0
- package/dist/utils/timerRegistry.js +187 -0
- package/dist/utils/timerRegistry.js.map +1 -0
- package/dist/utils/tokenCompressor.d.ts +332 -0
- package/dist/utils/tokenCompressor.d.ts.map +1 -0
- package/dist/utils/tokenCompressor.js +1306 -0
- package/dist/utils/tokenCompressor.js.map +1 -0
- package/dist/utils/tracing.d.ts +236 -0
- package/dist/utils/tracing.d.ts.map +1 -0
- package/dist/utils/tracing.js +378 -0
- package/dist/utils/tracing.js.map +1 -0
- package/dist/watcher/changeHandler.d.ts +123 -0
- package/dist/watcher/changeHandler.d.ts.map +1 -0
- package/dist/watcher/changeHandler.js +623 -0
- package/dist/watcher/changeHandler.js.map +1 -0
- package/dist/watcher/changeQueue.d.ts +133 -0
- package/dist/watcher/changeQueue.d.ts.map +1 -0
- package/dist/watcher/changeQueue.js +355 -0
- package/dist/watcher/changeQueue.js.map +1 -0
- package/dist/watcher/fileWatcher.d.ts +121 -0
- package/dist/watcher/fileWatcher.d.ts.map +1 -0
- package/dist/watcher/fileWatcher.js +531 -0
- package/dist/watcher/fileWatcher.js.map +1 -0
- package/dist/watcher/index.d.ts +94 -0
- package/dist/watcher/index.d.ts.map +1 -0
- package/dist/watcher/index.js +235 -0
- package/dist/watcher/index.js.map +1 -0
- package/dist/watcher/syncChecker.d.ts +93 -0
- package/dist/watcher/syncChecker.d.ts.map +1 -0
- package/dist/watcher/syncChecker.js +401 -0
- package/dist/watcher/syncChecker.js.map +1 -0
- package/dist/watcher/tsCompiler.d.ts +88 -0
- package/dist/watcher/tsCompiler.d.ts.map +1 -0
- package/dist/watcher/tsCompiler.js +212 -0
- package/dist/watcher/tsCompiler.js.map +1 -0
- package/embedding-sandbox/Dockerfile +77 -0
- package/embedding-sandbox/Dockerfile.frankenstein +91 -0
- package/embedding-sandbox/README.md +193 -0
- package/embedding-sandbox/__pycache__/frankenstein-embeddings.cpython-312.pyc +0 -0
- package/embedding-sandbox/__pycache__/frankenstein-embeddings.cpython-313.pyc +0 -0
- package/embedding-sandbox/__pycache__/qqms_v2.cpython-312.pyc +0 -0
- package/embedding-sandbox/__pycache__/qqms_v2.cpython-313.pyc +0 -0
- package/embedding-sandbox/add_js_docs.py +684 -0
- package/embedding-sandbox/build_docs_db.py +239 -0
- package/embedding-sandbox/client.cjs +376 -0
- package/embedding-sandbox/client.ts +913 -0
- package/embedding-sandbox/deploy-frankenstein.sh +240 -0
- package/embedding-sandbox/docker-compose.yml +60 -0
- package/embedding-sandbox/docker-manager.py +325 -0
- package/embedding-sandbox/docs/python_docs.db +0 -0
- package/embedding-sandbox/download-model.mjs +79 -0
- package/embedding-sandbox/download-model.py +28 -0
- package/embedding-sandbox/embedding-supervisor.sh +164 -0
- package/embedding-sandbox/frankenstein-embeddings.py +3940 -0
- package/embedding-sandbox/manage-services.sh +354 -0
- package/embedding-sandbox/overflow_queue.py +345 -0
- package/embedding-sandbox/package.json +17 -0
- package/embedding-sandbox/project_isolation.py +292 -0
- package/embedding-sandbox/qqms_v2.py +967 -0
- package/embedding-sandbox/ram-manager.sh +311 -0
- package/embedding-sandbox/requirements-frankenstein.txt +7 -0
- package/embedding-sandbox/run_js_docs.py +59 -0
- package/embedding-sandbox/seed_docs.py +885 -0
- package/embedding-sandbox/server-batch.mjs +228 -0
- package/embedding-sandbox/server.mjs +389 -0
- package/embedding-sandbox/specmem/sockets/claude-input-state.json +1 -0
- package/embedding-sandbox/specmem/sockets/embedding-death-reason.txt +3 -0
- package/embedding-sandbox/specmem/sockets/seen-sessions.json +1 -0
- package/embedding-sandbox/specmem/sockets/session-start.lock +1 -0
- package/embedding-sandbox/specmem/sockets/session-stops.log +7 -0
- package/embedding-sandbox/start-frankenstein-throttled.sh +98 -0
- package/embedding-sandbox/start-on-demand.sh +116 -0
- package/embedding-sandbox/start-sandbox.sh +237 -0
- package/embedding-sandbox/start-supervised.sh +11 -0
- package/embedding-sandbox/stop-sandbox.sh +51 -0
- package/embedding-sandbox/test-socket.mjs +61 -0
- package/embedding-sandbox/warm-start.sh +353 -0
- package/embedding-sandbox/warm_start_feeder.py +660 -0
- package/legal/README.md +31 -0
- package/legal/anthropic-privacy-center-screenshot-2026-01-30.png +0 -0
- package/legal/anthropic-tos-screenshot-2026-01-30.png +0 -0
- package/lib/codebase-bridge.cjs +308 -0
- package/package.json +136 -0
- package/plugins/specmem-agents/agents/bug-hunter.md +79 -0
- package/plugins/specmem-agents/agents/memory-explorer.md +57 -0
- package/plugins/specmem-agents/agents/team-coordinator.md +82 -0
- package/scripts/auto-updater.cjs +399 -0
- package/scripts/backfill-code-definition-embeddings.ts +440 -0
- package/scripts/backfill-code-embeddings.ts +206 -0
- package/scripts/capture-tos-screenshots.cjs +94 -0
- package/scripts/check-global-install.cjs +67 -0
- package/scripts/cleanup-embedding-servers.sh +25 -0
- package/scripts/dashboard-standalone.sh +369 -0
- package/scripts/deploy-hooks.cjs +1451 -0
- package/scripts/deploy.sh +106 -0
- package/scripts/docker-project-down.sh +83 -0
- package/scripts/docker-project-list.sh +40 -0
- package/scripts/docker-project-up.sh +79 -0
- package/scripts/fast-backfill-embeddings.ts +173 -0
- package/scripts/fast-batch-embedder.cjs +334 -0
- package/scripts/first-run-model-setup.cjs +849 -0
- package/scripts/global-postinstall.cjs +1957 -0
- package/scripts/index-codebase.js +72 -0
- package/scripts/migrate-fix-embeddings.py +110 -0
- package/scripts/migrate-to-project-schemas.ts +525 -0
- package/scripts/optimize-embedding-model.py +324 -0
- package/scripts/optimize-instructions.cjs +530 -0
- package/scripts/pack-docker-images.sh +68 -0
- package/scripts/pack-for-testing.sh +130 -0
- package/scripts/postinstall.cjs +54 -0
- package/scripts/project-env.sh +51 -0
- package/scripts/reset-db.sh +30 -0
- package/scripts/run-indexer.ts +69 -0
- package/scripts/run-migrations.js +47 -0
- package/scripts/setup-db.sh +34 -0
- package/scripts/setup-minimal-schema.sql +143 -0
- package/scripts/skills/code-review.md +44 -0
- package/scripts/skills/debugging.md +56 -0
- package/scripts/skills/specmem-deployteam.md +239 -0
- package/scripts/skills/teammemberskills/EFFICIENT_GREP.md +171 -0
- package/scripts/skills/teammemberskills/task-planning.md +67 -0
- package/scripts/specmem/sockets/session-start.lock +1 -0
- package/scripts/specmem/sockets/session-stops.log +1 -0
- package/scripts/specmem-health.sh +382 -0
- package/scripts/specmem-init.cjs +6935 -0
- package/scripts/strip-debug-logs.cjs +43 -0
- package/scripts/test-mcp-standalone.sh +365 -0
- package/scripts/test-optimized-models.py +166 -0
- package/scripts/verify-embedding-fix.sh +148 -0
- package/skills/code-review.md +44 -0
- package/skills/debugging.md +56 -0
- package/skills/specmem-deployteam.md +239 -0
- package/skills/teammemberskills/EFFICIENT_GREP.md +171 -0
- package/skills/teammemberskills/task-planning.md +67 -0
- package/specmem-health.cjs +522 -0
- package/specmem.env +216 -0
|
@@ -0,0 +1,684 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
ADD JAVASCRIPT DOCS - Enhance Mini-COT with comprehensive JS documentation
|
|
4
|
+
|
|
5
|
+
This script adds JavaScript documentation to the mini-cot docs database,
|
|
6
|
+
focusing on:
|
|
7
|
+
1. Common JavaScript errors (TypeError, ReferenceError, SyntaxError)
|
|
8
|
+
2. Async/await pitfalls and Promise patterns
|
|
9
|
+
3. Array/Object method gotchas
|
|
10
|
+
4. Scope, hoisting, and closure issues
|
|
11
|
+
5. Type coercion problems
|
|
12
|
+
6. Best practices and common bug fixes
|
|
13
|
+
|
|
14
|
+
Output: Appends to /app/docs.db or specified database
|
|
15
|
+
"""
|
|
16
|
+
|
|
17
|
+
import os
|
|
18
|
+
import sqlite3
|
|
19
|
+
import hashlib
|
|
20
|
+
from typing import List, Tuple
|
|
21
|
+
|
|
22
|
+
# Default output path (same as build_docs_db.py)
|
|
23
|
+
OUTPUT_DB = os.environ.get("DOCS_DB", "/specmem/embedding-sandbox/docs/python_docs.db")
|
|
24
|
+
|
|
25
|
+
# ============================================================================
|
|
26
|
+
# JAVASCRIPT ERROR PATTERNS AND FIXES
|
|
27
|
+
# ============================================================================
|
|
28
|
+
|
|
29
|
+
JS_ERROR_PATTERNS = [
|
|
30
|
+
# TypeError patterns
|
|
31
|
+
("TypeError: Cannot read property 'x' of undefined",
|
|
32
|
+
"This error occurs when trying to access a property on undefined or null. "
|
|
33
|
+
"Common causes: 1) Accessing nested object properties without null checks, "
|
|
34
|
+
"2) Calling methods on uninitialized variables, 3) Array index out of bounds. "
|
|
35
|
+
"Fix: Use optional chaining (?.) like obj?.prop?.nested, or nullish coalescing (??) "
|
|
36
|
+
"like obj?.prop ?? defaultValue. Always validate data before accessing nested properties."),
|
|
37
|
+
|
|
38
|
+
("TypeError: Cannot read property 'x' of null",
|
|
39
|
+
"Similar to undefined error but the value is explicitly null. "
|
|
40
|
+
"Common when: 1) DOM querySelector returns null, 2) JSON parsing returns null, "
|
|
41
|
+
"3) API response has null fields. Fix: Check for null before accessing: "
|
|
42
|
+
"if (element !== null) { element.innerHTML = 'text'; } or use optional chaining."),
|
|
43
|
+
|
|
44
|
+
("TypeError: x is not a function",
|
|
45
|
+
"Occurs when calling something that isn't callable. Common causes: "
|
|
46
|
+
"1) Overwriting a function with a variable of same name, "
|
|
47
|
+
"2) Importing/exporting incorrectly (missing default export), "
|
|
48
|
+
"3) Calling a property instead of a method. "
|
|
49
|
+
"Fix: Check the type with typeof fn === 'function' before calling. "
|
|
50
|
+
"Verify imports match exports (named vs default)."),
|
|
51
|
+
|
|
52
|
+
("TypeError: Cannot assign to read only property",
|
|
53
|
+
"Attempting to modify a frozen object or const primitive. "
|
|
54
|
+
"Common with: Object.freeze(), const declarations, or getter-only properties. "
|
|
55
|
+
"Fix: Create a copy before modifying: const newObj = {...frozenObj, prop: newValue}; "
|
|
56
|
+
"Or use Object.assign() to create mutable copies."),
|
|
57
|
+
|
|
58
|
+
("TypeError: x.map is not a function",
|
|
59
|
+
"Calling array methods on non-arrays. Common causes: "
|
|
60
|
+
"1) API returns object instead of array, 2) JSON.parse result isn't array, "
|
|
61
|
+
"3) Variable shadowing hides the array. "
|
|
62
|
+
"Fix: Verify with Array.isArray(x) before calling array methods. "
|
|
63
|
+
"Use (x || []).map() as defensive pattern."),
|
|
64
|
+
|
|
65
|
+
("TypeError: Assignment to constant variable",
|
|
66
|
+
"Trying to reassign a const variable. Remember const only prevents reassignment, "
|
|
67
|
+
"not mutation of object/array contents. Fix: Use let for variables that need reassignment. "
|
|
68
|
+
"For objects, you can still modify properties: const obj = {}; obj.prop = 'ok';"),
|
|
69
|
+
|
|
70
|
+
# ReferenceError patterns
|
|
71
|
+
("ReferenceError: x is not defined",
|
|
72
|
+
"Variable doesn't exist in current scope. Common causes: "
|
|
73
|
+
"1) Typo in variable name, 2) Using before declaration (temporal dead zone with let/const), "
|
|
74
|
+
"3) Variable declared in different scope/module. "
|
|
75
|
+
"Fix: Check spelling, ensure variable is declared before use, "
|
|
76
|
+
"verify imports are correct. Use typeof x === 'undefined' for safe checks."),
|
|
77
|
+
|
|
78
|
+
("ReferenceError: Cannot access 'x' before initialization",
|
|
79
|
+
"Temporal Dead Zone (TDZ) error with let/const. Unlike var which hoists and initializes to undefined, "
|
|
80
|
+
"let/const hoist but remain uninitialized until declaration line. "
|
|
81
|
+
"Fix: Move declaration before usage, or use var if hoisting behavior is needed (not recommended)."),
|
|
82
|
+
|
|
83
|
+
# SyntaxError patterns
|
|
84
|
+
("SyntaxError: Unexpected token",
|
|
85
|
+
"Parser encountered something unexpected. Common causes: "
|
|
86
|
+
"1) Missing comma in array/object, 2) Extra comma (trailing in old JS), "
|
|
87
|
+
"3) Missing brackets/braces, 4) Invalid JSON (single quotes, trailing commas). "
|
|
88
|
+
"Fix: Check for balanced brackets, proper comma placement. Use JSON.parse() with try-catch."),
|
|
89
|
+
|
|
90
|
+
("SyntaxError: Unexpected identifier",
|
|
91
|
+
"Usually missing operator or keyword. Common causes: "
|
|
92
|
+
"1) Missing 'function' keyword, 2) Missing semicolon (ASI failure), "
|
|
93
|
+
"3) Reserved word as variable name. Fix: Add missing keywords, "
|
|
94
|
+
"use descriptive non-reserved names like userData instead of class."),
|
|
95
|
+
|
|
96
|
+
("SyntaxError: Invalid or unexpected token",
|
|
97
|
+
"Character not valid in JS. Often: 1) Smart quotes from copy-paste (curly quotes instead of straight), "
|
|
98
|
+
"2) Invisible Unicode characters, 3) Template literal without backticks. "
|
|
99
|
+
"Fix: Retype quotes manually, use straight quotes, check for hidden characters."),
|
|
100
|
+
|
|
101
|
+
("SyntaxError: Missing ) after argument list",
|
|
102
|
+
"Unbalanced parentheses in function call. Often from: "
|
|
103
|
+
"1) Nested function calls with wrong count, 2) Template literal confusion, "
|
|
104
|
+
"3) Missing closing paren before brace. Fix: Count opening and closing parens, "
|
|
105
|
+
"use editor bracket matching feature."),
|
|
106
|
+
|
|
107
|
+
("SyntaxError: Illegal return statement",
|
|
108
|
+
"Return used outside a function. This happens when: "
|
|
109
|
+
"1) Return is at module level, 2) Return inside a class body but outside method. "
|
|
110
|
+
"Fix: Ensure return is inside a function body. For module exports, use export instead."),
|
|
111
|
+
|
|
112
|
+
# RangeError patterns
|
|
113
|
+
("RangeError: Maximum call stack size exceeded",
|
|
114
|
+
"Infinite recursion or very deep recursion. Causes: "
|
|
115
|
+
"1) Recursive function without base case, 2) Circular object references in serialization, "
|
|
116
|
+
"3) Event handlers triggering themselves. "
|
|
117
|
+
"Fix: Add proper base case, limit recursion depth, use trampolining or iterative approach."),
|
|
118
|
+
|
|
119
|
+
("RangeError: Invalid array length",
|
|
120
|
+
"Array length must be positive integer < 2^32. Causes: "
|
|
121
|
+
"1) new Array(-1) or new Array(NaN), 2) Setting array.length to invalid value. "
|
|
122
|
+
"Fix: Validate length before creating array: Math.max(0, Math.floor(len))."),
|
|
123
|
+
|
|
124
|
+
("RangeError: Invalid string length",
|
|
125
|
+
"String operations exceeding max length. Often from: "
|
|
126
|
+
"1) Infinite string concatenation in loop, 2) Very large repeat() call. "
|
|
127
|
+
"Fix: Check string sizes, use streaming for large data, limit repeat count."),
|
|
128
|
+
]
|
|
129
|
+
|
|
130
|
+
# ============================================================================
|
|
131
|
+
# ASYNC/AWAIT AND PROMISE PATTERNS
|
|
132
|
+
# ============================================================================
|
|
133
|
+
|
|
134
|
+
JS_ASYNC_PATTERNS = [
|
|
135
|
+
("async/await: Unhandled promise rejection",
|
|
136
|
+
"Async function throws but no try-catch or .catch(). Every async operation can fail. "
|
|
137
|
+
"Fix: Always wrap await in try-catch: try { await fetch(); } catch (e) { handleError(e); } "
|
|
138
|
+
"Or add global handler: process.on('unhandledRejection', handler);"),
|
|
139
|
+
|
|
140
|
+
("async/await: await in forEach doesn't work",
|
|
141
|
+
"forEach doesn't wait for async callbacks. The loop completes before promises resolve. "
|
|
142
|
+
"Fix: Use for...of loop: for (const item of items) { await process(item); } "
|
|
143
|
+
"Or Promise.all with map: await Promise.all(items.map(async item => await process(item)));"),
|
|
144
|
+
|
|
145
|
+
("async/await: Parallel vs sequential execution",
|
|
146
|
+
"Sequential: await a(); await b(); executes one after another. "
|
|
147
|
+
"Parallel: await Promise.all([a(), b()]) starts both immediately. "
|
|
148
|
+
"For independent operations, use parallel for better performance. "
|
|
149
|
+
"Only use sequential when b() depends on a()'s result."),
|
|
150
|
+
|
|
151
|
+
("async/await: Forgetting to await",
|
|
152
|
+
"async function returns Promise, not the resolved value. "
|
|
153
|
+
"Without await, you get Promise object instead of data. "
|
|
154
|
+
"Common symptom: [object Promise] in output. "
|
|
155
|
+
"Fix: Always await async calls or handle with .then()."),
|
|
156
|
+
|
|
157
|
+
("Promise: then() returns new Promise",
|
|
158
|
+
".then() always returns a new Promise, enabling chaining. "
|
|
159
|
+
"Return value becomes resolved value of new Promise. "
|
|
160
|
+
"Throwing inside .then() rejects the new Promise. "
|
|
161
|
+
"Pattern: fetch().then(r => r.json()).then(data => use(data));"),
|
|
162
|
+
|
|
163
|
+
("Promise: catch() placement matters",
|
|
164
|
+
".catch() only catches errors from preceding chain. "
|
|
165
|
+
"promise.then(a).then(b).catch(e) - catches errors from both a and b. "
|
|
166
|
+
"promise.then(a).catch(e).then(b) - b runs even if a throws. "
|
|
167
|
+
"Place .catch() at end to catch all errors in chain."),
|
|
168
|
+
|
|
169
|
+
("Promise: Promise.all() fails fast",
|
|
170
|
+
"Promise.all() rejects immediately when ANY promise rejects. "
|
|
171
|
+
"Other promises continue but results are lost. "
|
|
172
|
+
"For fail-safe: Use Promise.allSettled() to get all results regardless of rejection. "
|
|
173
|
+
"For first success: Use Promise.any() (ES2021)."),
|
|
174
|
+
|
|
175
|
+
("Promise: Mixing async/await with .then()",
|
|
176
|
+
"Avoid mixing styles in same code block - confusing and error-prone. "
|
|
177
|
+
"Choose one: either async/await throughout or .then() chains. "
|
|
178
|
+
"async/await is generally more readable for sequential logic."),
|
|
179
|
+
|
|
180
|
+
("async/await: async function always returns Promise",
|
|
181
|
+
"Even if you return plain value, it's wrapped in Promise. "
|
|
182
|
+
"return 5 becomes return Promise.resolve(5). "
|
|
183
|
+
"return undefined becomes return Promise.resolve(undefined). "
|
|
184
|
+
"Callers must await or .then() to get value."),
|
|
185
|
+
|
|
186
|
+
("Promise: Creating Promise executor anti-pattern",
|
|
187
|
+
"Don't create new Promise when you already have one: "
|
|
188
|
+
"BAD: new Promise(resolve => fetch(url).then(r => resolve(r))) "
|
|
189
|
+
"GOOD: fetch(url) - fetch already returns Promise. "
|
|
190
|
+
"Only use new Promise for wrapping callback-based APIs."),
|
|
191
|
+
]
|
|
192
|
+
|
|
193
|
+
# ============================================================================
|
|
194
|
+
# ARRAY AND OBJECT METHOD GOTCHAS
|
|
195
|
+
# ============================================================================
|
|
196
|
+
|
|
197
|
+
JS_ARRAY_OBJECT_GOTCHAS = [
|
|
198
|
+
("Array: sort() modifies original and sorts as strings",
|
|
199
|
+
"[10, 2, 1].sort() returns [1, 10, 2] because it converts to strings. "
|
|
200
|
+
"Fix: Use compare function: arr.sort((a, b) => a - b) for numbers. "
|
|
201
|
+
"For descending: arr.sort((a, b) => b - a). "
|
|
202
|
+
"Note: sort() mutates original array, use [...arr].sort() for copy."),
|
|
203
|
+
|
|
204
|
+
("Array: splice() vs slice()",
|
|
205
|
+
"splice(start, deleteCount, ...items) MUTATES array, returns deleted items. "
|
|
206
|
+
"slice(start, end) returns NEW array, doesn't mutate. "
|
|
207
|
+
"Common mistake: using splice when you wanted slice. "
|
|
208
|
+
"For immutable operations, prefer slice, filter, map."),
|
|
209
|
+
|
|
210
|
+
("Array: map() vs forEach() return values",
|
|
211
|
+
"map() returns new array with transformed values. "
|
|
212
|
+
"forEach() returns undefined, only for side effects. "
|
|
213
|
+
"Don't use map() if you don't need return array (wasteful). "
|
|
214
|
+
"Don't use forEach() expecting to collect results."),
|
|
215
|
+
|
|
216
|
+
("Array: filter() doesn't modify original",
|
|
217
|
+
"filter() returns NEW array with elements passing test. "
|
|
218
|
+
"Original array unchanged. To modify in place, use splice in loop. "
|
|
219
|
+
"Pattern: arr = arr.filter(x => x !== valueToRemove);"),
|
|
220
|
+
|
|
221
|
+
("Array: reduce() initial value importance",
|
|
222
|
+
"Without initial value, uses first element as accumulator. "
|
|
223
|
+
"Empty array without initial throws TypeError. "
|
|
224
|
+
"Always provide initial value: arr.reduce((acc, x) => acc + x, 0). "
|
|
225
|
+
"For objects: arr.reduce((acc, x) => ({...acc, [x.id]: x}), {})."),
|
|
226
|
+
|
|
227
|
+
("Array: includes() vs indexOf()",
|
|
228
|
+
"includes() returns boolean, handles NaN correctly. "
|
|
229
|
+
"[NaN].includes(NaN) is true. [NaN].indexOf(NaN) is -1. "
|
|
230
|
+
"Use includes() for existence check, indexOf() when you need position."),
|
|
231
|
+
|
|
232
|
+
("Array: find() vs filter() for single item",
|
|
233
|
+
"find() returns first match or undefined, stops at first match. "
|
|
234
|
+
"filter() returns array of all matches. "
|
|
235
|
+
"For single item lookup, find() is more efficient and cleaner."),
|
|
236
|
+
|
|
237
|
+
("Array: flat() and flatMap()",
|
|
238
|
+
"flat(depth) flattens nested arrays: [[1],[2]].flat() = [1,2]. "
|
|
239
|
+
"Default depth is 1. Use Infinity for complete flatten. "
|
|
240
|
+
"flatMap() is map() + flat(1) in one pass - more efficient."),
|
|
241
|
+
|
|
242
|
+
("Object: Object.keys/values/entries order",
|
|
243
|
+
"Iteration order: 1) Integer keys in ascending order, "
|
|
244
|
+
"2) String keys in insertion order, 3) Symbol keys in insertion order. "
|
|
245
|
+
"For guaranteed order, use Map instead of Object."),
|
|
246
|
+
|
|
247
|
+
("Object: Shallow vs deep copy",
|
|
248
|
+
"Object.assign() and spread {...obj} create SHALLOW copies. "
|
|
249
|
+
"Nested objects still reference originals. "
|
|
250
|
+
"For deep copy: JSON.parse(JSON.stringify(obj)) (loses functions, dates). "
|
|
251
|
+
"Or use structuredClone(obj) (modern browsers, Node 17+)."),
|
|
252
|
+
|
|
253
|
+
("Object: in vs hasOwnProperty",
|
|
254
|
+
"'prop' in obj checks prototype chain too. "
|
|
255
|
+
"obj.hasOwnProperty('prop') only checks own properties. "
|
|
256
|
+
"Modern: Object.hasOwn(obj, 'prop') - safer, works when hasOwnProperty overwritten."),
|
|
257
|
+
|
|
258
|
+
("Object: Property shorthand gotcha",
|
|
259
|
+
"const name = 'John'; const obj = { name }; // { name: 'John' }. "
|
|
260
|
+
"But computed properties need brackets: { [dynamicKey]: value }. "
|
|
261
|
+
"Don't confuse { name } with { 'name': name }."),
|
|
262
|
+
]
|
|
263
|
+
|
|
264
|
+
# ============================================================================
|
|
265
|
+
# SCOPE, HOISTING, AND CLOSURE ISSUES
|
|
266
|
+
# ============================================================================
|
|
267
|
+
|
|
268
|
+
JS_SCOPE_PATTERNS = [
|
|
269
|
+
("Hoisting: var vs let/const",
|
|
270
|
+
"var is hoisted and initialized to undefined. "
|
|
271
|
+
"let/const are hoisted but NOT initialized (TDZ). "
|
|
272
|
+
"console.log(x); var x = 1; // undefined. "
|
|
273
|
+
"console.log(x); let x = 1; // ReferenceError. "
|
|
274
|
+
"Best practice: Always declare at top of scope, prefer const/let."),
|
|
275
|
+
|
|
276
|
+
("Hoisting: Function declarations vs expressions",
|
|
277
|
+
"Function declarations are fully hoisted: fn(); function fn(){} works. "
|
|
278
|
+
"Function expressions with var: fn(); var fn = function(){} // TypeError. "
|
|
279
|
+
"Arrow functions same as expressions - not hoisted."),
|
|
280
|
+
|
|
281
|
+
("Closure: Loop variable capture",
|
|
282
|
+
"Classic bug: for(var i=0; i<3; i++) setTimeout(() => console.log(i), 1000) "
|
|
283
|
+
"Prints 3,3,3 not 0,1,2 because closures share same i. "
|
|
284
|
+
"Fix 1: Use let: for(let i=0; ...) - each iteration gets own i. "
|
|
285
|
+
"Fix 2: IIFE: (function(i){ setTimeout(()=>console.log(i), 1000) })(i);"),
|
|
286
|
+
|
|
287
|
+
("Closure: Memory leaks",
|
|
288
|
+
"Closures keep references to outer scope variables. "
|
|
289
|
+
"If closure outlives outer function, those variables aren't GC'd. "
|
|
290
|
+
"Common in event handlers, timers, callbacks. "
|
|
291
|
+
"Fix: Nullify references when done, remove event listeners, clear timers."),
|
|
292
|
+
|
|
293
|
+
("Scope: Block scope vs function scope",
|
|
294
|
+
"var is function-scoped: visible throughout function. "
|
|
295
|
+
"let/const are block-scoped: only within { }. "
|
|
296
|
+
"if(true){ var x=1; let y=2; } // x accessible, y not. "
|
|
297
|
+
"Best practice: Use let/const for predictable scoping."),
|
|
298
|
+
|
|
299
|
+
("Scope: Global pollution",
|
|
300
|
+
"Assigning without declaration creates global: x = 1; // window.x in browser. "
|
|
301
|
+
"'use strict' prevents this (throws ReferenceError). "
|
|
302
|
+
"Always use const/let/var. Avoid modifying global objects."),
|
|
303
|
+
|
|
304
|
+
("this: Context binding",
|
|
305
|
+
"Regular functions: this determined by call site. "
|
|
306
|
+
"Arrow functions: this from enclosing lexical scope. "
|
|
307
|
+
"obj.method() - this is obj. const fn = obj.method; fn() - this is undefined/window. "
|
|
308
|
+
"Fix: Use arrow functions or .bind()/.call()/.apply()."),
|
|
309
|
+
|
|
310
|
+
("this: Lost context in callbacks",
|
|
311
|
+
"class C { method() { setTimeout(function() { this.x }, 1000); } } "
|
|
312
|
+
"this inside setTimeout is not the class instance. "
|
|
313
|
+
"Fix 1: Arrow function: setTimeout(() => this.x, 1000). "
|
|
314
|
+
"Fix 2: Bind: setTimeout(this.handler.bind(this), 1000). "
|
|
315
|
+
"Fix 3: Store reference: const self = this;"),
|
|
316
|
+
|
|
317
|
+
("Closure: Creating functions in loops",
|
|
318
|
+
"BAD: for(var i=0; i<btns.length; i++) btns[i].onclick = function(){ alert(i); }; "
|
|
319
|
+
"All buttons alert same value (btns.length). "
|
|
320
|
+
"GOOD: Use let, or forEach which creates closure per iteration: "
|
|
321
|
+
"btns.forEach((btn, i) => btn.onclick = () => alert(i));"),
|
|
322
|
+
]
|
|
323
|
+
|
|
324
|
+
# ============================================================================
|
|
325
|
+
# TYPE COERCION PROBLEMS
|
|
326
|
+
# ============================================================================
|
|
327
|
+
|
|
328
|
+
JS_TYPE_COERCION = [
|
|
329
|
+
("Equality: == vs ===",
|
|
330
|
+
"== performs type coercion: '1' == 1 is true. "
|
|
331
|
+
"=== strict equality, no coercion: '1' === 1 is false. "
|
|
332
|
+
"null == undefined is true, null === undefined is false. "
|
|
333
|
+
"Best practice: Always use === unless you specifically need coercion."),
|
|
334
|
+
|
|
335
|
+
("Coercion: + operator with strings",
|
|
336
|
+
"'1' + 2 = '12' (string concatenation). "
|
|
337
|
+
"1 + '2' = '12' (string wins). "
|
|
338
|
+
"1 + 2 + '3' = '33' (left to right: 3 + '3'). "
|
|
339
|
+
"Fix: Explicit conversion: Number('1') + 2, or parseInt('1') + 2."),
|
|
340
|
+
|
|
341
|
+
("Coercion: Falsy values",
|
|
342
|
+
"Falsy: false, 0, '', null, undefined, NaN. "
|
|
343
|
+
"if(!x) catches all falsy, not just null/undefined. "
|
|
344
|
+
"0 and '' are valid values that are falsy. "
|
|
345
|
+
"Fix: Use x === null || x === undefined, or x ?? defaultValue (nullish coalescing)."),
|
|
346
|
+
|
|
347
|
+
("Coercion: NaN quirks",
|
|
348
|
+
"NaN !== NaN is true (NaN is not equal to itself). "
|
|
349
|
+
"typeof NaN is 'number'. "
|
|
350
|
+
"Use Number.isNaN(x) not isNaN(x). "
|
|
351
|
+
"isNaN('hello') is true (coerces to NaN), Number.isNaN('hello') is false."),
|
|
352
|
+
|
|
353
|
+
("Coercion: [] and {} in boolean context",
|
|
354
|
+
"Empty array [] is truthy: if([]) is true. "
|
|
355
|
+
"Empty object {} is truthy: if({}) is true. "
|
|
356
|
+
"Only [] == false is true ([] coerces to '' coerces to 0). "
|
|
357
|
+
"Check length: if(arr.length), or use Array.isArray() with length check."),
|
|
358
|
+
|
|
359
|
+
("Coercion: + unary for conversion",
|
|
360
|
+
"+string converts to number: +'42' is 42. "
|
|
361
|
+
"+'' is 0, +'hello' is NaN. "
|
|
362
|
+
"Also works with dates: +new Date() gives timestamp. "
|
|
363
|
+
"Prefer explicit Number() for clarity."),
|
|
364
|
+
|
|
365
|
+
("Coercion: Boolean conversion",
|
|
366
|
+
"Boolean(x) or !!x for explicit conversion. "
|
|
367
|
+
"!!0 is false, !!1 is true, !!'' is false, !!'x' is true. "
|
|
368
|
+
"!![] is true, !!{} is true (objects are truthy)."),
|
|
369
|
+
|
|
370
|
+
("Coercion: Object to primitive",
|
|
371
|
+
"Objects convert via valueOf() then toString(). "
|
|
372
|
+
"[1,2,3] + '' = '1,2,3'. {} + '' = '[object Object]'. "
|
|
373
|
+
"Custom objects can override: valueOf() { return 42; }"),
|
|
374
|
+
|
|
375
|
+
("typeof: Quirks and limitations",
|
|
376
|
+
"typeof null is 'object' (historical bug). "
|
|
377
|
+
"typeof [] is 'object' (use Array.isArray). "
|
|
378
|
+
"typeof function is 'function'. "
|
|
379
|
+
"typeof undeclaredVar is 'undefined' (doesn't throw)."),
|
|
380
|
+
|
|
381
|
+
("Coercion: parseInt gotchas",
|
|
382
|
+
"parseInt('08') was 0 in old JS (octal). Now 8 in ES5+. "
|
|
383
|
+
"Always specify radix: parseInt('08', 10). "
|
|
384
|
+
"parseInt stops at first non-digit: parseInt('123abc') is 123. "
|
|
385
|
+
"parseInt(0.0000005) is 5 (coerces to '5e-7', parses 5)."),
|
|
386
|
+
]
|
|
387
|
+
|
|
388
|
+
# ============================================================================
|
|
389
|
+
# MODERN JAVASCRIPT BEST PRACTICES
|
|
390
|
+
# ============================================================================
|
|
391
|
+
|
|
392
|
+
JS_BEST_PRACTICES = [
|
|
393
|
+
("Destructuring: Default values",
|
|
394
|
+
"const { x = 10 } = obj; // x is 10 if obj.x is undefined. "
|
|
395
|
+
"Works with arrays: const [a = 1, b = 2] = arr; "
|
|
396
|
+
"Note: Only triggers on undefined, not null or 0."),
|
|
397
|
+
|
|
398
|
+
("Optional chaining: Safe property access",
|
|
399
|
+
"obj?.prop?.nested - returns undefined if any part is null/undefined. "
|
|
400
|
+
"Works with methods: obj.method?.() - calls only if method exists. "
|
|
401
|
+
"Works with arrays: arr?.[0]?.prop. "
|
|
402
|
+
"Combine with nullish coalescing: obj?.prop ?? defaultValue."),
|
|
403
|
+
|
|
404
|
+
("Nullish coalescing: ?? vs ||",
|
|
405
|
+
"|| returns right side for ANY falsy value. "
|
|
406
|
+
"?? returns right side only for null/undefined. "
|
|
407
|
+
"0 || 10 is 10 (0 is falsy). "
|
|
408
|
+
"0 ?? 10 is 0 (0 is not nullish). "
|
|
409
|
+
"Use ?? when 0, '', or false are valid values."),
|
|
410
|
+
|
|
411
|
+
("Template literals: Tagged templates",
|
|
412
|
+
"Tagged templates can process string: html`<div>${unsafe}</div>`. "
|
|
413
|
+
"The tag function receives strings array and values. "
|
|
414
|
+
"Useful for escaping, i18n, styled-components, SQL queries."),
|
|
415
|
+
|
|
416
|
+
("Spread operator: Use cases",
|
|
417
|
+
"Array copy: [...arr], merge: [...arr1, ...arr2]. "
|
|
418
|
+
"Object copy: {...obj}, merge: {...obj1, ...obj2}. "
|
|
419
|
+
"Function args: Math.max(...numbers). "
|
|
420
|
+
"Later spreads override earlier: {...defaults, ...userConfig}."),
|
|
421
|
+
|
|
422
|
+
("Rest parameters: Collecting arguments",
|
|
423
|
+
"function fn(first, ...rest) - rest is array of remaining args. "
|
|
424
|
+
"Must be last parameter. "
|
|
425
|
+
"Replaces deprecated arguments object. "
|
|
426
|
+
"Also in destructuring: const [head, ...tail] = arr."),
|
|
427
|
+
|
|
428
|
+
("Short-circuit evaluation: Common patterns",
|
|
429
|
+
"condition && doSomething() - execute if true. "
|
|
430
|
+
"value || defaultValue - use default if falsy. "
|
|
431
|
+
"value ?? defaultValue - use default if nullish (preferred for defaults). "
|
|
432
|
+
"Avoid complex logic - hard to read."),
|
|
433
|
+
|
|
434
|
+
("Default parameters: Function defaults",
|
|
435
|
+
"function fn(x = 10) - x is 10 if undefined. "
|
|
436
|
+
"Defaults evaluated at call time: fn(arr = []) - fresh array each call. "
|
|
437
|
+
"Can reference earlier params: fn(x, y = x * 2). "
|
|
438
|
+
"null doesn't trigger default (only undefined does)."),
|
|
439
|
+
|
|
440
|
+
("Object method shorthand",
|
|
441
|
+
"const obj = { method() {} } instead of method: function() {}. "
|
|
442
|
+
"const obj = { async method() {} } for async. "
|
|
443
|
+
"const obj = { *generator() {} } for generators. "
|
|
444
|
+
"const obj = { get prop() {}, set prop(v) {} } for accessors."),
|
|
445
|
+
|
|
446
|
+
("Class: Private fields",
|
|
447
|
+
"class C { #privateField = 0; #privateMethod() {} }. "
|
|
448
|
+
"Truly private - not accessible outside class. "
|
|
449
|
+
"Accessed with #: this.#privateField. "
|
|
450
|
+
"WeakMap alternative for older environments."),
|
|
451
|
+
]
|
|
452
|
+
|
|
453
|
+
# ============================================================================
|
|
454
|
+
# NODE.JS SPECIFIC PATTERNS
|
|
455
|
+
# ============================================================================
|
|
456
|
+
|
|
457
|
+
JS_NODEJS_PATTERNS = [
|
|
458
|
+
("Node: require vs import",
|
|
459
|
+
"CommonJS: const fs = require('fs') - synchronous, dynamic. "
|
|
460
|
+
"ES Modules: import fs from 'fs' - async, static. "
|
|
461
|
+
"Use 'type': 'module' in package.json for ESM. "
|
|
462
|
+
"Or .mjs extension for ESM, .cjs for CommonJS."),
|
|
463
|
+
|
|
464
|
+
("Node: __dirname and __filename in ESM",
|
|
465
|
+
"__dirname and __filename not available in ES modules. "
|
|
466
|
+
"Fix: import { fileURLToPath } from 'url'; "
|
|
467
|
+
"const __filename = fileURLToPath(import.meta.url); "
|
|
468
|
+
"const __dirname = path.dirname(__filename);"),
|
|
469
|
+
|
|
470
|
+
("Node: Callback error-first pattern",
|
|
471
|
+
"Node callbacks: callback(error, result). "
|
|
472
|
+
"Always handle error first: if (err) return handleError(err); "
|
|
473
|
+
"Use util.promisify to convert to Promise: "
|
|
474
|
+
"const readFile = util.promisify(fs.readFile);"),
|
|
475
|
+
|
|
476
|
+
("Node: Event emitter memory leak",
|
|
477
|
+
"Default max listeners is 10. Warning if exceeded. "
|
|
478
|
+
"emitter.setMaxListeners(20) to increase. "
|
|
479
|
+
"Always remove listeners when done: emitter.removeListener(). "
|
|
480
|
+
"Use once() for one-time listeners."),
|
|
481
|
+
|
|
482
|
+
("Node: process.nextTick vs setImmediate",
|
|
483
|
+
"nextTick runs before I/O callbacks (microtask). "
|
|
484
|
+
"setImmediate runs after I/O callbacks (macrotask). "
|
|
485
|
+
"Recursive nextTick can starve I/O - use setImmediate for recursive calls. "
|
|
486
|
+
"Promise callbacks also run in microtask queue."),
|
|
487
|
+
|
|
488
|
+
("Node: Buffer handling",
|
|
489
|
+
"Buffer.from(string, encoding) to create. "
|
|
490
|
+
"buf.toString(encoding) to convert back. "
|
|
491
|
+
"Allocate with Buffer.alloc(size) (zeroed) or Buffer.allocUnsafe(size) (faster, uninitialized). "
|
|
492
|
+
"Buffer.allocUnsafe may contain old memory - fill before use."),
|
|
493
|
+
|
|
494
|
+
("Node: Stream error handling",
|
|
495
|
+
"Always handle 'error' event on streams. "
|
|
496
|
+
"Unhandled error crashes process. "
|
|
497
|
+
"stream.on('error', handleError). "
|
|
498
|
+
"Use pipeline() for automatic error handling: "
|
|
499
|
+
"pipeline(source, transform, dest, callback);"),
|
|
500
|
+
|
|
501
|
+
("Node: Graceful shutdown",
|
|
502
|
+
"Handle SIGTERM/SIGINT for clean shutdown. "
|
|
503
|
+
"process.on('SIGTERM', () => { server.close(() => process.exit(0)); }); "
|
|
504
|
+
"Set timeout for forced exit if graceful takes too long. "
|
|
505
|
+
"Close database connections, finish pending requests."),
|
|
506
|
+
]
|
|
507
|
+
|
|
508
|
+
# ============================================================================
|
|
509
|
+
# DATABASE FUNCTIONS
|
|
510
|
+
# ============================================================================
|
|
511
|
+
|
|
512
|
+
def create_tables(conn: sqlite3.Connection):
|
|
513
|
+
"""Ensure tables exist (same schema as build_docs_db.py)"""
|
|
514
|
+
conn.execute("""
|
|
515
|
+
CREATE TABLE IF NOT EXISTS docs (
|
|
516
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
517
|
+
language TEXT NOT NULL,
|
|
518
|
+
category TEXT NOT NULL,
|
|
519
|
+
title TEXT NOT NULL,
|
|
520
|
+
content TEXT NOT NULL,
|
|
521
|
+
content_hash TEXT UNIQUE,
|
|
522
|
+
created_at REAL DEFAULT (julianday('now'))
|
|
523
|
+
)
|
|
524
|
+
""")
|
|
525
|
+
|
|
526
|
+
conn.execute("CREATE INDEX IF NOT EXISTS idx_docs_language ON docs(language)")
|
|
527
|
+
conn.execute("CREATE INDEX IF NOT EXISTS idx_docs_category ON docs(category)")
|
|
528
|
+
conn.execute("CREATE INDEX IF NOT EXISTS idx_docs_title ON docs(title)")
|
|
529
|
+
|
|
530
|
+
# FTS for full-text search
|
|
531
|
+
conn.execute("""
|
|
532
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS docs_fts USING fts5(
|
|
533
|
+
title, content, content='docs', content_rowid='id'
|
|
534
|
+
)
|
|
535
|
+
""")
|
|
536
|
+
|
|
537
|
+
conn.commit()
|
|
538
|
+
|
|
539
|
+
|
|
540
|
+
def insert_docs(conn: sqlite3.Connection, docs: List[Tuple[str, str]],
|
|
541
|
+
category: str, language: str = "javascript") -> int:
|
|
542
|
+
"""Insert documentation entries into database"""
|
|
543
|
+
inserted = 0
|
|
544
|
+
|
|
545
|
+
for title, content in docs:
|
|
546
|
+
content_hash = hashlib.md5(content.encode()).hexdigest()
|
|
547
|
+
|
|
548
|
+
try:
|
|
549
|
+
cursor = conn.execute("""
|
|
550
|
+
INSERT INTO docs (language, category, title, content, content_hash)
|
|
551
|
+
VALUES (?, ?, ?, ?, ?)
|
|
552
|
+
""", (language, category, title, content, content_hash))
|
|
553
|
+
|
|
554
|
+
# Update FTS
|
|
555
|
+
conn.execute("""
|
|
556
|
+
INSERT INTO docs_fts (rowid, title, content)
|
|
557
|
+
VALUES (?, ?, ?)
|
|
558
|
+
""", (cursor.lastrowid, title, content))
|
|
559
|
+
|
|
560
|
+
inserted += 1
|
|
561
|
+
|
|
562
|
+
except sqlite3.IntegrityError:
|
|
563
|
+
pass # Duplicate
|
|
564
|
+
|
|
565
|
+
conn.commit()
|
|
566
|
+
return inserted
|
|
567
|
+
|
|
568
|
+
|
|
569
|
+
def add_all_js_docs(db_path: str = OUTPUT_DB) -> dict:
|
|
570
|
+
"""Add all JavaScript documentation to the database"""
|
|
571
|
+
print(f"Adding JavaScript docs to: {db_path}")
|
|
572
|
+
|
|
573
|
+
conn = sqlite3.connect(db_path)
|
|
574
|
+
create_tables(conn)
|
|
575
|
+
|
|
576
|
+
stats = {}
|
|
577
|
+
|
|
578
|
+
# Add error patterns
|
|
579
|
+
count = insert_docs(conn, JS_ERROR_PATTERNS, "errors/common")
|
|
580
|
+
stats["Error Patterns"] = count
|
|
581
|
+
print(f" Added {count} error pattern sections")
|
|
582
|
+
|
|
583
|
+
# Add async/await patterns
|
|
584
|
+
count = insert_docs(conn, JS_ASYNC_PATTERNS, "async/patterns")
|
|
585
|
+
stats["Async/Await Patterns"] = count
|
|
586
|
+
print(f" Added {count} async/await sections")
|
|
587
|
+
|
|
588
|
+
# Add array/object gotchas
|
|
589
|
+
count = insert_docs(conn, JS_ARRAY_OBJECT_GOTCHAS, "methods/gotchas")
|
|
590
|
+
stats["Array/Object Gotchas"] = count
|
|
591
|
+
print(f" Added {count} array/object gotcha sections")
|
|
592
|
+
|
|
593
|
+
# Add scope patterns
|
|
594
|
+
count = insert_docs(conn, JS_SCOPE_PATTERNS, "scope/patterns")
|
|
595
|
+
stats["Scope/Closure Patterns"] = count
|
|
596
|
+
print(f" Added {count} scope/closure sections")
|
|
597
|
+
|
|
598
|
+
# Add type coercion
|
|
599
|
+
count = insert_docs(conn, JS_TYPE_COERCION, "types/coercion")
|
|
600
|
+
stats["Type Coercion"] = count
|
|
601
|
+
print(f" Added {count} type coercion sections")
|
|
602
|
+
|
|
603
|
+
# Add best practices
|
|
604
|
+
count = insert_docs(conn, JS_BEST_PRACTICES, "best-practices")
|
|
605
|
+
stats["Best Practices"] = count
|
|
606
|
+
print(f" Added {count} best practice sections")
|
|
607
|
+
|
|
608
|
+
# Add Node.js patterns
|
|
609
|
+
count = insert_docs(conn, JS_NODEJS_PATTERNS, "nodejs/patterns")
|
|
610
|
+
stats["Node.js Patterns"] = count
|
|
611
|
+
print(f" Added {count} Node.js pattern sections")
|
|
612
|
+
|
|
613
|
+
# Get totals
|
|
614
|
+
cursor = conn.execute("""
|
|
615
|
+
SELECT language, COUNT(*)
|
|
616
|
+
FROM docs
|
|
617
|
+
GROUP BY language
|
|
618
|
+
""")
|
|
619
|
+
|
|
620
|
+
print("\nTotal by language:")
|
|
621
|
+
for row in cursor:
|
|
622
|
+
print(f" {row[0]}: {row[1]} sections")
|
|
623
|
+
|
|
624
|
+
cursor = conn.execute("SELECT COUNT(*) FROM docs WHERE language = 'javascript'")
|
|
625
|
+
total_js = cursor.fetchone()[0]
|
|
626
|
+
|
|
627
|
+
conn.close()
|
|
628
|
+
|
|
629
|
+
stats["Total JS Sections"] = total_js
|
|
630
|
+
return stats
|
|
631
|
+
|
|
632
|
+
|
|
633
|
+
def search_docs(query: str, db_path: str = OUTPUT_DB, limit: int = 5):
|
|
634
|
+
"""Search the docs database (for testing)"""
|
|
635
|
+
conn = sqlite3.connect(db_path)
|
|
636
|
+
|
|
637
|
+
cursor = conn.execute("""
|
|
638
|
+
SELECT d.language, d.category, d.title,
|
|
639
|
+
snippet(docs_fts, 1, '>>>', '<<<', '...', 50) as snippet
|
|
640
|
+
FROM docs_fts
|
|
641
|
+
JOIN docs d ON docs_fts.rowid = d.id
|
|
642
|
+
WHERE docs_fts MATCH ?
|
|
643
|
+
ORDER BY rank
|
|
644
|
+
LIMIT ?
|
|
645
|
+
""", (query, limit))
|
|
646
|
+
|
|
647
|
+
results = cursor.fetchall()
|
|
648
|
+
conn.close()
|
|
649
|
+
|
|
650
|
+
return results
|
|
651
|
+
|
|
652
|
+
|
|
653
|
+
if __name__ == "__main__":
|
|
654
|
+
import argparse
|
|
655
|
+
|
|
656
|
+
parser = argparse.ArgumentParser(description="Add JavaScript docs to Mini-COT database")
|
|
657
|
+
parser.add_argument("--db", type=str, default=OUTPUT_DB, help="Database path")
|
|
658
|
+
parser.add_argument("--search", type=str, help="Search the database")
|
|
659
|
+
parser.add_argument("--stats", action="store_true", help="Show statistics")
|
|
660
|
+
|
|
661
|
+
args = parser.parse_args()
|
|
662
|
+
|
|
663
|
+
if args.search:
|
|
664
|
+
results = search_docs(args.search, args.db)
|
|
665
|
+
for lang, cat, title, snippet in results:
|
|
666
|
+
print(f"\n[{lang}] {cat}/{title}")
|
|
667
|
+
print(f" {snippet}")
|
|
668
|
+
elif args.stats:
|
|
669
|
+
conn = sqlite3.connect(args.db)
|
|
670
|
+
cursor = conn.execute("""
|
|
671
|
+
SELECT language, category, COUNT(*)
|
|
672
|
+
FROM docs
|
|
673
|
+
GROUP BY language, category
|
|
674
|
+
ORDER BY language, COUNT(*) DESC
|
|
675
|
+
""")
|
|
676
|
+
print("Documentation sections by category:")
|
|
677
|
+
for row in cursor:
|
|
678
|
+
print(f" {row[0]}/{row[1]}: {row[2]}")
|
|
679
|
+
conn.close()
|
|
680
|
+
else:
|
|
681
|
+
stats = add_all_js_docs(args.db)
|
|
682
|
+
print("\n=== JavaScript Documentation Added ===")
|
|
683
|
+
for key, value in stats.items():
|
|
684
|
+
print(f" {key}: {value}")
|