memorylink 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cursorrules +0 -0
- package/.github/workflows/buddy-check.yml +105 -0
- package/.github/workflows/memorylink-preflight.yml +63 -0
- package/.github/workflows/release-on-tag.yml +58 -0
- package/.github/workflows/stress-tests.yml +79 -0
- package/.memorylinkignore +24 -0
- package/5000_SCENARIOS_TEST_RESULTS.md +174 -0
- package/ADVANCED_SCENARIOS_TEST_RESULTS.md +377 -0
- package/AGGRESSIVE_RANDOM_TEST_RESULTS.md +134 -0
- package/AI_CONSENSUS_ANALYSIS.md +138 -0
- package/AI_CONSENSUS_ANALYSIS_FINAL.md +345 -0
- package/AI_CONSENSUS_ANALYSIS_v2.md +188 -0
- package/AI_CONSENSUS_ANALYSIS_v3.md +246 -0
- package/AI_CONSENSUS_ANALYSIS_v4.md +309 -0
- package/AI_CONSENSUS_ANALYSIS_v5.md +311 -0
- package/AI_CONSENSUS_ANALYSIS_v6.md +432 -0
- package/AI_PANEL_CLARIFICATION_REQUEST.md +37 -0
- package/AI_RESPONSES_BLACKBOX.md +338 -0
- package/AI_RESPONSES_CHATGPT.md +379 -0
- package/AI_RESPONSES_CLAUDE.md +464 -0
- package/AI_RESPONSES_CONSOLIDATED.md +560 -0
- package/AI_RESPONSES_DEEPSEEK.md +341 -0
- package/AI_RESPONSES_GEMINI.md +262 -0
- package/AI_RESPONSES_GROK.md +335 -0
- package/AI_RESPONSES_MANUS.md +246 -0
- package/AI_RESPONSES_PERPLEXITY.md +295 -0
- package/AI_RESPONSES_QWEN.md +335 -0
- package/AI_REVIEW_REQUEST.md +333 -0
- package/AI_STRATEGIC_CONSENSUS_COMPARISON.md +507 -0
- package/AI_VALIDATION_AND_GAP_ANALYSIS.md +410 -0
- package/ALL_10_AI_RESPONSES_FINAL.md +435 -0
- package/ALL_3_AI_RESPONSES_FINAL.md +305 -0
- package/ALL_4_AI_RESPONSES_FINAL.md +335 -0
- package/ALL_5_AI_RESPONSES_FINAL.md +349 -0
- package/ALL_6_AI_RESPONSES_FINAL.md +354 -0
- package/ALL_7_AI_RESPONSES_FINAL.md +369 -0
- package/ALL_8_AI_RESPONSES_FINAL.md +381 -0
- package/ALL_9_AI_RESPONSES_FINAL.md +398 -0
- package/ALL_AI_RESPONSES_TRACKER.md +152 -0
- package/ALL_AI_RESPONSES_VALIDATED.md +261 -0
- package/ALL_FEATURES_COMPLETE.md +198 -0
- package/BREAK_IT_TEST_RESULTS.md +273 -0
- package/BUDDY_CHECK_STRESS_TEST_PLAN.md +1089 -0
- package/CHANGELOG.md +135 -0
- package/CHATGPT_GAP_ANALYSIS.md +286 -0
- package/CHATGPT_V2_ANALYSIS.md +109 -0
- package/CHECK_MISSING_FEATURES.md +192 -0
- package/CI_CD_INTEGRATION.md +421 -0
- package/COMPETITIVE_LAUNCH_STRATEGY.md +257 -0
- package/COMPLETE_COMPETITIVE_ANALYSIS_ALL_AIS.md +339 -0
- package/COMPLETE_DEVELOPMENT_PLAN_ALL_AIS.md +622 -0
- package/COMPREHENSIVE_FEATURE_ANALYSIS_100_PERCENT.md +423 -0
- package/COMPREHENSIVE_TEST_SUMMARY.md +314 -0
- package/CONTINUOUS_TESTING_COMPLETE.md +268 -0
- package/CONTINUOUS_TESTING_GUIDE.md +328 -0
- package/CONTINUOUS_TEST_FINAL_RESULTS.md +148 -0
- package/CONTINUOUS_TEST_INSTRUCTIONS.md +173 -0
- package/CONTINUOUS_TEST_RESULTS.md +194 -0
- package/CONTINUOUS_TEST_STATUS.md +68 -0
- package/CURSOR_AI_BUDDY_CHECK_GUIDE.md +439 -0
- package/CURSOR_AI_INTEGRATION_GUIDE.md +775 -0
- package/CURSOR_AI_V1.4_NEXT_STEPS.md +314 -0
- package/CURSOR_BREAK_IT_TEST.md +389 -0
- package/CURSOR_DOCUMENTATION_RULES.md +259 -0
- package/CURSOR_HOSTILE_TEST_DOCUMENT.md +343 -0
- package/CURSOR_PROMPTS_FOR_TESTING.md +252 -0
- package/DEPLOYMENT_GUIDE.md +493 -0
- package/DEVELOPMENT_AND_OVERNIGHT_TESTING.md +304 -0
- package/DEVELOPMENT_PROGRESS.md +185 -0
- package/DOCS_CLEANUP_SUMMARY.md +192 -0
- package/DOC_CONFIDENTIALITY_RULES.md +259 -0
- package/E2E_TEST_REPORT_v1.3.0.md +196 -0
- package/E2E_TEST_RESULTS.md +250 -0
- package/E2E_TEST_SCENARIOS.md +357 -0
- package/END_TO_END_TEST_REPORT.md +217 -0
- package/ENHANCEMENT_RECOMMENDATIONS.md +368 -0
- package/EPIPE_FIX_SUMMARY.md +177 -0
- package/FEEDBACK_TEMPLATE.md +173 -0
- package/FINAL_100_PERCENT_CONFIRMATION.md +319 -0
- package/FINAL_8_AI_CONSENSUS_SUMMARY.md +355 -0
- package/FINAL_CONFIRMATION.md +143 -0
- package/FINAL_E2E_TEST_REPORT.md +248 -0
- package/FINAL_E2E_TEST_RESULTS.md +212 -0
- package/FINAL_LAUNCH_CLARIFICATION_SUMMARY.md +101 -0
- package/FINAL_LAUNCH_PLAN_BASED_ON_AI_CONSENSUS.md +410 -0
- package/FINAL_LAUNCH_SUMMARY.md +176 -0
- package/FINAL_PRODUCT_TEST.md +316 -0
- package/FINAL_PROJECT_STATUS.md +407 -0
- package/FINAL_STATUS_REPORT.md +244 -0
- package/FINAL_STRATEGIC_PLAN_9_AIS.md +576 -0
- package/FINAL_TEST_EXECUTION_REPORT.md +252 -0
- package/FINAL_VALIDATION_DOCUMENT.md +238 -0
- package/FINAL_VALIDATION_SUMMARY.md +230 -0
- package/FIX_SPECIAL_CHARS.sh +13 -0
- package/FRESH_SCENARIOS_TEST_RESULTS.md +358 -0
- package/GAP_EVALUATION_TEMPLATE.md +146 -0
- package/GITHUB_SETUP_GUIDE.md +193 -0
- package/HOSTILE_TEST_RESULTS.md +221 -0
- package/HOW_MEMORYLINK_HELPS_AI.md +401 -0
- package/IMPLEMENTATION_PLANS_DETAILED.md +516 -0
- package/LAUNCH_CHECKLIST.md +247 -0
- package/LAUNCH_DOCS_FRAMEWORK.md +378 -0
- package/LAUNCH_READINESS.md +148 -0
- package/LAUNCH_SEQUENCE.md +137 -0
- package/LICENSE +67 -0
- package/MARKET_ANALYSIS_AND_STRATEGY.md +280 -0
- package/MASTER_AI_VERIFICATION_DOCUMENT.md +1085 -0
- package/MASTER_VALIDATION_DOCUMENT.md +818 -0
- package/MINORITY_OPINION_ANALYSIS.md +464 -0
- package/NEW_RANDOM_TEST_RESULTS.md +127 -0
- package/NEW_SCENARIOS_TEST_RESULTS.md +272 -0
- package/NEXT_ACTIONS_COMPLETE.md +137 -0
- package/NEXT_PLAN_BASED_ON_AI_ANALYSES.md +413 -0
- package/NEXT_PLAN_BASED_ON_ALL_AI_RESPONSES.md +558 -0
- package/NEXT_STEPS.md +120 -0
- package/NEXT_STEPS_ACTION_PLAN.md +369 -0
- package/NPM_2FA_FIX.md +113 -0
- package/NPM_PUBLISH_TROUBLESHOOTING.md +230 -0
- package/PERPLEXITY_AI_VALIDATION_REQUEST.md +318 -0
- package/PERPLEXITY_AI_VALIDATION_RESPONSE.md +172 -0
- package/PERPLEXITY_BREAK_IT_VALIDATION.md +262 -0
- package/PERPLEXITY_DOCS_VALIDATION.md +237 -0
- package/PERPLEXITY_FEEDBACK_ACTION_PLAN.md +271 -0
- package/PERPLEXITY_FINAL_E2E_VALIDATION.md +210 -0
- package/PERPLEXITY_FINAL_SUMMARY.md +211 -0
- package/PERPLEXITY_PHASE2_VALIDATION.md +270 -0
- package/PERPLEXITY_PHASE2_VALIDATION_RESPONSE.md +136 -0
- package/PERPLEXITY_PRIORITY2_VALIDATION.md +321 -0
- package/PERPLEXITY_TELEMETRY_EXPLANATION.md +174 -0
- package/PERPLEXITY_TELEMETRY_VALIDATION.md +118 -0
- package/PERPLEXITY_TELEMETRY_VALIDATION_RESPONSE.md +154 -0
- package/PERPLEXITY_USER_GUIDE_VALIDATION.md +236 -0
- package/PERPLEXITY_VALIDATION_REQUEST.md +427 -0
- package/PERPLEXITY_VALIDATION_REQUEST_v1.5.1.md +190 -0
- package/PHASE_2_COMPLETE.md +149 -0
- package/PRE_LAUNCH_SECURITY_AUDIT.md +155 -0
- package/PRE_LAUNCH_TEST_CYCLE.md +326 -0
- package/PRE_LAUNCH_TEST_RESULTS.md +148 -0
- package/PROJECT_STRUCTURE_PLAN.md +104 -0
- package/PUBLIC_DOCS.md +90 -0
- package/PUBLISH_CHECKLIST.md +134 -0
- package/PUSH_INSTRUCTIONS.md +120 -0
- package/QUICK_START_TEST_CYCLE.md +76 -0
- package/README.md +557 -0
- package/README_TEST_INSTRUCTIONS.md +65 -0
- package/README_v1.5.1.md +137 -0
- package/REALISTIC_ASSESSMENT.md +186 -0
- package/REAL_WORLD_VALIDATION_COMPLETE.md +98 -0
- package/RED_TEAM_TESTING_GUIDE.md +302 -0
- package/RELEASE_NOTES_v1.0.0.md +125 -0
- package/RELEASE_NOTES_v1.5.1.md +105 -0
- package/REQUEST_COUNTERS.md +22 -0
- package/ROADMAP_v1.6.md +335 -0
- package/ROUND3_RANDOM_TEST_RESULTS.md +135 -0
- package/SECURITY_MODEL.md +577 -0
- package/SESSION_SUMMARY_CURRENT_STATE.md +206 -0
- package/SESSION_SUMMARY_REVIEW.md +203 -0
- package/SINGLE_RUN_ALL_SCENARIOS_TEST.sh +129 -0
- package/STRATEGIC_QUESTIONS_FOR_AI_VALIDATION.md +277 -0
- package/STRESS_TEST_CHECK_RESULTS.md +154 -0
- package/STRESS_TEST_EXECUTION_GUIDE.md +284 -0
- package/STRESS_TEST_IMPLEMENTATION_SUMMARY.md +221 -0
- package/TELEMETRY.md +370 -0
- package/TELEMETRY_COMPLETE_SUMMARY.md +231 -0
- package/TELEMETRY_CONTROL_POLICY.md +135 -0
- package/TELEMETRY_DESIGN_SUMMARY.md +210 -0
- package/TELEMETRY_FINAL_STATUS.md +178 -0
- package/TELEMETRY_NEXT_STEPS.md +258 -0
- package/TELEMETRY_TESTING_NOTES.md +217 -0
- package/TELEMETRY_WORK_COMPLETE.md +237 -0
- package/TEST_PLAN_v1.0.1.md +194 -0
- package/TEST_RESULTS_SUMMARY.md +128 -0
- package/TREE_SITTER_EXPLANATION.md +303 -0
- package/TROUBLESHOOTING.md +62 -0
- package/ULTIMATE_SCENARIOS_TEST_RESULTS.md +366 -0
- package/USER_FEEDBACK_TEMPLATE.md +104 -0
- package/USER_GUIDE.md +809 -0
- package/V1.1_DEVELOPMENT_COMPLETE.md +299 -0
- package/V1.1_SCENARIOS_ADDED.md +161 -0
- package/V1.2_CODE_STRUCTURE_IMPLEMENTATION.md +243 -0
- package/V1.3_COMPETITIVE_LAUNCH_COMPLETE.md +253 -0
- package/V1.3_COMPETITIVE_LAUNCH_IMPLEMENTATION_PLAN.md +385 -0
- package/V1.3_TEAM_PATTERNS_IMPLEMENTATION.md +183 -0
- package/V1.4_BUILD_PLAN_IMPLEMENTATION.md +698 -0
- package/V1.4_COMPLETE_SUMMARY_FOR_AI_REVIEW.md +516 -0
- package/V1.4_COMPLETE_VALIDATION_DOCUMENT.md +601 -0
- package/V1.4_DEVELOPMENT_PROGRESS.md +117 -0
- package/V1.4_FINAL_STATUS.md +147 -0
- package/V1.4_INTEGRATION_COMPLETE.md +207 -0
- package/V1.4_INTEGRATION_TEST_RESULTS.md +181 -0
- package/V1.4_OBSERVABILITY_AND_OVERRIDE_COMPLETE.md +180 -0
- package/V1.4_PHASE_3_COMPLETE.md +135 -0
- package/V1.4_RUNTIME_TESTING_GUIDE.md +364 -0
- package/V1.4_VERIFICATION_REPORT.md +199 -0
- package/V1.5.1_COMPLETE_SUMMARY.md +234 -0
- package/V1.5.1_RELEASE_NOTES.md +206 -0
- package/V1.5.1_RELEASE_READY.md +198 -0
- package/V1.5_COMPLETE_SUMMARY.md +264 -0
- package/V1.5_COMPLETE_VERIFICATION.md +183 -0
- package/V1.5_DESIGN_NOTES.md +272 -0
- package/V1.5_FINAL_STATUS.md +224 -0
- package/V1.5_IMPLEMENTATION_SUMMARY.md +113 -0
- package/V1.5_IMPROVEMENTS_COMPLETE.md +205 -0
- package/V1.5_PHASE1_COMPLETE.md +183 -0
- package/V1.5_PHASE1_PROGRESS.md +102 -0
- package/V1.5_PHASE2_COMPLETE.md +133 -0
- package/V1.5_PHASE2_PLAN.md +185 -0
- package/V1.5_PRIORITIZATION.md +313 -0
- package/V1.5_PRIORITY2_COMPLETE.md +150 -0
- package/V1.5_TESTING_COMPLETE.md +69 -0
- package/V1.5_TEST_RESULTS.md +178 -0
- package/V1.5_VALIDATION_RESULTS.md +209 -0
- package/V1.6_GAP_TRACKING.md +118 -0
- package/VALIDATION_SUMMARY_FOR_PERPLEXITY.md +83 -0
- package/VERIFICATION_REPORT.md +220 -0
- package/VERSION_UPDATE_VERIFICATION.md +76 -0
- package/config/tsconfig.json +21 -0
- package/dist/cli.d.ts +9 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +1114 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/archive.d.ts +20 -0
- package/dist/commands/archive.d.ts.map +1 -0
- package/dist/commands/archive.js +231 -0
- package/dist/commands/archive.js.map +1 -0
- package/dist/commands/auto-context.d.ts +22 -0
- package/dist/commands/auto-context.d.ts.map +1 -0
- package/dist/commands/auto-context.js +172 -0
- package/dist/commands/auto-context.js.map +1 -0
- package/dist/commands/auto-log.d.ts +30 -0
- package/dist/commands/auto-log.d.ts.map +1 -0
- package/dist/commands/auto-log.js +500 -0
- package/dist/commands/auto-log.js.map +1 -0
- package/dist/commands/change.d.ts +13 -0
- package/dist/commands/change.d.ts.map +1 -0
- package/dist/commands/change.js +254 -0
- package/dist/commands/change.js.map +1 -0
- package/dist/commands/checkpoint.d.ts +26 -0
- package/dist/commands/checkpoint.d.ts.map +1 -0
- package/dist/commands/checkpoint.js +326 -0
- package/dist/commands/checkpoint.js.map +1 -0
- package/dist/commands/configure.d.ts +21 -0
- package/dist/commands/configure.d.ts.map +1 -0
- package/dist/commands/configure.js +283 -0
- package/dist/commands/configure.js.map +1 -0
- package/dist/commands/consolidate.d.ts +19 -0
- package/dist/commands/consolidate.d.ts.map +1 -0
- package/dist/commands/consolidate.js +236 -0
- package/dist/commands/consolidate.js.map +1 -0
- package/dist/commands/context.d.ts +10 -0
- package/dist/commands/context.d.ts.map +1 -0
- package/dist/commands/context.js +571 -0
- package/dist/commands/context.js.map +1 -0
- package/dist/commands/detect.d.ts +13 -0
- package/dist/commands/detect.d.ts.map +1 -0
- package/dist/commands/detect.js +187 -0
- package/dist/commands/detect.js.map +1 -0
- package/dist/commands/doctor.d.ts +19 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +1272 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/export.d.ts +3 -0
- package/dist/commands/export.d.ts.map +1 -0
- package/dist/commands/export.js +95 -0
- package/dist/commands/export.js.map +1 -0
- package/dist/commands/graph.d.ts +25 -0
- package/dist/commands/graph.d.ts.map +1 -0
- package/dist/commands/graph.js +208 -0
- package/dist/commands/graph.js.map +1 -0
- package/dist/commands/hooks.d.ts +9 -0
- package/dist/commands/hooks.d.ts.map +1 -0
- package/dist/commands/hooks.js +240 -0
- package/dist/commands/hooks.js.map +1 -0
- package/dist/commands/impact.d.ts +18 -0
- package/dist/commands/impact.d.ts.map +1 -0
- package/dist/commands/impact.js +163 -0
- package/dist/commands/impact.js.map +1 -0
- package/dist/commands/index-vector.d.ts +13 -0
- package/dist/commands/index-vector.d.ts.map +1 -0
- package/dist/commands/index-vector.js +103 -0
- package/dist/commands/index-vector.js.map +1 -0
- package/dist/commands/index.d.ts +37 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +105 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/init.d.ts +8 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +200 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/inject.d.ts +22 -0
- package/dist/commands/inject.d.ts.map +1 -0
- package/dist/commands/inject.js +394 -0
- package/dist/commands/inject.js.map +1 -0
- package/dist/commands/learn.d.ts +13 -0
- package/dist/commands/learn.d.ts.map +1 -0
- package/dist/commands/learn.js +282 -0
- package/dist/commands/learn.js.map +1 -0
- package/dist/commands/lock.d.ts +35 -0
- package/dist/commands/lock.d.ts.map +1 -0
- package/dist/commands/lock.js +308 -0
- package/dist/commands/lock.js.map +1 -0
- package/dist/commands/memory.d.ts +15 -0
- package/dist/commands/memory.d.ts.map +1 -0
- package/dist/commands/memory.js +366 -0
- package/dist/commands/memory.js.map +1 -0
- package/dist/commands/migrate.d.ts +22 -0
- package/dist/commands/migrate.d.ts.map +1 -0
- package/dist/commands/migrate.js +458 -0
- package/dist/commands/migrate.js.map +1 -0
- package/dist/commands/patterns.d.ts +18 -0
- package/dist/commands/patterns.d.ts.map +1 -0
- package/dist/commands/patterns.js +120 -0
- package/dist/commands/patterns.js.map +1 -0
- package/dist/commands/protect.d.ts +12 -0
- package/dist/commands/protect.d.ts.map +1 -0
- package/dist/commands/protect.js +181 -0
- package/dist/commands/protect.js.map +1 -0
- package/dist/commands/quickstart.d.ts +11 -0
- package/dist/commands/quickstart.d.ts.map +1 -0
- package/dist/commands/quickstart.js +256 -0
- package/dist/commands/quickstart.js.map +1 -0
- package/dist/commands/repair.d.ts +13 -0
- package/dist/commands/repair.d.ts.map +1 -0
- package/dist/commands/repair.js +157 -0
- package/dist/commands/repair.js.map +1 -0
- package/dist/commands/resolve.d.ts +19 -0
- package/dist/commands/resolve.d.ts.map +1 -0
- package/dist/commands/resolve.js +355 -0
- package/dist/commands/resolve.js.map +1 -0
- package/dist/commands/roadmap.d.ts +5 -0
- package/dist/commands/roadmap.d.ts.map +1 -0
- package/dist/commands/roadmap.js +23 -0
- package/dist/commands/roadmap.js.map +1 -0
- package/dist/commands/scopes.d.ts +10 -0
- package/dist/commands/scopes.d.ts.map +1 -0
- package/dist/commands/scopes.js +80 -0
- package/dist/commands/scopes.js.map +1 -0
- package/dist/commands/search.d.ts +9 -0
- package/dist/commands/search.d.ts.map +1 -0
- package/dist/commands/search.js +313 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/setup.d.ts +13 -0
- package/dist/commands/setup.d.ts.map +1 -0
- package/dist/commands/setup.js +405 -0
- package/dist/commands/setup.js.map +1 -0
- package/dist/commands/snippet.d.ts +23 -0
- package/dist/commands/snippet.d.ts.map +1 -0
- package/dist/commands/snippet.js +235 -0
- package/dist/commands/snippet.js.map +1 -0
- package/dist/commands/stats.d.ts +15 -0
- package/dist/commands/stats.d.ts.map +1 -0
- package/dist/commands/stats.js +502 -0
- package/dist/commands/stats.js.map +1 -0
- package/dist/commands/status.d.ts +8 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +134 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/suggest-tags.d.ts +9 -0
- package/dist/commands/suggest-tags.d.ts.map +1 -0
- package/dist/commands/suggest-tags.js +95 -0
- package/dist/commands/suggest-tags.js.map +1 -0
- package/dist/commands/sync-rules.d.ts +14 -0
- package/dist/commands/sync-rules.d.ts.map +1 -0
- package/dist/commands/sync-rules.js +211 -0
- package/dist/commands/sync-rules.js.map +1 -0
- package/dist/commands/sync.d.ts +24 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +330 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/commands/telemetry-test.d.ts +24 -0
- package/dist/commands/telemetry-test.d.ts.map +1 -0
- package/dist/commands/telemetry-test.js +84 -0
- package/dist/commands/telemetry-test.js.map +1 -0
- package/dist/commands/template.d.ts +16 -0
- package/dist/commands/template.d.ts.map +1 -0
- package/dist/commands/template.js +122 -0
- package/dist/commands/template.js.map +1 -0
- package/dist/commands/validate.d.ts +11 -0
- package/dist/commands/validate.d.ts.map +1 -0
- package/dist/commands/validate.js +144 -0
- package/dist/commands/validate.js.map +1 -0
- package/dist/commands/watch-preferences.d.ts +17 -0
- package/dist/commands/watch-preferences.d.ts.map +1 -0
- package/dist/commands/watch-preferences.js +172 -0
- package/dist/commands/watch-preferences.js.map +1 -0
- package/dist/commands/watch.d.ts +11 -0
- package/dist/commands/watch.d.ts.map +1 -0
- package/dist/commands/watch.js +223 -0
- package/dist/commands/watch.js.map +1 -0
- package/dist/config/thresholds.d.ts +8 -0
- package/dist/config/thresholds.d.ts.map +1 -0
- package/dist/config/thresholds.js +10 -0
- package/dist/config/thresholds.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/memorylink.d.ts +91 -0
- package/dist/memorylink.d.ts.map +1 -0
- package/dist/memorylink.js +208 -0
- package/dist/memorylink.js.map +1 -0
- package/dist/search/local-embeddings.d.ts +21 -0
- package/dist/search/local-embeddings.d.ts.map +1 -0
- package/dist/search/local-embeddings.js +87 -0
- package/dist/search/local-embeddings.js.map +1 -0
- package/dist/search/vector-search.d.ts +58 -0
- package/dist/search/vector-search.d.ts.map +1 -0
- package/dist/search/vector-search.js +535 -0
- package/dist/search/vector-search.js.map +1 -0
- package/dist/server/mcp-server.d.ts +18 -0
- package/dist/server/mcp-server.d.ts.map +1 -0
- package/dist/server/mcp-server.js +293 -0
- package/dist/server/mcp-server.js.map +1 -0
- package/dist/telemetry.d.ts +92 -0
- package/dist/telemetry.d.ts.map +1 -0
- package/dist/telemetry.js +339 -0
- package/dist/telemetry.js.map +1 -0
- package/dist/telemetry.test.d.ts +13 -0
- package/dist/telemetry.test.d.ts.map +1 -0
- package/dist/telemetry.test.js +324 -0
- package/dist/telemetry.test.js.map +1 -0
- package/dist/test-runner/TestRunner.d.ts +68 -0
- package/dist/test-runner/TestRunner.d.ts.map +1 -0
- package/dist/test-runner/TestRunner.js +384 -0
- package/dist/test-runner/TestRunner.js.map +1 -0
- package/dist/test-runner/performance-test.d.ts +36 -0
- package/dist/test-runner/performance-test.d.ts.map +1 -0
- package/dist/test-runner/performance-test.js +163 -0
- package/dist/test-runner/performance-test.js.map +1 -0
- package/dist/test-runner/run-tests.d.ts +7 -0
- package/dist/test-runner/run-tests.d.ts.map +1 -0
- package/dist/test-runner/run-tests.js +167 -0
- package/dist/test-runner/run-tests.js.map +1 -0
- package/dist/types.d.ts +400 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +81 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/batch-commits.d.ts +48 -0
- package/dist/utils/batch-commits.d.ts.map +1 -0
- package/dist/utils/batch-commits.js +164 -0
- package/dist/utils/batch-commits.js.map +1 -0
- package/dist/utils/code-structure.d.ts +62 -0
- package/dist/utils/code-structure.d.ts.map +1 -0
- package/dist/utils/code-structure.js +582 -0
- package/dist/utils/code-structure.js.map +1 -0
- package/dist/utils/commit-patterns.d.ts +24 -0
- package/dist/utils/commit-patterns.d.ts.map +1 -0
- package/dist/utils/commit-patterns.js +78 -0
- package/dist/utils/commit-patterns.js.map +1 -0
- package/dist/utils/observability.d.ts +47 -0
- package/dist/utils/observability.d.ts.map +1 -0
- package/dist/utils/observability.js +137 -0
- package/dist/utils/observability.js.map +1 -0
- package/dist/utils/quality.d.ts +32 -0
- package/dist/utils/quality.d.ts.map +1 -0
- package/dist/utils/quality.js +207 -0
- package/dist/utils/quality.js.map +1 -0
- package/dist/utils/semantic-search.d.ts +29 -0
- package/dist/utils/semantic-search.d.ts.map +1 -0
- package/dist/utils/semantic-search.js +167 -0
- package/dist/utils/semantic-search.js.map +1 -0
- package/dist/utils/streaming.d.ts +24 -0
- package/dist/utils/streaming.d.ts.map +1 -0
- package/dist/utils/streaming.js +121 -0
- package/dist/utils/streaming.js.map +1 -0
- package/dist/utils/tag-suggestions.d.ts +18 -0
- package/dist/utils/tag-suggestions.d.ts.map +1 -0
- package/dist/utils/tag-suggestions.js +103 -0
- package/dist/utils/tag-suggestions.js.map +1 -0
- package/dist/utils/team-patterns.d.ts +48 -0
- package/dist/utils/team-patterns.d.ts.map +1 -0
- package/dist/utils/team-patterns.js +413 -0
- package/dist/utils/team-patterns.js.map +1 -0
- package/dist/utils/templates.d.ts +36 -0
- package/dist/utils/templates.d.ts.map +1 -0
- package/dist/utils/templates.js +200 -0
- package/dist/utils/templates.js.map +1 -0
- package/dist/utils/tree-sitter-parser.d.ts +20 -0
- package/dist/utils/tree-sitter-parser.d.ts.map +1 -0
- package/dist/utils/tree-sitter-parser.js +259 -0
- package/dist/utils/tree-sitter-parser.js.map +1 -0
- package/dist/utils/v1.6-patterns.d.ts +117 -0
- package/dist/utils/v1.6-patterns.d.ts.map +1 -0
- package/dist/utils/v1.6-patterns.js +201 -0
- package/dist/utils/v1.6-patterns.js.map +1 -0
- package/dist/utils.d.ts +176 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +822 -0
- package/dist/utils.js.map +1 -0
- package/docs/1000_SCENARIOS_TEST_RESULTS.md +138 -0
- package/docs/1000_UNIQUE_SCENARIOS_TEST.md +171 -0
- package/docs/100_PERCENT_PASS_RATE_VERIFICATION.md +111 -0
- package/docs/5000_SCENARIOS_ISSUE_ANALYSIS.md +96 -0
- package/docs/5000_SCENARIOS_TEST_PLAN.md +281 -0
- package/docs/AGENT_CONTRACT.md +240 -0
- package/docs/AI_RESPONSE_ANALYZER.md +157 -0
- package/docs/AI_RESPONSE_TRACKER.md +923 -0
- package/docs/AI_TESTING_PROMPT.md +307 -0
- package/docs/AI_VALIDATION_PROMPTS.md +366 -0
- package/docs/ALL_AI_ANALYSES_CONSOLIDATED.md +354 -0
- package/docs/ALL_AI_CONSOLIDATION_FINAL.md +372 -0
- package/docs/ALL_AI_TEST_CONSOLIDATION.md +290 -0
- package/docs/ALL_AI_VALIDATION_SYNTHESIS.md +241 -0
- package/docs/BEST_TESTING_SOLUTION.md +227 -0
- package/docs/BLACKBOX_AI_ANALYSIS.md +288 -0
- package/docs/BLACKBOX_AI_CLARIFICATION.md +55 -0
- package/docs/BLACKBOX_AI_STRATEGIC_VALIDATION.md +283 -0
- package/docs/BLACKBOX_AI_VALIDATION_RESPONSE.md +251 -0
- package/docs/BLACKBOX_AI_VALIDATION_RESPONSE_v2.md +402 -0
- package/docs/BLACKBOX_LAUNCH_VALIDATION.md +25 -0
- package/docs/BLACKBOX_SUPERMEMORY_VALIDATION_AND_PLAN.md +50 -0
- package/docs/CAPACITY_AND_ALTERNATIVES_ANALYSIS.md +289 -0
- package/docs/CHATGPT_AI_CLARIFICATION.md +65 -0
- package/docs/CHATGPT_FINAL_VALIDATION.md +348 -0
- package/docs/CHATGPT_IMPLEMENTATION_GUIDE.md +325 -0
- package/docs/CHATGPT_LAUNCH_VALIDATION.md +47 -0
- package/docs/CHATGPT_MEMORY_QUALITY_AND_VSCODE_CHECK.md +43 -0
- package/docs/CHATGPT_SCOPE_REALITY_CHECK.md +35 -0
- package/docs/CHATGPT_STRATEGIC_VALIDATION.md +329 -0
- package/docs/CHATGPT_VALIDATION_RESPONSE.md +332 -0
- package/docs/CHATGPT_VALIDATION_RESPONSE_v2.md +294 -0
- package/docs/CHATGPT_VALIDATION_RESULTS.md +143 -0
- package/docs/CLAUDE_AI_ANALYSIS.md +692 -0
- package/docs/CLAUDE_AI_CLARIFICATION.md +67 -0
- package/docs/CLAUDE_AI_STRATEGIC_VALIDATION.md +578 -0
- package/docs/CLAUDE_AI_VALIDATION_RESPONSE.md +374 -0
- package/docs/CLAUDE_AI_VALIDATION_RESPONSE_v2.md +463 -0
- package/docs/CLAUDE_FINAL_VALIDATION.md +679 -0
- package/docs/CLAUDE_LAUNCH_VALIDATION.md +27 -0
- package/docs/CLAUDE_SUPERMEMORY_LAUNCH_PRIORITIES.md +44 -0
- package/docs/CLAUDE_UNIVERSAL_VISION.md +18 -0
- package/docs/COMPLETE_AI_VALIDATION_SYNTHESIS.md +229 -0
- package/docs/COMPLETE_MEMORY_ANALYSIS_SUMMARY.md +323 -0
- package/docs/COMPLETE_STRATEGIC_LAUNCH_PLAN.md +241 -0
- package/docs/COPILOT_LANGCHAIN_MEMORY_COMPARISON_AND_PLAN.md +43 -0
- package/docs/CRITICAL_FIXES_ACTION_PLAN.md +251 -0
- package/docs/CRITICAL_MEMORY_USAGE_PROMPTS.md +290 -0
- package/docs/CURSOR_AI_MEMORY_ANALYSIS.md +479 -0
- package/docs/CURSOR_AI_MEMORY_WORKFLOW_ANALYSIS.md +267 -0
- package/docs/CURSOR_AI_TEST_RESULTS.md +298 -0
- package/docs/DEEPSEEK_AI_CLARIFICATION.md +52 -0
- package/docs/DEEPSEEK_AI_IMPLEMENTATION_GUIDE.md +398 -0
- package/docs/DEEPSEEK_AI_STRATEGIC_VALIDATION.md +348 -0
- package/docs/DEEPSEEK_AI_VALIDATION_RESPONSE.md +276 -0
- package/docs/DEEPSEEK_AI_VALIDATION_RESPONSE_v2.md +325 -0
- package/docs/DEEPSEEK_FINAL_VALIDATION.md +337 -0
- package/docs/DEEPSEEK_LAUNCH_VALIDATION.md +55 -0
- package/docs/DEEPSEEK_SCOPE_REALITY_CHECK.md +30 -0
- package/docs/DEEPSEEK_SUPERMEMORY_ADOPTION_AND_VSCODE_PIVOT.md +47 -0
- package/docs/DEEPSEEK_VALIDATION_RESULTS.md +165 -0
- package/docs/DEVELOPMENT_TESTING_PROTOCOL.md +378 -0
- package/docs/E2E_TEST_RESULTS.md +102 -0
- package/docs/END_TO_END_MEMORY_ISSUE_ANALYSIS.md +442 -0
- package/docs/FEATURE_1_GIT_SYNC_PLAN.md +228 -0
- package/docs/FEATURE_2_AUTO_LOGGING_PLAN.md +239 -0
- package/docs/FEATURE_3_CODE_SNIPPET_PLAN.md +249 -0
- package/docs/FEATURE_4_TAG_NORMALIZATION_PLAN.md +211 -0
- package/docs/FEATURE_5_WINDOWS_PATH_HANDLING_PLAN.md +199 -0
- package/docs/FEATURE_6_CONFLICT_DETECTION_PLAN.md +126 -0
- package/docs/FEATURE_IMPLEMENTATION_REPORT.md +203 -0
- package/docs/FINAL_COMPLETE_LAUNCH_DECISION.md +255 -0
- package/docs/FINAL_LAUNCH_DECISION.md +235 -0
- package/docs/FINAL_LAUNCH_DECISION_ALL_AIS.md +226 -0
- package/docs/FINAL_SCENARIO_VERIFICATION.md +363 -0
- package/docs/FIX_100_PERCENT_ANALYSIS.md +133 -0
- package/docs/FRAMEWORK_STRUCTURE.md +94 -0
- package/docs/GEMINI_AI_ANALYSIS.md +156 -0
- package/docs/GEMINI_AI_CLARIFICATION.md +47 -0
- package/docs/GEMINI_AI_STRATEGIC_VALIDATION.md +235 -0
- package/docs/GEMINI_AI_VALIDATION_RESPONSE.md +238 -0
- package/docs/GEMINI_AI_VALIDATION_RESPONSE_v2.md +168 -0
- package/docs/GEMINI_FINAL_VALIDATION.md +204 -0
- package/docs/GEMINI_LAUNCH_VALIDATION.md +30 -0
- package/docs/GEMINI_SCOPE_AND_UNIVERSALITY_DEBATE.md +25 -0
- package/docs/GEMINI_SUPERMEMORY_TREE_SITTER_MANDATE.md +43 -0
- package/docs/GEMINI_VALIDATION_RESULTS.md +183 -0
- package/docs/GROK_AI_ANALYSIS.md +278 -0
- package/docs/GROK_AI_CLARIFICATION.md +52 -0
- package/docs/GROK_AI_STRATEGIC_VALIDATION.md +306 -0
- package/docs/GROK_AI_VALIDATION_RESPONSE.md +252 -0
- package/docs/GROK_AI_VALIDATION_RESPONSE_v2.md +264 -0
- package/docs/GROK_FINAL_VALIDATION.md +251 -0
- package/docs/GROK_LAUNCH_VALIDATION.md +24 -0
- package/docs/GROK_SCOPE_REALITY_CHECK.md +28 -0
- package/docs/GROK_SUPERMEMORY_LAUNCH_ANALYSIS.md +44 -0
- package/docs/GROK_VALIDATION_RESULTS.md +180 -0
- package/docs/IMPLEMENTATION_PLAN_16_CRITICAL_FIXES.md +641 -0
- package/docs/LANGCHAIN_AND_LANGGRAPH_INTEGRATION_PLAN.md +51 -0
- package/docs/LAUNCH_DECISION_FINAL.md +243 -0
- package/docs/MANUS_AI_ANALYSIS.md +171 -0
- package/docs/MANUS_AI_CLARIFICATION.md +43 -0
- package/docs/MANUS_AI_VALIDATION_RESPONSE.md +335 -0
- package/docs/MANUS_AI_VALIDATION_RESPONSE_v2.md +226 -0
- package/docs/MANUS_FINAL_VALIDATION.md +257 -0
- package/docs/MANUS_VALIDATION_RESULTS.md +237 -0
- package/docs/MCP_SERVER_SETUP.md +167 -0
- package/docs/MEMORYLINK_7AI_FINAL_CONFIRMATION.md +210 -0
- package/docs/MEMORYLINK_CURSOR_AI_DEVELOPMENT_GUIDE.md +1092 -0
- package/docs/MEMORYLINK_DEVELOPMENT_PLAN_CURSOR_AI.md +629 -0
- package/docs/MEMORYLINK_FINAL_7AI_CLARIFICATION.md +184 -0
- package/docs/MEMORYLINK_MASTER_DOCUMENT_v4.md +1338 -0
- package/docs/MEMORYLINK_NAMING_ANALYSIS.md +427 -0
- package/docs/MEMORYLINK_REAL_WORLD_SCENARIOS.md +3517 -0
- package/docs/MEMORYLINK_STORAGE_COMPARISON.md +498 -0
- package/docs/MEMORYLINK_V1.0_FINAL_IMPLEMENTATION_PLAN.md +285 -0
- package/docs/MEMORYLINK_VALIDATION_COMPLETE_ANALYSIS.md +207 -0
- package/docs/MEMORYLINK_VS_MEMORY_APPS_ANALYSIS.md +667 -0
- package/docs/MEMORYLINK_v1.0_BUILD_DOCUMENT_FINAL.md +1928 -0
- package/docs/MEMORY_USAGE_FIX_IMPLEMENTATION.md +314 -0
- package/docs/MISTRAL_AI_ANALYSIS.md +189 -0
- package/docs/MISTRAL_AI_CLARIFICATION.md +57 -0
- package/docs/MISTRAL_AI_STRATEGIC_VALIDATION.md +334 -0
- package/docs/MISTRAL_AI_TESTING_REQUEST.md +261 -0
- package/docs/MISTRAL_AI_VALIDATION_RESPONSE.md +446 -0
- package/docs/MISTRAL_AI_VALIDATION_RESPONSE_v2.md +227 -0
- package/docs/MISTRAL_FINAL_VALIDATION.md +398 -0
- package/docs/MISTRAL_LAUNCH_VALIDATION.md +32 -0
- package/docs/MISTRAL_SCOPE_REALITY_CHECK.md +32 -0
- package/docs/MISTRAL_SUPERMEMORY_LAUNCH_ANALYSIS.md +43 -0
- package/docs/MISTRAL_VALIDATION_RESULTS.md +371 -0
- package/docs/NEXT_PLAN.md +300 -0
- package/docs/PERPLEXITY_AI_ANALYSIS.md +285 -0
- package/docs/PERPLEXITY_AI_CLARIFICATION.md +57 -0
- package/docs/PERPLEXITY_AI_STRATEGIC_VALIDATION.md +288 -0
- package/docs/PERPLEXITY_AI_VALIDATION_RESPONSE.md +350 -0
- package/docs/PERPLEXITY_AI_VALIDATION_RESPONSE_v2.md +260 -0
- package/docs/PERPLEXITY_FINAL_VALIDATION.md +320 -0
- package/docs/PERPLEXITY_LAUNCH_VALIDATION.md +42 -0
- package/docs/PERPLEXITY_MEMORY_QUALITY_AND_VSCODE_PLAN.md +56 -0
- package/docs/PERPLEXITY_SCOPE_REALITY_CHECK.md +31 -0
- package/docs/PERPLEXITY_VALIDATION_RESULTS.md +154 -0
- package/docs/PRE_LAUNCH_GAP_ANALYSIS.md +663 -0
- package/docs/PROJECT_STRUCTURE_PLAN.md +104 -0
- package/docs/QWEN_AI_ANALYSIS.md +176 -0
- package/docs/QWEN_AI_CLARIFICATION.md +60 -0
- package/docs/QWEN_AI_STRATEGIC_VALIDATION.md +241 -0
- package/docs/QWEN_AI_VALIDATION_RESPONSE.md +197 -0
- package/docs/QWEN_AI_VALIDATION_RESPONSE_v2.md +186 -0
- package/docs/QWEN_FINAL_VALIDATION.md +284 -0
- package/docs/QWEN_LAUNCH_VALIDATION.md +26 -0
- package/docs/QWEN_SCENARIOS_TEST_RESULTS.md +244 -0
- package/docs/QWEN_SCOPE_REALITY_CHECK.md +26 -0
- package/docs/QWEN_SUPERMEMORY_LAUNCH_AND_ENFORCEMENT_PLAN.md +56 -0
- package/docs/QWEN_VALIDATION_RESULTS.md +185 -0
- package/docs/README.md +479 -0
- package/docs/REAL_PRODUCT_LAUNCH_DECISION.md +185 -0
- package/docs/RECIPES.md +424 -0
- package/docs/RELEASE_NOTES_v1.0.0.md +193 -0
- package/docs/SCENARIO_INVENTORY_AND_VERIFICATION.md +284 -0
- package/docs/SINGLE_RUN_1018_SCENARIOS_RESULTS.md +142 -0
- package/docs/TESTING.md +256 -0
- package/docs/TESTING_STRATEGY.md +194 -0
- package/docs/TROUBLESHOOTING.md +188 -0
- package/docs/ULTIMATE_LAUNCH_DECISION.md +246 -0
- package/docs/WHAT_WE_BUILT.md +504 -0
- package/docs/v1.0_LAUNCH_CHECKLIST.md +104 -0
- package/examples/README.md +199 -0
- package/examples/chatgpt-context.js +161 -0
- package/examples/ci-integration.js +288 -0
- package/examples/sync-from-cursor.js +196 -0
- package/extensions/vscode/README.md +25 -0
- package/extensions/vscode/out/buddy-check.js +208 -0
- package/extensions/vscode/out/buddy-check.js.map +1 -0
- package/extensions/vscode/out/extension.js +413 -0
- package/extensions/vscode/out/extension.js.map +1 -0
- package/extensions/vscode/out/sidebar.js +409 -0
- package/extensions/vscode/out/sidebar.js.map +1 -0
- package/extensions/vscode/package.json +92 -0
- package/extensions/vscode/src/buddy-check.ts +220 -0
- package/extensions/vscode/src/extension.ts +425 -0
- package/extensions/vscode/src/shims-vscode.d.ts +2 -0
- package/extensions/vscode/src/sidebar.ts +431 -0
- package/extensions/vscode/tsconfig.json +14 -0
- package/k6-load-test.js +86 -0
- package/package.json +68 -0
- package/run-professional-tests.sh +72 -0
- package/scripts/monitor-continuous-test.sh +17 -0
- package/scripts/reorganize-project.sh +164 -0
- package/scripts/run-tests-parallel.sh +111 -0
- package/scripts/run-tests.sh +30 -0
- package/scripts/setup-framework.sh +139 -0
- package/scripts/setup-testing.sh +96 -0
- package/scripts/stress-test/README.md +86 -0
- package/scripts/stress-test/create-all-scenarios.sh +17 -0
- package/scripts/stress-test/create-remaining-scenarios.sh +3 -0
- package/scripts/stress-test/dev-test.sh +21 -0
- package/scripts/stress-test/monitor-continuous.sh +149 -0
- package/scripts/stress-test/overnight-test.sh +30 -0
- package/scripts/stress-test/quick-test.sh +21 -0
- package/scripts/stress-test/run-all-tests.sh +157 -0
- package/scripts/stress-test/run-continuous.sh +300 -0
- package/scripts/stress-test/run-stress-test.sh +153 -0
- package/scripts/stress-test/set1/1_1_mass_refactoring.sh +117 -0
- package/scripts/stress-test/set1/1_1_mass_refactoring_simple.sh +117 -0
- package/scripts/stress-test/set1/1_2_function_rename.sh +95 -0
- package/scripts/stress-test/set1/1_3_feature_flags.sh +93 -0
- package/scripts/stress-test/set1/1_4_feature_removal.sh +57 -0
- package/scripts/stress-test/set1/1_5_schema_changes.sh +42 -0
- package/scripts/stress-test/set1/1_6_dependency_update.sh +47 -0
- package/scripts/stress-test/set1/1_7_config_modification.sh +53 -0
- package/scripts/stress-test/set2/2_1_payment_logging.sh +49 -0
- package/scripts/stress-test/set2/2_2_test_data_generation.sh +43 -0
- package/scripts/stress-test/set2/2_3_documentation_leak.sh +45 -0
- package/scripts/stress-test/set2/2_4_api_key_rotation.sh +45 -0
- package/scripts/stress-test/set2/2_5_hardcoded_secrets.sh +45 -0
- package/scripts/stress-test/set2/2_6_debug_output.sh +49 -0
- package/scripts/stress-test/set3/3_1_billing_modification.sh +47 -0
- package/scripts/stress-test/set3/3_2_migration_deletion.sh +43 -0
- package/scripts/stress-test/set3/3_3_auth_middleware.sh +52 -0
- package/scripts/stress-test/set3/3_4_permission_bypass.sh +48 -0
- package/scripts/stress-test/set3/3_5_config_modification.sh +43 -0
- package/scripts/stress-test/set3/3_6_core_library.sh +51 -0
- package/scripts/stress-test/set3/3_7_test_infrastructure.sh +49 -0
- package/scripts/stress-test/set4/4_1_concurrent_features.sh +49 -0
- package/scripts/stress-test/set4/4_2_lock_acquisition.sh +32 -0
- package/scripts/stress-test/set4/4_3_migration_hotfix.sh +43 -0
- package/scripts/stress-test/set4/4_4_overlapping_scopes.sh +50 -0
- package/scripts/stress-test/set4/4_5_lock_timeout.sh +34 -0
- package/scripts/stress-test/set4/4_6_concurrent_stats.sh +33 -0
- package/scripts/stress-test/set5/5_1_wrong_decision.sh +41 -0
- package/scripts/stress-test/set5/5_2_outdated_docs.sh +40 -0
- package/scripts/stress-test/set5/5_3_conflicting_memories.sh +34 -0
- package/scripts/stress-test/set5/5_4_deleted_file_references.sh +38 -0
- package/scripts/stress-test/set5/5_5_old_pattern.sh +41 -0
- package/scripts/stress-test/set5/5_6_wrong_architecture.sh +42 -0
- package/scripts/stress-test/set5/5_7_high_trust_stale.sh +46 -0
- package/scripts/stress-test/set5/5_8_observability_stale.sh +36 -0
- package/scripts/stress-test/setup-test-repo-simple.sh +144 -0
- package/scripts/stress-test/setup-test-repo.sh +154 -0
- package/scripts/stress-test/start-continuous.sh +48 -0
- package/scripts/stress-test/stop-continuous.sh +42 -0
- package/scripts/stress-test/template-scenario.sh +115 -0
- package/scripts/test-advanced-scenarios.sh +411 -0
- package/scripts/test-continuous-30min.sh +307 -0
- package/scripts/test-continuous-enhanced.sh +250 -0
- package/scripts/test-e2e-comprehensive.sh +114 -0
- package/scripts/test-e2e-random.sh +359 -0
- package/scripts/test-fresh-scenarios.sh +412 -0
- package/scripts/test-new-scenarios.sh +374 -0
- package/scripts/test-quick-random.sh +97 -0
- package/scripts/test-runtime.sh +129 -0
- package/scripts/test-telemetry-local.sh +193 -0
- package/scripts/test-ultimate-scenarios.sh +428 -0
- package/scripts/test-v1.5-complete.sh +225 -0
- package/scripts/test-v1.5-phase1.sh +222 -0
- package/src/cli.ts +1259 -0
- package/src/commands/archive.ts +252 -0
- package/src/commands/auto-context.ts +159 -0
- package/src/commands/auto-log.ts +531 -0
- package/src/commands/change.ts +298 -0
- package/src/commands/checkpoint.ts +390 -0
- package/src/commands/configure.ts +297 -0
- package/src/commands/consolidate.ts +263 -0
- package/src/commands/context.ts +618 -0
- package/src/commands/detect.ts +181 -0
- package/src/commands/doctor.ts +1468 -0
- package/src/commands/export.ts +77 -0
- package/src/commands/graph.ts +214 -0
- package/src/commands/hooks.ts +245 -0
- package/src/commands/impact.ts +163 -0
- package/src/commands/index-vector.ts +126 -0
- package/src/commands/index.ts +57 -0
- package/src/commands/init.ts +194 -0
- package/src/commands/inject.ts +440 -0
- package/src/commands/learn.ts +328 -0
- package/src/commands/lock.ts +345 -0
- package/src/commands/memory.ts +415 -0
- package/src/commands/migrate.ts +540 -0
- package/src/commands/patterns.ts +158 -0
- package/src/commands/protect.ts +199 -0
- package/src/commands/quickstart.ts +259 -0
- package/src/commands/resolve.ts +373 -0
- package/src/commands/roadmap.ts +25 -0
- package/src/commands/scopes.ts +113 -0
- package/src/commands/search.ts +365 -0
- package/src/commands/setup.ts +430 -0
- package/src/commands/snippet.ts +271 -0
- package/src/commands/stats.ts +591 -0
- package/src/commands/status.ts +127 -0
- package/src/commands/suggest-tags.ts +122 -0
- package/src/commands/sync-rules.ts +218 -0
- package/src/commands/sync.ts +363 -0
- package/src/commands/telemetry-test.ts +97 -0
- package/src/commands/template.ts +166 -0
- package/src/commands/validate.ts +191 -0
- package/src/commands/watch-preferences.ts +162 -0
- package/src/commands/watch.ts +239 -0
- package/src/config/thresholds.ts +14 -0
- package/src/index.ts +12 -0
- package/src/memorylink.ts +308 -0
- package/src/search/local-embeddings.ts +94 -0
- package/src/search/vector-search.ts +608 -0
- package/src/server/mcp-server.ts +355 -0
- package/src/telemetry.ts +391 -0
- package/src/test-runner/TestRunner.ts +421 -0
- package/src/test-runner/performance-test.ts +161 -0
- package/src/test-runner/run-tests.ts +152 -0
- package/src/types.ts +533 -0
- package/src/utils/batch-commits.ts +162 -0
- package/src/utils/code-structure.ts +686 -0
- package/src/utils/commit-patterns.ts +87 -0
- package/src/utils/observability.ts +149 -0
- package/src/utils/quality.ts +230 -0
- package/src/utils/semantic-search.ts +222 -0
- package/src/utils/streaming.ts +109 -0
- package/src/utils/tag-suggestions.ts +117 -0
- package/src/utils/team-patterns.ts +499 -0
- package/src/utils/templates.ts +181 -0
- package/src/utils/tree-sitter-parser.ts +246 -0
- package/src/utils/v1.6-patterns.ts +227 -0
- package/src/utils.ts +885 -0
- package/test-all-features.sh +102 -0
- package/test-all-implemented-features.sh +209 -0
- package/test-all-new-features.sh +171 -0
- package/test-auto-log.txt +1 -0
- package/test-batch-commits.sh +47 -0
- package/test-conflict-resolution.sh +47 -0
- package/test-e2e.sh +22 -0
- package/test-end-to-end.sh +151 -0
- package/test-enhanced-autocapture.sh +164 -0
- package/test-inject.sh +44 -0
- package/test-mcp-server.sh +67 -0
- package/test-pagination.sh +37 -0
- package/test-python-go-structure.sh +164 -0
- package/test-quality-validation.sh +167 -0
- package/test-results-quick-smoke.json +13 -0
- package/test-results-targeted-perf.json +23 -0
- package/test-results.json +2272 -0
- package/test-scenarios/payment-logging.ts +17 -0
- package/test-scenarios/test-config.ts +13 -0
- package/test-semantic-search.sh +161 -0
- package/test-tag-intelligence.sh +49 -0
- package/test-vector-search.sh +64 -0
- package/test-vscode-extension.sh +144 -0
- package/test-watcher-file.txt +2 -0
- package/test-watcher-file2.txt +1 -0
- package/test-watcher.sh +103 -0
- package/test_qwen_scenarios.sh +285 -0
- package/tests/scenarios/4000_HARD_SCENARIOS.sh +4137 -0
- package/tests/scenarios/ADD_V1.1_SCENARIOS.sh +93 -0
- package/tests/scenarios/AGGRESSIVE_RANDOM_E2E_TEST.sh +474 -0
- package/tests/scenarios/COMPLETE_PRODUCT_VALIDATION.sh +227 -0
- package/tests/scenarios/COMPREHENSIVE_E2E_TEST.sh +426 -0
- package/tests/scenarios/CONTINUOUS_RANDOM_STRESS_TEST.sh +240 -0
- package/tests/scenarios/EXECUTE_10000_SCENARIOS.sh +61 -0
- package/tests/scenarios/EXECUTE_1000_UNIQUE_SCENARIOS.sh +190 -0
- package/tests/scenarios/EXECUTE_5000_SCENARIOS_SPLIT.sh +192 -0
- package/tests/scenarios/EXECUTE_5000_TOTAL_SCENARIOS.sh +162 -0
- package/tests/scenarios/EXECUTE_5040_SCENARIOS_WITH_V1.1.sh +251 -0
- package/tests/scenarios/EXECUTE_8_BATCHES_500.sh +51 -0
- package/tests/scenarios/EXECUTE_QUICK_SMOKE.sh +9 -0
- package/tests/scenarios/EXECUTE_SINGLE_BATCH.sh +117 -0
- package/tests/scenarios/EXECUTE_TARGETED_PERF.sh +19 -0
- package/tests/scenarios/GENERATE_1000_SCENARIOS.sh +235 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS.sh +266 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS_FIXED.sh +267 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS_FIXED_V2.sh +267 -0
- package/tests/scenarios/NEW_RANDOM_E2E_TEST.sh +422 -0
- package/tests/scenarios/QUICK_SMOKE_200.sh +38 -0
- package/tests/scenarios/QUICK_SMOKE_MINI.sh +3 -0
- package/tests/scenarios/RANDOM_REAL_WORLD_SCENARIOS.sh +372 -0
- package/tests/scenarios/ROUND3_RANDOM_E2E_TEST.sh +446 -0
- package/tests/scenarios/RUN_AGGRESSIVE_AND_SUMMARY.sh +51 -0
- package/tests/scenarios/RUN_ALL_1018_SCENARIOS.sh +161 -0
- package/tests/scenarios/TARGETED_PERF.sh +75 -0
- package/tests/scenarios/V1.1_FEATURES_SCENARIOS.sh +145 -0
- package/tests/unit/utils.test.ts +52 -0
- package/tests/v1.1-features-scenarios.sh +276 -0
- package/tsconfig.json +21 -0
- package/v1.6_FEATURE_REQUESTS.md +79 -0
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryLink - Commit Pattern Detection
|
|
3
|
+
* Detect commit message patterns and suggest logging
|
|
4
|
+
*
|
|
5
|
+
* v1.3: Week 6 - Enhanced Auto-Capture
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Commit message patterns that suggest learning/decision logging
|
|
10
|
+
*/
|
|
11
|
+
export interface CommitPattern {
|
|
12
|
+
pattern: RegExp;
|
|
13
|
+
type: 'learning' | 'memory';
|
|
14
|
+
suggestion: string;
|
|
15
|
+
tags?: string[];
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const COMMIT_PATTERNS: CommitPattern[] = [
|
|
19
|
+
{
|
|
20
|
+
pattern: /^(fix|bugfix|fixes?|fixed|resolve|resolves?|resolved)/i,
|
|
21
|
+
type: 'learning',
|
|
22
|
+
suggestion: 'This looks like a bug fix. Consider logging as a learning: memorylink learn "Problem" "Solution" --status SUCCESS',
|
|
23
|
+
tags: ['bugfix', 'fix'],
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
pattern: /^(feat|feature|add|added|implement|implements?|implemented)/i,
|
|
27
|
+
type: 'memory',
|
|
28
|
+
suggestion: 'This looks like a new feature. Consider logging as a decision: memorylink memory "Feature description" --type decision',
|
|
29
|
+
tags: ['feature', 'decision'],
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
pattern: /^(refactor|refactoring|refactored|cleanup|clean)/i,
|
|
33
|
+
type: 'learning',
|
|
34
|
+
suggestion: 'This looks like a refactoring. Consider logging as a learning: memorylink learn "What needed refactoring" "How you refactored it" --status SUCCESS',
|
|
35
|
+
tags: ['refactor', 'code-quality'],
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
pattern: /^(test|tests?|testing|spec|specs?)/i,
|
|
39
|
+
type: 'memory',
|
|
40
|
+
suggestion: 'This looks like test-related changes. Consider logging: memorylink memory "Test description" --tags test',
|
|
41
|
+
tags: ['test', 'testing'],
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
pattern: /^(docs?|documentation|readme)/i,
|
|
45
|
+
type: 'memory',
|
|
46
|
+
suggestion: 'This looks like documentation changes. Consider logging: memorylink memory "Documentation update" --type doc_ref',
|
|
47
|
+
tags: ['docs', 'documentation'],
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
pattern: /^(perf|performance|optimize|optimization|optimized)/i,
|
|
51
|
+
type: 'learning',
|
|
52
|
+
suggestion: 'This looks like a performance improvement. Consider logging as a learning: memorylink learn "Performance issue" "Optimization solution" --status SUCCESS',
|
|
53
|
+
tags: ['performance', 'optimization'],
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
pattern: /^(chore|maintenance|update|updated|upgrade|upgraded)/i,
|
|
57
|
+
type: 'memory',
|
|
58
|
+
suggestion: 'This looks like maintenance. Consider logging: memorylink memory "Maintenance description" --tags maintenance',
|
|
59
|
+
tags: ['maintenance', 'chore'],
|
|
60
|
+
},
|
|
61
|
+
];
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Detect commit message pattern and suggest logging
|
|
65
|
+
*/
|
|
66
|
+
export function detectCommitPattern(commitMessage: string): CommitPattern | null {
|
|
67
|
+
for (const pattern of COMMIT_PATTERNS) {
|
|
68
|
+
if (pattern.pattern.test(commitMessage)) {
|
|
69
|
+
return pattern;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Format suggestion for display
|
|
77
|
+
*/
|
|
78
|
+
export function formatSuggestion(pattern: CommitPattern, commitHash: string, commitMessage: string): string {
|
|
79
|
+
let output = `💡 Commit pattern detected: ${pattern.type}\n`;
|
|
80
|
+
output += ` Commit: ${commitHash.substring(0, 8)} - ${commitMessage.substring(0, 60)}...\n`;
|
|
81
|
+
output += ` ${pattern.suggestion}\n`;
|
|
82
|
+
if (pattern.tags && pattern.tags.length > 0) {
|
|
83
|
+
output += ` Suggested tags: ${pattern.tags.join(', ')}\n`;
|
|
84
|
+
}
|
|
85
|
+
return output;
|
|
86
|
+
}
|
|
87
|
+
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryLink - Observability Logging
|
|
3
|
+
* v1.4: Log Buddy-Check runs for analytics and debugging
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import * as fs from 'fs';
|
|
7
|
+
import * as path from 'path';
|
|
8
|
+
import { findRoot, getFilePath } from '../utils.js';
|
|
9
|
+
import { MEMORYLINK_DIR } from '../types.js';
|
|
10
|
+
import type { BuddyReport, BuddyStatus } from '../types.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Observability log entry
|
|
14
|
+
*/
|
|
15
|
+
export interface ObservabilityEntry {
|
|
16
|
+
timestamp: string; // ISO 8601 UTC
|
|
17
|
+
runType: 'preflight' | 'postflight';
|
|
18
|
+
status: BuddyStatus;
|
|
19
|
+
agentId?: string;
|
|
20
|
+
branch?: string;
|
|
21
|
+
prNumber?: string;
|
|
22
|
+
recordsUsed?: number;
|
|
23
|
+
highTrust?: number;
|
|
24
|
+
mediumTrust?: number;
|
|
25
|
+
lowTrust?: number;
|
|
26
|
+
staleCount?: number;
|
|
27
|
+
issues?: string[]; // Unique issue types found
|
|
28
|
+
durationMs?: number;
|
|
29
|
+
override?: boolean; // Was this run overridden?
|
|
30
|
+
overrideBy?: string; // Who overrode it?
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Get observability log file path
|
|
35
|
+
*/
|
|
36
|
+
function getObservabilityLogPath(root?: string): string {
|
|
37
|
+
const projectRoot = root || findRoot() || process.cwd();
|
|
38
|
+
return path.join(projectRoot, MEMORYLINK_DIR, 'observability.log');
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Log a Buddy-Check run to observability log
|
|
43
|
+
*/
|
|
44
|
+
export function logBuddyCheckRun(report: BuddyReport, root?: string): void {
|
|
45
|
+
try {
|
|
46
|
+
const logPath = getObservabilityLogPath(root);
|
|
47
|
+
const projectRoot = root || findRoot() || process.cwd();
|
|
48
|
+
|
|
49
|
+
// Extract unique issue types
|
|
50
|
+
const issueTypes = [...new Set(report.issues.map(i => i.type))];
|
|
51
|
+
|
|
52
|
+
// Create log entry
|
|
53
|
+
const entry: ObservabilityEntry = {
|
|
54
|
+
timestamp: report.timestamp || new Date().toISOString(),
|
|
55
|
+
runType: report.runType || 'preflight',
|
|
56
|
+
status: report.status,
|
|
57
|
+
agentId: report.agentId,
|
|
58
|
+
branch: report.branch,
|
|
59
|
+
recordsUsed: report.recordsUsed,
|
|
60
|
+
highTrust: report.highTrust,
|
|
61
|
+
mediumTrust: report.mediumTrust,
|
|
62
|
+
lowTrust: report.lowTrust,
|
|
63
|
+
staleCount: report.staleCount,
|
|
64
|
+
issues: issueTypes.length > 0 ? issueTypes : undefined,
|
|
65
|
+
durationMs: report.durationMs,
|
|
66
|
+
override: report.override !== undefined,
|
|
67
|
+
overrideBy: report.override?.approvedBy,
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
// Append to JSONL file
|
|
71
|
+
const jsonlLine = JSON.stringify(entry) + '\n';
|
|
72
|
+
fs.appendFileSync(logPath, jsonlLine, 'utf-8');
|
|
73
|
+
} catch (err) {
|
|
74
|
+
// Silently fail - observability logging should not break the main flow
|
|
75
|
+
// Could add a debug flag to log errors if needed
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Read observability log entries
|
|
81
|
+
*/
|
|
82
|
+
export function readObservabilityLog(limit?: number, root?: string): ObservabilityEntry[] {
|
|
83
|
+
const logPath = getObservabilityLogPath(root);
|
|
84
|
+
|
|
85
|
+
if (!fs.existsSync(logPath)) {
|
|
86
|
+
return [];
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const content = fs.readFileSync(logPath, 'utf-8');
|
|
90
|
+
const lines = content.split('\n').filter(line => line.trim() !== '');
|
|
91
|
+
const entries: ObservabilityEntry[] = [];
|
|
92
|
+
|
|
93
|
+
for (const line of lines) {
|
|
94
|
+
try {
|
|
95
|
+
const entry = JSON.parse(line) as ObservabilityEntry;
|
|
96
|
+
entries.push(entry);
|
|
97
|
+
} catch {
|
|
98
|
+
// Skip invalid JSON lines
|
|
99
|
+
continue;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// Sort by timestamp (newest first)
|
|
104
|
+
entries.sort((a, b) =>
|
|
105
|
+
new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime()
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
return limit ? entries.slice(0, limit) : entries;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Get observability statistics
|
|
113
|
+
*/
|
|
114
|
+
export function getObservabilityStats(root?: string): {
|
|
115
|
+
totalRuns: number;
|
|
116
|
+
preflightRuns: number;
|
|
117
|
+
postflightRuns: number;
|
|
118
|
+
greenCount: number;
|
|
119
|
+
yellowCount: number;
|
|
120
|
+
redCount: number;
|
|
121
|
+
overrideCount: number;
|
|
122
|
+
avgDuration: number;
|
|
123
|
+
} {
|
|
124
|
+
const entries = readObservabilityLog(undefined, root);
|
|
125
|
+
|
|
126
|
+
const stats = {
|
|
127
|
+
totalRuns: entries.length,
|
|
128
|
+
preflightRuns: entries.filter(e => e.runType === 'preflight').length,
|
|
129
|
+
postflightRuns: entries.filter(e => e.runType === 'postflight').length,
|
|
130
|
+
greenCount: entries.filter(e => e.status === 'GREEN').length,
|
|
131
|
+
yellowCount: entries.filter(e => e.status === 'YELLOW').length,
|
|
132
|
+
redCount: entries.filter(e => e.status === 'RED').length,
|
|
133
|
+
overrideCount: entries.filter(e => e.override === true).length,
|
|
134
|
+
avgDuration: 0,
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
const durations = entries
|
|
138
|
+
.filter(e => e.durationMs !== undefined)
|
|
139
|
+
.map(e => e.durationMs!);
|
|
140
|
+
|
|
141
|
+
if (durations.length > 0) {
|
|
142
|
+
stats.avgDuration = Math.round(
|
|
143
|
+
durations.reduce((a, b) => a + b, 0) / durations.length
|
|
144
|
+
);
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
return stats;
|
|
148
|
+
}
|
|
149
|
+
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryLink - Quality Validation
|
|
3
|
+
* Prevent log rot with quality checks
|
|
4
|
+
*
|
|
5
|
+
* v1.3: Week 5 - Memory Quality Validation
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import type { MemoryEntry, LearningEntry, BaseEntry } from '../types.js';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Quality score result
|
|
12
|
+
*/
|
|
13
|
+
export interface QualityScore {
|
|
14
|
+
score: number; // 0-100
|
|
15
|
+
issues: string[]; // List of issues found
|
|
16
|
+
suggestions: string[]; // Suggestions for improvement
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Vague words that indicate low quality
|
|
21
|
+
*/
|
|
22
|
+
const VAGUE_WORDS = [
|
|
23
|
+
'thing', 'stuff', 'something', 'anything', 'everything',
|
|
24
|
+
'fixed', 'done', 'updated', 'changed', 'modified',
|
|
25
|
+
'issue', 'problem', 'bug', 'error', 'broken',
|
|
26
|
+
'work', 'works', 'working', 'not working',
|
|
27
|
+
];
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Score a memory entry
|
|
31
|
+
*/
|
|
32
|
+
export function scoreMemoryEntry(entry: MemoryEntry): QualityScore {
|
|
33
|
+
const issues: string[] = [];
|
|
34
|
+
const suggestions: string[] = [];
|
|
35
|
+
let score = 100;
|
|
36
|
+
|
|
37
|
+
// Check length
|
|
38
|
+
const details = entry.details || '';
|
|
39
|
+
if (details.length < 10) {
|
|
40
|
+
score -= 30;
|
|
41
|
+
issues.push('Too short (less than 10 characters)');
|
|
42
|
+
suggestions.push('Add more details about the memory');
|
|
43
|
+
} else if (details.length < 30) {
|
|
44
|
+
score -= 15;
|
|
45
|
+
issues.push('Short (less than 30 characters)');
|
|
46
|
+
suggestions.push('Consider adding more context');
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// Check for vague words
|
|
50
|
+
const detailsLower = details.toLowerCase();
|
|
51
|
+
const vagueCount = VAGUE_WORDS.filter(word => detailsLower.includes(word)).length;
|
|
52
|
+
if (vagueCount > 2) {
|
|
53
|
+
score -= 20;
|
|
54
|
+
issues.push(`Contains ${vagueCount} vague words`);
|
|
55
|
+
suggestions.push('Be more specific (avoid words like "thing", "stuff", "fixed")');
|
|
56
|
+
} else if (vagueCount > 0) {
|
|
57
|
+
score -= 10;
|
|
58
|
+
issues.push(`Contains ${vagueCount} vague word(s)`);
|
|
59
|
+
suggestions.push('Consider being more specific');
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Check for tags
|
|
63
|
+
if (!entry.tags || entry.tags.length === 0) {
|
|
64
|
+
score -= 15;
|
|
65
|
+
issues.push('No tags');
|
|
66
|
+
suggestions.push('Add tags to improve searchability');
|
|
67
|
+
} else if (entry.tags.length === 1) {
|
|
68
|
+
score -= 5;
|
|
69
|
+
issues.push('Only one tag');
|
|
70
|
+
suggestions.push('Consider adding more tags');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Check for file context
|
|
74
|
+
if (!entry.path && entry.type !== 'rule' && entry.type !== 'preference') {
|
|
75
|
+
score -= 10;
|
|
76
|
+
issues.push('No file context');
|
|
77
|
+
suggestions.push('Link to a file if this memory is file-specific');
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
// Bonus for good status
|
|
81
|
+
if (entry.status === 'ACTIVE') {
|
|
82
|
+
score += 5;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Bonus for recent entries (within 7 days)
|
|
86
|
+
const entryDate = new Date(entry.ts);
|
|
87
|
+
const daysSince = (Date.now() - entryDate.getTime()) / (1000 * 60 * 60 * 24);
|
|
88
|
+
if (daysSince < 7) {
|
|
89
|
+
score += 5;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
// Bonus for code snippets with context
|
|
93
|
+
if (entry.type === 'code_snippet' && entry.code && entry.context) {
|
|
94
|
+
score += 10;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Ensure score is within bounds
|
|
98
|
+
score = Math.max(0, Math.min(100, score));
|
|
99
|
+
|
|
100
|
+
return {
|
|
101
|
+
score: Math.round(score),
|
|
102
|
+
issues,
|
|
103
|
+
suggestions,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Score a learning entry
|
|
109
|
+
*/
|
|
110
|
+
export function scoreLearningEntry(entry: LearningEntry): QualityScore {
|
|
111
|
+
const issues: string[] = [];
|
|
112
|
+
const suggestions: string[] = [];
|
|
113
|
+
let score = 100;
|
|
114
|
+
|
|
115
|
+
// Check problem clarity
|
|
116
|
+
const problem = entry.problem || '';
|
|
117
|
+
if (problem.length < 10) {
|
|
118
|
+
score -= 25;
|
|
119
|
+
issues.push('Problem description too short');
|
|
120
|
+
suggestions.push('Describe the problem in detail');
|
|
121
|
+
} else if (problem.length < 30) {
|
|
122
|
+
score -= 15;
|
|
123
|
+
issues.push('Problem description short');
|
|
124
|
+
suggestions.push('Add more details about the problem');
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Check solution clarity
|
|
128
|
+
const solution = entry.solution || '';
|
|
129
|
+
if (solution.length < 10) {
|
|
130
|
+
score -= 25;
|
|
131
|
+
issues.push('Solution description too short');
|
|
132
|
+
suggestions.push('Describe the solution in detail');
|
|
133
|
+
} else if (solution.length < 30) {
|
|
134
|
+
score -= 15;
|
|
135
|
+
issues.push('Solution description short');
|
|
136
|
+
suggestions.push('Add more details about the solution');
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// Check for vague words in problem
|
|
140
|
+
const problemLower = problem.toLowerCase();
|
|
141
|
+
const vagueCount = VAGUE_WORDS.filter(word => problemLower.includes(word)).length;
|
|
142
|
+
if (vagueCount > 1) {
|
|
143
|
+
score -= 15;
|
|
144
|
+
issues.push(`Problem contains ${vagueCount} vague words`);
|
|
145
|
+
suggestions.push('Be more specific about the problem');
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// Check for vague words in solution
|
|
149
|
+
const solutionLower = solution.toLowerCase();
|
|
150
|
+
const vagueCountSolution = VAGUE_WORDS.filter(word => solutionLower.includes(word)).length;
|
|
151
|
+
if (vagueCountSolution > 1) {
|
|
152
|
+
score -= 15;
|
|
153
|
+
issues.push(`Solution contains ${vagueCountSolution} vague words`);
|
|
154
|
+
suggestions.push('Be more specific about the solution');
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
// Check outcome
|
|
158
|
+
if (!entry.outcome || (entry.outcome !== 'SUCCESS' && entry.outcome !== 'FAILED')) {
|
|
159
|
+
score -= 20;
|
|
160
|
+
issues.push('No outcome specified');
|
|
161
|
+
suggestions.push('Specify outcome: SUCCESS or FAILED');
|
|
162
|
+
} else if (entry.outcome === 'SUCCESS') {
|
|
163
|
+
score += 10; // Bonus for successful learnings
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
// Check for tags
|
|
167
|
+
if (!entry.tags || entry.tags.length === 0) {
|
|
168
|
+
score -= 10;
|
|
169
|
+
issues.push('No tags');
|
|
170
|
+
suggestions.push('Add tags to improve searchability');
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// Bonus for recent entries
|
|
174
|
+
const entryDate = new Date(entry.ts);
|
|
175
|
+
const daysSince = (Date.now() - entryDate.getTime()) / (1000 * 60 * 60 * 24);
|
|
176
|
+
if (daysSince < 7) {
|
|
177
|
+
score += 5;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
// Ensure score is within bounds
|
|
181
|
+
score = Math.max(0, Math.min(100, score));
|
|
182
|
+
|
|
183
|
+
return {
|
|
184
|
+
score: Math.round(score),
|
|
185
|
+
issues,
|
|
186
|
+
suggestions,
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* Get quality level from score
|
|
192
|
+
*/
|
|
193
|
+
export function getQualityLevel(score: number): 'excellent' | 'good' | 'acceptable' | 'poor' {
|
|
194
|
+
if (score >= 80) return 'excellent';
|
|
195
|
+
if (score >= 60) return 'good';
|
|
196
|
+
if (score >= 40) return 'acceptable';
|
|
197
|
+
return 'poor';
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/**
|
|
201
|
+
* Format quality score for display
|
|
202
|
+
*/
|
|
203
|
+
export function formatQualityScore(score: QualityScore): string {
|
|
204
|
+
const level = getQualityLevel(score.score);
|
|
205
|
+
const levelEmoji = {
|
|
206
|
+
excellent: '🌟',
|
|
207
|
+
good: '✅',
|
|
208
|
+
acceptable: '⚠️',
|
|
209
|
+
poor: '❌',
|
|
210
|
+
}[level];
|
|
211
|
+
|
|
212
|
+
let output = `${levelEmoji} Quality Score: ${score.score}/100 (${level})\n`;
|
|
213
|
+
|
|
214
|
+
if (score.issues.length > 0) {
|
|
215
|
+
output += '\nIssues:\n';
|
|
216
|
+
score.issues.forEach(issue => {
|
|
217
|
+
output += ` • ${issue}\n`;
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
if (score.suggestions.length > 0) {
|
|
222
|
+
output += '\nSuggestions:\n';
|
|
223
|
+
score.suggestions.forEach(suggestion => {
|
|
224
|
+
output += ` 💡 ${suggestion}\n`;
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
return output;
|
|
229
|
+
}
|
|
230
|
+
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryLink - Semantic Search Utilities
|
|
3
|
+
* Lightweight TF-IDF and word similarity for semantic search
|
|
4
|
+
*
|
|
5
|
+
* v1.0: TF-IDF + word similarity (no ML dependencies)
|
|
6
|
+
* v1.5: Can upgrade to embeddings (transformers.js, etc.)
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import type { BaseEntry, MemoryEntry, LearningEntry, ChangeEntry } from '../types.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Tokenize text into words (lowercase, remove punctuation)
|
|
13
|
+
*/
|
|
14
|
+
export function tokenize(text: string): string[] {
|
|
15
|
+
return text
|
|
16
|
+
.toLowerCase()
|
|
17
|
+
.replace(/[^\w\s]/g, ' ')
|
|
18
|
+
.split(/\s+/)
|
|
19
|
+
.filter(word => word.length > 2); // Filter out very short words
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Calculate Term Frequency (TF) for a term in a document
|
|
24
|
+
*/
|
|
25
|
+
function termFrequency(term: string, tokens: string[]): number {
|
|
26
|
+
const count = tokens.filter(t => t === term).length;
|
|
27
|
+
return count / tokens.length;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Calculate Inverse Document Frequency (IDF) for a term across all documents
|
|
32
|
+
*/
|
|
33
|
+
function inverseDocumentFrequency(
|
|
34
|
+
term: string,
|
|
35
|
+
allDocuments: string[][]
|
|
36
|
+
): number {
|
|
37
|
+
const documentsContainingTerm = allDocuments.filter(doc =>
|
|
38
|
+
doc.includes(term)
|
|
39
|
+
).length;
|
|
40
|
+
|
|
41
|
+
if (documentsContainingTerm === 0) {
|
|
42
|
+
return 0;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return Math.log(allDocuments.length / documentsContainingTerm);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Calculate TF-IDF score for a term in a document
|
|
50
|
+
*/
|
|
51
|
+
function tfidf(
|
|
52
|
+
term: string,
|
|
53
|
+
documentTokens: string[],
|
|
54
|
+
allDocuments: string[][]
|
|
55
|
+
): number {
|
|
56
|
+
const tf = termFrequency(term, documentTokens);
|
|
57
|
+
const idf = inverseDocumentFrequency(term, allDocuments);
|
|
58
|
+
return tf * idf;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Calculate Jaccard similarity between two sets
|
|
63
|
+
*/
|
|
64
|
+
function jaccardSimilarity(set1: Set<string>, set2: Set<string>): number {
|
|
65
|
+
const intersection = new Set([...set1].filter(x => set2.has(x)));
|
|
66
|
+
const union = new Set([...set1, ...set2]);
|
|
67
|
+
return union.size === 0 ? 0 : intersection.size / union.size;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Calculate cosine similarity between two vectors (word counts)
|
|
72
|
+
*/
|
|
73
|
+
function cosineSimilarity(
|
|
74
|
+
vec1: Map<string, number>,
|
|
75
|
+
vec2: Map<string, number>
|
|
76
|
+
): number {
|
|
77
|
+
const allTerms = new Set([...vec1.keys(), ...vec2.keys()]);
|
|
78
|
+
|
|
79
|
+
let dotProduct = 0;
|
|
80
|
+
let norm1 = 0;
|
|
81
|
+
let norm2 = 0;
|
|
82
|
+
|
|
83
|
+
for (const term of allTerms) {
|
|
84
|
+
const v1 = vec1.get(term) || 0;
|
|
85
|
+
const v2 = vec2.get(term) || 0;
|
|
86
|
+
dotProduct += v1 * v2;
|
|
87
|
+
norm1 += v1 * v1;
|
|
88
|
+
norm2 += v2 * v2;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (norm1 === 0 || norm2 === 0) {
|
|
92
|
+
return 0;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
return dotProduct / (Math.sqrt(norm1) * Math.sqrt(norm2));
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* Extract searchable text from an entry
|
|
100
|
+
*/
|
|
101
|
+
function extractSearchableText(entry: BaseEntry): string {
|
|
102
|
+
let text = '';
|
|
103
|
+
|
|
104
|
+
// Memory entry
|
|
105
|
+
if ('details' in entry) {
|
|
106
|
+
const memEntry = entry as MemoryEntry;
|
|
107
|
+
text += memEntry.details || '';
|
|
108
|
+
if (memEntry.code) {
|
|
109
|
+
text += ' ' + memEntry.code;
|
|
110
|
+
}
|
|
111
|
+
if (memEntry.context) {
|
|
112
|
+
text += ' ' + memEntry.context;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// Learning entry
|
|
117
|
+
if ('problem' in entry) {
|
|
118
|
+
const learnEntry = entry as LearningEntry;
|
|
119
|
+
text += (learnEntry.problem || '') + ' ' + (learnEntry.solution || '');
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// Change entry
|
|
123
|
+
if ('file' in entry) {
|
|
124
|
+
const changeEntry = entry as ChangeEntry;
|
|
125
|
+
text += (changeEntry.file || '') + ' ' + (changeEntry.reason || '');
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
// Tags
|
|
129
|
+
if (entry.tags && entry.tags.length > 0) {
|
|
130
|
+
text += ' ' + entry.tags.join(' ');
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
return text;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Calculate semantic similarity score between query and entry
|
|
138
|
+
* Returns a score between 0 and 1
|
|
139
|
+
*/
|
|
140
|
+
export function calculateSemanticScore(
|
|
141
|
+
query: string,
|
|
142
|
+
entry: BaseEntry,
|
|
143
|
+
allEntries: BaseEntry[]
|
|
144
|
+
): number {
|
|
145
|
+
const queryTokens = tokenize(query);
|
|
146
|
+
const entryText = extractSearchableText(entry);
|
|
147
|
+
const entryTokens = tokenize(entryText);
|
|
148
|
+
|
|
149
|
+
if (entryTokens.length === 0) {
|
|
150
|
+
return 0;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
// 1. TF-IDF score (relevance)
|
|
154
|
+
const allDocuments = allEntries.map(e => tokenize(extractSearchableText(e)));
|
|
155
|
+
let tfidfScore = 0;
|
|
156
|
+
for (const term of queryTokens) {
|
|
157
|
+
tfidfScore += tfidf(term, entryTokens, allDocuments);
|
|
158
|
+
}
|
|
159
|
+
// Normalize TF-IDF score (0-1 range)
|
|
160
|
+
const normalizedTfidf = Math.min(1, tfidfScore / queryTokens.length);
|
|
161
|
+
|
|
162
|
+
// 2. Jaccard similarity (word overlap)
|
|
163
|
+
const querySet = new Set(queryTokens);
|
|
164
|
+
const entrySet = new Set(entryTokens);
|
|
165
|
+
const jaccardScore = jaccardSimilarity(querySet, entrySet);
|
|
166
|
+
|
|
167
|
+
// 3. Cosine similarity (word frequency)
|
|
168
|
+
const queryVec = new Map<string, number>();
|
|
169
|
+
queryTokens.forEach(t => queryVec.set(t, (queryVec.get(t) || 0) + 1));
|
|
170
|
+
|
|
171
|
+
const entryVec = new Map<string, number>();
|
|
172
|
+
entryTokens.forEach(t => entryVec.set(t, (entryVec.get(t) || 0) + 1));
|
|
173
|
+
|
|
174
|
+
const cosineScore = cosineSimilarity(queryVec, entryVec);
|
|
175
|
+
|
|
176
|
+
// 4. Exact keyword match bonus
|
|
177
|
+
const exactMatchBonus = queryTokens.some(term =>
|
|
178
|
+
entryTokens.includes(term)
|
|
179
|
+
) ? 0.2 : 0;
|
|
180
|
+
|
|
181
|
+
// Combine scores (weighted average)
|
|
182
|
+
const combinedScore =
|
|
183
|
+
normalizedTfidf * 0.4 +
|
|
184
|
+
jaccardScore * 0.3 +
|
|
185
|
+
cosineScore * 0.2 +
|
|
186
|
+
exactMatchBonus * 0.1;
|
|
187
|
+
|
|
188
|
+
return Math.min(1, combinedScore);
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* Rank entries by semantic similarity to query
|
|
193
|
+
*/
|
|
194
|
+
export function rankBySemanticSimilarity<T extends BaseEntry>(
|
|
195
|
+
query: string,
|
|
196
|
+
entries: T[],
|
|
197
|
+
threshold: number = 0.1
|
|
198
|
+
): Array<{ entry: T; score: number }> {
|
|
199
|
+
const scored = entries.map(entry => ({
|
|
200
|
+
entry,
|
|
201
|
+
score: calculateSemanticScore(query, entry, entries),
|
|
202
|
+
}));
|
|
203
|
+
|
|
204
|
+
// Filter by threshold and sort by score (descending)
|
|
205
|
+
return scored
|
|
206
|
+
.filter(item => item.score >= threshold)
|
|
207
|
+
.sort((a, b) => b.score - a.score);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* Find semantically similar entries
|
|
212
|
+
*/
|
|
213
|
+
export function findSemanticMatches<T extends BaseEntry>(
|
|
214
|
+
query: string,
|
|
215
|
+
entries: T[],
|
|
216
|
+
limit: number = 10,
|
|
217
|
+
threshold: number = 0.1
|
|
218
|
+
): T[] {
|
|
219
|
+
const ranked = rankBySemanticSimilarity(query, entries, threshold);
|
|
220
|
+
return ranked.slice(0, limit).map(item => item.entry);
|
|
221
|
+
}
|
|
222
|
+
|