moflo 4.8.27 → 4.8.30
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/.claude/agents/browser/browser-agent.yaml +182 -182
- package/.claude/agents/core/coder.md +265 -265
- package/.claude/agents/core/planner.md +167 -167
- package/.claude/agents/core/researcher.md +189 -189
- package/.claude/agents/core/reviewer.md +325 -325
- package/.claude/agents/core/tester.md +318 -318
- package/.claude/agents/database-specialist.yaml +21 -21
- package/.claude/agents/dual-mode/codex-coordinator.md +224 -224
- package/.claude/agents/dual-mode/codex-worker.md +211 -211
- package/.claude/agents/dual-mode/dual-orchestrator.md +291 -291
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +537 -537
- package/.claude/agents/github/github-modes.md +172 -172
- package/.claude/agents/github/issue-tracker.md +318 -318
- package/.claude/agents/github/multi-repo-swarm.md +552 -552
- package/.claude/agents/github/pr-manager.md +190 -190
- package/.claude/agents/github/project-board-sync.md +508 -508
- package/.claude/agents/github/release-manager.md +366 -366
- package/.claude/agents/github/release-swarm.md +582 -582
- package/.claude/agents/github/repo-architect.md +397 -397
- package/.claude/agents/github/swarm-issue.md +572 -572
- package/.claude/agents/github/swarm-pr.md +427 -427
- package/.claude/agents/github/sync-coordinator.md +451 -451
- package/.claude/agents/github/workflow-automation.md +634 -634
- package/.claude/agents/goal/code-goal-planner.md +445 -445
- package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -129
- package/.claude/agents/hive-mind/queen-coordinator.md +202 -202
- package/.claude/agents/hive-mind/scout-explorer.md +241 -241
- package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -192
- package/.claude/agents/hive-mind/worker-specialist.md +216 -216
- package/.claude/agents/index.yaml +17 -17
- package/.claude/agents/neural/safla-neural.md +73 -73
- package/.claude/agents/payments/agentic-payments.md +126 -0
- package/.claude/agents/project-coordinator.yaml +15 -15
- package/.claude/agents/python-specialist.yaml +21 -21
- package/.claude/agents/reasoning/goal-planner.md +72 -72
- package/.claude/agents/security-auditor.yaml +20 -20
- package/.claude/agents/sona/sona-learning-optimizer.md +74 -0
- package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
- package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
- package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
- package/.claude/agents/sublinear/performance-optimizer.md +368 -0
- package/.claude/agents/sublinear/trading-predictor.md +246 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +395 -395
- package/.claude/agents/swarm/hierarchical-coordinator.md +326 -326
- package/.claude/agents/swarm/mesh-coordinator.md +391 -391
- package/.claude/agents/templates/migration-plan.md +745 -745
- package/.claude/agents/typescript-specialist.yaml +21 -21
- package/.claude/agents/v3/adr-architect.md +184 -0
- package/.claude/agents/v3/aidefence-guardian.md +282 -0
- package/.claude/agents/v3/claims-authorizer.md +208 -0
- package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
- package/.claude/agents/v3/ddd-domain-expert.md +220 -0
- package/.claude/agents/v3/injection-analyst.md +236 -0
- package/.claude/agents/v3/memory-specialist.md +995 -0
- package/.claude/agents/v3/performance-engineer.md +1233 -0
- package/.claude/agents/v3/pii-detector.md +151 -0
- package/.claude/agents/v3/reasoningbank-learner.md +213 -0
- package/.claude/agents/v3/security-architect-aidefence.md +410 -0
- package/.claude/agents/v3/security-architect.md +867 -0
- package/.claude/agents/v3/security-auditor.md +771 -0
- package/.claude/agents/v3/sparc-orchestrator.md +182 -0
- package/.claude/agents/v3/swarm-memory-manager.md +157 -0
- package/.claude/agents/v3/v3-integration-architect.md +205 -0
- package/.claude/checkpoints/1767754460.json +8 -8
- package/.claude/commands/agents/agent-spawning.md +28 -28
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/github/github-modes.md +146 -146
- package/.claude/commands/github/github-swarm.md +121 -121
- package/.claude/commands/github/issue-tracker.md +291 -291
- package/.claude/commands/github/pr-manager.md +169 -169
- package/.claude/commands/github/release-manager.md +337 -337
- package/.claude/commands/github/repo-architect.md +366 -366
- package/.claude/commands/github/sync-coordinator.md +300 -300
- package/.claude/commands/memory/neural.md +47 -47
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/sparc/analyzer.md +51 -51
- package/.claude/commands/sparc/architect.md +53 -53
- package/.claude/commands/sparc/ask.md +97 -97
- package/.claude/commands/sparc/batch-executor.md +54 -54
- package/.claude/commands/sparc/code.md +89 -89
- package/.claude/commands/sparc/coder.md +54 -54
- package/.claude/commands/sparc/debug.md +83 -83
- package/.claude/commands/sparc/debugger.md +54 -54
- package/.claude/commands/sparc/designer.md +53 -53
- package/.claude/commands/sparc/devops.md +109 -109
- package/.claude/commands/sparc/docs-writer.md +80 -80
- package/.claude/commands/sparc/documenter.md +54 -54
- package/.claude/commands/sparc/innovator.md +54 -54
- package/.claude/commands/sparc/integration.md +83 -83
- package/.claude/commands/sparc/mcp.md +117 -117
- package/.claude/commands/sparc/memory-manager.md +54 -54
- package/.claude/commands/sparc/optimizer.md +54 -54
- package/.claude/commands/sparc/orchestrator.md +131 -131
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
- package/.claude/commands/sparc/researcher.md +54 -54
- package/.claude/commands/sparc/reviewer.md +54 -54
- package/.claude/commands/sparc/security-review.md +80 -80
- package/.claude/commands/sparc/sparc-modes.md +174 -174
- package/.claude/commands/sparc/sparc.md +111 -111
- package/.claude/commands/sparc/spec-pseudocode.md +80 -80
- package/.claude/commands/sparc/supabase-admin.md +348 -348
- package/.claude/commands/sparc/swarm-coordinator.md +54 -54
- package/.claude/commands/sparc/tdd.md +54 -54
- package/.claude/commands/sparc/tester.md +54 -54
- package/.claude/commands/sparc/tutorial.md +79 -79
- package/.claude/commands/sparc/workflow-manager.md +54 -54
- package/.claude/commands/sparc.md +166 -166
- package/.claude/commands/swarm/analysis.md +95 -95
- package/.claude/commands/swarm/development.md +96 -96
- package/.claude/commands/swarm/examples.md +168 -168
- package/.claude/commands/swarm/maintenance.md +102 -102
- package/.claude/commands/swarm/optimization.md +117 -117
- package/.claude/commands/swarm/research.md +136 -136
- package/.claude/commands/swarm/testing.md +131 -131
- package/.claude/commands/workflows/development.md +77 -77
- package/.claude/commands/workflows/research.md +62 -62
- package/.claude/guidance/moflo-bootstrap.md +126 -126
- package/.claude/guidance/shipped/agent-bootstrap.md +148 -143
- package/.claude/guidance/shipped/guidance-memory-strategy.md +262 -262
- package/.claude/guidance/shipped/memory-strategy.md +204 -204
- package/.claude/guidance/shipped/moflo.md +668 -675
- package/.claude/guidance/shipped/task-icons.md +42 -0
- package/.claude/guidance/shipped/task-swarm-integration.md +441 -441
- package/.claude/helpers/gate-hook.mjs +50 -0
- package/.claude/helpers/gate.cjs +138 -0
- package/.claude/helpers/hook-handler.cjs +76 -0
- package/.claude/helpers/intelligence.cjs +207 -207
- package/.claude/helpers/prompt-hook.mjs +72 -0
- package/.claude/helpers/statusline.cjs +851 -851
- package/.claude/scripts/build-embeddings.mjs +549 -0
- package/.claude/scripts/generate-code-map.mjs +776 -0
- package/.claude/scripts/hooks.mjs +656 -0
- package/.claude/scripts/index-guidance.mjs +893 -0
- package/.claude/scripts/index-tests.mjs +710 -0
- package/.claude/scripts/semantic-search.mjs +473 -0
- package/.claude/scripts/session-start-launcher.mjs +238 -0
- package/.claude/settings.local.json +18 -0
- package/.claude/skills/fl/SKILL.md +583 -583
- package/.claude/skills/flo/SKILL.md +583 -583
- package/.claude/skills/github-code-review/SKILL.md +1140 -1140
- package/.claude/skills/github-multi-repo/SKILL.md +874 -874
- package/.claude/skills/github-project-management/SKILL.md +1277 -1277
- package/.claude/skills/github-release-management/SKILL.md +1081 -1081
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
- package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
- package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/performance-analysis/SKILL.md +563 -563
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
- package/.claude/skills/stream-chain/SKILL.md +563 -0
- package/.claude/skills/swarm-advanced/SKILL.md +973 -973
- package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
- package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
- package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
- package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
- package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
- package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
- package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
- package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
- package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
- package/.claude/workflow-state.json +5 -5
- package/LICENSE +21 -21
- package/README.md +698 -685
- package/bin/cli.js +0 -0
- package/bin/gate-hook.mjs +50 -50
- package/bin/gate.cjs +138 -138
- package/bin/generate-code-map.mjs +956 -938
- package/bin/hook-handler.cjs +83 -83
- package/bin/hooks.mjs +696 -696
- package/bin/index-guidance.mjs +906 -893
- package/bin/index-tests.mjs +729 -710
- package/bin/lib/process-manager.mjs +256 -256
- package/bin/lib/registry-cleanup.cjs +41 -41
- package/bin/prompt-hook.mjs +72 -72
- package/bin/semantic-search.mjs +472 -472
- package/bin/session-start-launcher.mjs +238 -238
- package/bin/setup-project.mjs +253 -251
- package/package.json +123 -123
- package/src/@claude-flow/cli/README.md +452 -452
- package/src/@claude-flow/cli/bin/cli.js +180 -180
- package/src/@claude-flow/cli/bin/preinstall.cjs +2 -2
- package/src/@claude-flow/cli/dist/src/commands/completions.js +409 -409
- package/src/@claude-flow/cli/dist/src/commands/doctor.js +156 -3
- package/src/@claude-flow/cli/dist/src/commands/embeddings.js +25 -25
- package/src/@claude-flow/cli/dist/src/commands/github.js +61 -61
- package/src/@claude-flow/cli/dist/src/commands/hive-mind.js +90 -90
- package/src/@claude-flow/cli/dist/src/commands/hooks.js +9 -9
- package/src/@claude-flow/cli/dist/src/commands/init.js +3 -6
- package/src/@claude-flow/cli/dist/src/commands/ruvector/import.js +14 -14
- package/src/@claude-flow/cli/dist/src/commands/ruvector/setup.js +624 -624
- package/src/@claude-flow/cli/dist/src/config/moflo-config.d.ts +3 -0
- package/src/@claude-flow/cli/dist/src/config/moflo-config.js +101 -91
- package/src/@claude-flow/cli/dist/src/index.d.ts +5 -0
- package/src/@claude-flow/cli/dist/src/index.js +44 -0
- package/src/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +29 -29
- package/src/@claude-flow/cli/dist/src/init/claudemd-generator.js +89 -87
- package/src/@claude-flow/cli/dist/src/init/executor.js +453 -453
- package/src/@claude-flow/cli/dist/src/init/helpers-generator.js +482 -482
- package/src/@claude-flow/cli/dist/src/init/moflo-init.d.ts +30 -30
- package/src/@claude-flow/cli/dist/src/init/moflo-init.js +904 -848
- package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +876 -876
- package/src/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +3 -3
- package/src/@claude-flow/cli/dist/src/memory/memory-initializer.js +371 -371
- package/src/@claude-flow/cli/dist/src/runtime/headless.js +28 -28
- package/src/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +197 -0
- package/src/@claude-flow/cli/dist/src/services/container-worker-pool.js +584 -0
- package/src/@claude-flow/cli/dist/src/services/daemon-lock.d.ts +14 -0
- package/src/@claude-flow/cli/dist/src/services/daemon-lock.js +1 -1
- package/src/@claude-flow/cli/dist/src/services/headless-worker-executor.js +84 -84
- package/src/@claude-flow/cli/package.json +1 -1
- package/src/@claude-flow/guidance/README.md +1195 -1195
- package/src/@claude-flow/guidance/package.json +198 -198
- package/src/@claude-flow/memory/README.md +587 -587
- package/src/@claude-flow/memory/dist/agentdb-backend.js +26 -26
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +27 -27
- package/src/@claude-flow/memory/dist/hybrid-backend.d.ts +245 -0
- package/src/@claude-flow/memory/dist/hybrid-backend.js +569 -0
- package/src/@claude-flow/memory/dist/hybrid-backend.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/hybrid-backend.test.js +320 -0
- package/src/@claude-flow/memory/dist/sqlite-backend.d.ts +121 -0
- package/src/@claude-flow/memory/dist/sqlite-backend.js +572 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.js +26 -26
- package/src/@claude-flow/memory/package.json +44 -44
- package/src/@claude-flow/shared/README.md +323 -323
- package/src/@claude-flow/shared/dist/events/event-store.js +31 -31
- package/src/README.md +493 -493
|
@@ -1,207 +1,207 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* Intelligence Layer Stub (ADR-050)
|
|
4
|
-
* Minimal fallback — full version is copied from package source.
|
|
5
|
-
* Provides: init, getContext, recordEdit, feedback, consolidate
|
|
6
|
-
*/
|
|
7
|
-
'use strict';
|
|
8
|
-
|
|
9
|
-
const fs = require('fs');
|
|
10
|
-
const path = require('path');
|
|
11
|
-
const os = require('os');
|
|
12
|
-
|
|
13
|
-
const DATA_DIR = path.join(process.cwd(), '.claude-flow', 'data');
|
|
14
|
-
const STORE_PATH = path.join(DATA_DIR, 'auto-memory-store.json');
|
|
15
|
-
const RANKED_PATH = path.join(DATA_DIR, 'ranked-context.json');
|
|
16
|
-
const PENDING_PATH = path.join(DATA_DIR, 'pending-insights.jsonl');
|
|
17
|
-
const SESSION_DIR = path.join(process.cwd(), '.claude-flow', 'sessions');
|
|
18
|
-
const SESSION_FILE = path.join(SESSION_DIR, 'current.json');
|
|
19
|
-
|
|
20
|
-
function ensureDir(dir) {
|
|
21
|
-
if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
function readJSON(p) {
|
|
25
|
-
try { return fs.existsSync(p) ? JSON.parse(fs.readFileSync(p, "utf-8")) : null; }
|
|
26
|
-
catch { return null; }
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
function writeJSON(p, data) {
|
|
30
|
-
ensureDir(path.dirname(p));
|
|
31
|
-
fs.writeFileSync(p, JSON.stringify(data, null, 2), "utf-8");
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
function sessionGet(key) {
|
|
35
|
-
var session = readJSON(SESSION_FILE);
|
|
36
|
-
if (!session) return null;
|
|
37
|
-
return key ? (session.context || {})[key] : session.context;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
function sessionSet(key, value) {
|
|
41
|
-
var session = readJSON(SESSION_FILE);
|
|
42
|
-
if (!session) return;
|
|
43
|
-
if (!session.context) session.context = {};
|
|
44
|
-
session.context[key] = value;
|
|
45
|
-
writeJSON(SESSION_FILE, session);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
function tokenize(text) {
|
|
49
|
-
if (!text) return [];
|
|
50
|
-
return text.toLowerCase().replace(/[^a-z0-9\s]/g, " ").split(/\s+/).filter(function(w) { return w.length > 2; });
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
function bootstrapFromMemoryFiles() {
|
|
54
|
-
var entries = [];
|
|
55
|
-
var candidates = [
|
|
56
|
-
path.join(os.homedir(), ".claude", "projects"),
|
|
57
|
-
path.join(process.cwd(), ".claude-flow", "memory"),
|
|
58
|
-
path.join(process.cwd(), ".claude", "memory"),
|
|
59
|
-
];
|
|
60
|
-
for (var i = 0; i < candidates.length; i++) {
|
|
61
|
-
try {
|
|
62
|
-
if (!fs.existsSync(candidates[i])) continue;
|
|
63
|
-
var files = [];
|
|
64
|
-
try {
|
|
65
|
-
var items = fs.readdirSync(candidates[i], { withFileTypes: true, recursive: true });
|
|
66
|
-
for (var j = 0; j < items.length; j++) {
|
|
67
|
-
if (items[j].name === "MEMORY.md") {
|
|
68
|
-
var parentDir = items[j].parentPath || items[j].path || candidates[i];
|
|
69
|
-
var fp = path.join(parentDir, items[j].name);
|
|
70
|
-
files.push(fp);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
} catch (e) { continue; }
|
|
74
|
-
for (var k = 0; k < files.length; k++) {
|
|
75
|
-
try {
|
|
76
|
-
var content = fs.readFileSync(files[k], "utf-8");
|
|
77
|
-
var sections = content.split(/^##\s+/m).filter(function(s) { return s.trim().length > 20; });
|
|
78
|
-
for (var s = 0; s < sections.length; s++) {
|
|
79
|
-
var lines = sections[s].split("\n");
|
|
80
|
-
var title = lines[0] ? lines[0].trim() : "section-" + s;
|
|
81
|
-
entries.push({
|
|
82
|
-
id: "mem-" + entries.length,
|
|
83
|
-
content: sections[s].substring(0, 500),
|
|
84
|
-
summary: title.substring(0, 100),
|
|
85
|
-
category: "memory",
|
|
86
|
-
confidence: 0.5,
|
|
87
|
-
sourceFile: files[k],
|
|
88
|
-
words: tokenize(sections[s].substring(0, 500)),
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
} catch (e) { /* skip */ }
|
|
92
|
-
}
|
|
93
|
-
} catch (e) { /* skip */ }
|
|
94
|
-
}
|
|
95
|
-
return entries;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
function loadEntries() {
|
|
99
|
-
var store = readJSON(STORE_PATH);
|
|
100
|
-
// Support both formats: flat array or { entries: [...] }
|
|
101
|
-
var entries = null;
|
|
102
|
-
if (store) {
|
|
103
|
-
if (Array.isArray(store) && store.length > 0) {
|
|
104
|
-
entries = store;
|
|
105
|
-
} else if (store.entries && store.entries.length > 0) {
|
|
106
|
-
entries = store.entries;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
if (entries) {
|
|
110
|
-
return entries.map(function(e, i) {
|
|
111
|
-
return {
|
|
112
|
-
id: e.id || ("entry-" + i),
|
|
113
|
-
content: e.content || e.value || "",
|
|
114
|
-
summary: e.summary || e.key || "",
|
|
115
|
-
category: e.category || e.namespace || "default",
|
|
116
|
-
confidence: e.confidence || 0.5,
|
|
117
|
-
sourceFile: e.sourceFile || (e.metadata && e.metadata.sourceFile) || "",
|
|
118
|
-
words: tokenize((e.content || e.value || "") + " " + (e.summary || e.key || "")),
|
|
119
|
-
};
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
return bootstrapFromMemoryFiles();
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
function matchScore(promptWords, entryWords) {
|
|
126
|
-
if (!promptWords.length || !entryWords.length) return 0;
|
|
127
|
-
var entrySet = {};
|
|
128
|
-
for (var i = 0; i < entryWords.length; i++) entrySet[entryWords[i]] = true;
|
|
129
|
-
var overlap = 0;
|
|
130
|
-
for (var j = 0; j < promptWords.length; j++) {
|
|
131
|
-
if (entrySet[promptWords[j]]) overlap++;
|
|
132
|
-
}
|
|
133
|
-
var union = Object.keys(entrySet).length + promptWords.length - overlap;
|
|
134
|
-
return union > 0 ? overlap / union : 0;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
var cachedEntries = null;
|
|
138
|
-
|
|
139
|
-
module.exports = {
|
|
140
|
-
init: function() {
|
|
141
|
-
cachedEntries = loadEntries();
|
|
142
|
-
var ranked = cachedEntries.map(function(e) {
|
|
143
|
-
return { id: e.id, content: e.content, summary: e.summary, category: e.category, confidence: e.confidence, words: e.words };
|
|
144
|
-
});
|
|
145
|
-
writeJSON(RANKED_PATH, { version: 1, computedAt: Date.now(), entries: ranked });
|
|
146
|
-
return { nodes: cachedEntries.length, edges: 0 };
|
|
147
|
-
},
|
|
148
|
-
|
|
149
|
-
getContext: function(prompt) {
|
|
150
|
-
if (!prompt) return null;
|
|
151
|
-
var ranked = readJSON(RANKED_PATH);
|
|
152
|
-
var entries = (ranked && ranked.entries) || (cachedEntries || []);
|
|
153
|
-
if (!entries.length) return null;
|
|
154
|
-
var promptWords = tokenize(prompt);
|
|
155
|
-
if (!promptWords.length) return null;
|
|
156
|
-
var scored = entries.map(function(e) {
|
|
157
|
-
return { entry: e, score: matchScore(promptWords, e.words || tokenize(e.content + " " + e.summary)) };
|
|
158
|
-
}).filter(function(s) { return s.score > 0.05; });
|
|
159
|
-
scored.sort(function(a, b) { return b.score - a.score; });
|
|
160
|
-
var top = scored.slice(0, 5);
|
|
161
|
-
if (!top.length) return null;
|
|
162
|
-
var prevMatched = sessionGet("lastMatchedPatterns");
|
|
163
|
-
var matchedIds = top.map(function(s) { return s.entry.id; });
|
|
164
|
-
sessionSet("lastMatchedPatterns", matchedIds);
|
|
165
|
-
var lines = ["[INTELLIGENCE] Relevant patterns for this task:"];
|
|
166
|
-
for (var j = 0; j < top.length; j++) {
|
|
167
|
-
var e = top[j];
|
|
168
|
-
var conf = e.entry.confidence || 0.5;
|
|
169
|
-
var summary = (e.entry.summary || e.entry.content || "").substring(0, 80);
|
|
170
|
-
lines.push(" * (" + conf.toFixed(2) + ") " + summary);
|
|
171
|
-
}
|
|
172
|
-
return lines.join("\n");
|
|
173
|
-
},
|
|
174
|
-
|
|
175
|
-
recordEdit: function(file) {
|
|
176
|
-
if (!file) return;
|
|
177
|
-
ensureDir(DATA_DIR);
|
|
178
|
-
var line = JSON.stringify({ type: "edit", file: file, timestamp: Date.now() }) + "\n";
|
|
179
|
-
fs.appendFileSync(PENDING_PATH, line, "utf-8");
|
|
180
|
-
},
|
|
181
|
-
|
|
182
|
-
feedback: function(success) {
|
|
183
|
-
// Stub: no-op in minimal version
|
|
184
|
-
},
|
|
185
|
-
|
|
186
|
-
consolidate: function() {
|
|
187
|
-
var count = 0;
|
|
188
|
-
if (fs.existsSync(PENDING_PATH)) {
|
|
189
|
-
try {
|
|
190
|
-
var content = fs.readFileSync(PENDING_PATH, "utf-8").trim();
|
|
191
|
-
count = content ? content.split("\n").length : 0;
|
|
192
|
-
fs.writeFileSync(PENDING_PATH, "", "utf-8");
|
|
193
|
-
} catch (e) { /* skip */ }
|
|
194
|
-
}
|
|
195
|
-
return { entries: count, edges: 0, newEntries: 0 };
|
|
196
|
-
},
|
|
197
|
-
|
|
198
|
-
stats: function(json) {
|
|
199
|
-
var ranked = readJSON(RANKED_PATH);
|
|
200
|
-
var count = ranked && ranked.entries ? ranked.entries.length : 0;
|
|
201
|
-
if (json) {
|
|
202
|
-
console.log(JSON.stringify({ entries: count, computedAt: ranked ? ranked.computedAt : null }));
|
|
203
|
-
} else {
|
|
204
|
-
console.log('[INTELLIGENCE] Stats: ' + count + ' entries loaded');
|
|
205
|
-
}
|
|
206
|
-
},
|
|
207
|
-
};
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Intelligence Layer Stub (ADR-050)
|
|
4
|
+
* Minimal fallback — full version is copied from package source.
|
|
5
|
+
* Provides: init, getContext, recordEdit, feedback, consolidate
|
|
6
|
+
*/
|
|
7
|
+
'use strict';
|
|
8
|
+
|
|
9
|
+
const fs = require('fs');
|
|
10
|
+
const path = require('path');
|
|
11
|
+
const os = require('os');
|
|
12
|
+
|
|
13
|
+
const DATA_DIR = path.join(process.cwd(), '.claude-flow', 'data');
|
|
14
|
+
const STORE_PATH = path.join(DATA_DIR, 'auto-memory-store.json');
|
|
15
|
+
const RANKED_PATH = path.join(DATA_DIR, 'ranked-context.json');
|
|
16
|
+
const PENDING_PATH = path.join(DATA_DIR, 'pending-insights.jsonl');
|
|
17
|
+
const SESSION_DIR = path.join(process.cwd(), '.claude-flow', 'sessions');
|
|
18
|
+
const SESSION_FILE = path.join(SESSION_DIR, 'current.json');
|
|
19
|
+
|
|
20
|
+
function ensureDir(dir) {
|
|
21
|
+
if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function readJSON(p) {
|
|
25
|
+
try { return fs.existsSync(p) ? JSON.parse(fs.readFileSync(p, "utf-8")) : null; }
|
|
26
|
+
catch { return null; }
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
function writeJSON(p, data) {
|
|
30
|
+
ensureDir(path.dirname(p));
|
|
31
|
+
fs.writeFileSync(p, JSON.stringify(data, null, 2), "utf-8");
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function sessionGet(key) {
|
|
35
|
+
var session = readJSON(SESSION_FILE);
|
|
36
|
+
if (!session) return null;
|
|
37
|
+
return key ? (session.context || {})[key] : session.context;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function sessionSet(key, value) {
|
|
41
|
+
var session = readJSON(SESSION_FILE);
|
|
42
|
+
if (!session) return;
|
|
43
|
+
if (!session.context) session.context = {};
|
|
44
|
+
session.context[key] = value;
|
|
45
|
+
writeJSON(SESSION_FILE, session);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function tokenize(text) {
|
|
49
|
+
if (!text) return [];
|
|
50
|
+
return text.toLowerCase().replace(/[^a-z0-9\s]/g, " ").split(/\s+/).filter(function(w) { return w.length > 2; });
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
function bootstrapFromMemoryFiles() {
|
|
54
|
+
var entries = [];
|
|
55
|
+
var candidates = [
|
|
56
|
+
path.join(os.homedir(), ".claude", "projects"),
|
|
57
|
+
path.join(process.cwd(), ".claude-flow", "memory"),
|
|
58
|
+
path.join(process.cwd(), ".claude", "memory"),
|
|
59
|
+
];
|
|
60
|
+
for (var i = 0; i < candidates.length; i++) {
|
|
61
|
+
try {
|
|
62
|
+
if (!fs.existsSync(candidates[i])) continue;
|
|
63
|
+
var files = [];
|
|
64
|
+
try {
|
|
65
|
+
var items = fs.readdirSync(candidates[i], { withFileTypes: true, recursive: true });
|
|
66
|
+
for (var j = 0; j < items.length; j++) {
|
|
67
|
+
if (items[j].name === "MEMORY.md") {
|
|
68
|
+
var parentDir = items[j].parentPath || items[j].path || candidates[i];
|
|
69
|
+
var fp = path.join(parentDir, items[j].name);
|
|
70
|
+
files.push(fp);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
} catch (e) { continue; }
|
|
74
|
+
for (var k = 0; k < files.length; k++) {
|
|
75
|
+
try {
|
|
76
|
+
var content = fs.readFileSync(files[k], "utf-8");
|
|
77
|
+
var sections = content.split(/^##\s+/m).filter(function(s) { return s.trim().length > 20; });
|
|
78
|
+
for (var s = 0; s < sections.length; s++) {
|
|
79
|
+
var lines = sections[s].split("\n");
|
|
80
|
+
var title = lines[0] ? lines[0].trim() : "section-" + s;
|
|
81
|
+
entries.push({
|
|
82
|
+
id: "mem-" + entries.length,
|
|
83
|
+
content: sections[s].substring(0, 500),
|
|
84
|
+
summary: title.substring(0, 100),
|
|
85
|
+
category: "memory",
|
|
86
|
+
confidence: 0.5,
|
|
87
|
+
sourceFile: files[k],
|
|
88
|
+
words: tokenize(sections[s].substring(0, 500)),
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
} catch (e) { /* skip */ }
|
|
92
|
+
}
|
|
93
|
+
} catch (e) { /* skip */ }
|
|
94
|
+
}
|
|
95
|
+
return entries;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
function loadEntries() {
|
|
99
|
+
var store = readJSON(STORE_PATH);
|
|
100
|
+
// Support both formats: flat array or { entries: [...] }
|
|
101
|
+
var entries = null;
|
|
102
|
+
if (store) {
|
|
103
|
+
if (Array.isArray(store) && store.length > 0) {
|
|
104
|
+
entries = store;
|
|
105
|
+
} else if (store.entries && store.entries.length > 0) {
|
|
106
|
+
entries = store.entries;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (entries) {
|
|
110
|
+
return entries.map(function(e, i) {
|
|
111
|
+
return {
|
|
112
|
+
id: e.id || ("entry-" + i),
|
|
113
|
+
content: e.content || e.value || "",
|
|
114
|
+
summary: e.summary || e.key || "",
|
|
115
|
+
category: e.category || e.namespace || "default",
|
|
116
|
+
confidence: e.confidence || 0.5,
|
|
117
|
+
sourceFile: e.sourceFile || (e.metadata && e.metadata.sourceFile) || "",
|
|
118
|
+
words: tokenize((e.content || e.value || "") + " " + (e.summary || e.key || "")),
|
|
119
|
+
};
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
return bootstrapFromMemoryFiles();
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
function matchScore(promptWords, entryWords) {
|
|
126
|
+
if (!promptWords.length || !entryWords.length) return 0;
|
|
127
|
+
var entrySet = {};
|
|
128
|
+
for (var i = 0; i < entryWords.length; i++) entrySet[entryWords[i]] = true;
|
|
129
|
+
var overlap = 0;
|
|
130
|
+
for (var j = 0; j < promptWords.length; j++) {
|
|
131
|
+
if (entrySet[promptWords[j]]) overlap++;
|
|
132
|
+
}
|
|
133
|
+
var union = Object.keys(entrySet).length + promptWords.length - overlap;
|
|
134
|
+
return union > 0 ? overlap / union : 0;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
var cachedEntries = null;
|
|
138
|
+
|
|
139
|
+
module.exports = {
|
|
140
|
+
init: function() {
|
|
141
|
+
cachedEntries = loadEntries();
|
|
142
|
+
var ranked = cachedEntries.map(function(e) {
|
|
143
|
+
return { id: e.id, content: e.content, summary: e.summary, category: e.category, confidence: e.confidence, words: e.words };
|
|
144
|
+
});
|
|
145
|
+
writeJSON(RANKED_PATH, { version: 1, computedAt: Date.now(), entries: ranked });
|
|
146
|
+
return { nodes: cachedEntries.length, edges: 0 };
|
|
147
|
+
},
|
|
148
|
+
|
|
149
|
+
getContext: function(prompt) {
|
|
150
|
+
if (!prompt) return null;
|
|
151
|
+
var ranked = readJSON(RANKED_PATH);
|
|
152
|
+
var entries = (ranked && ranked.entries) || (cachedEntries || []);
|
|
153
|
+
if (!entries.length) return null;
|
|
154
|
+
var promptWords = tokenize(prompt);
|
|
155
|
+
if (!promptWords.length) return null;
|
|
156
|
+
var scored = entries.map(function(e) {
|
|
157
|
+
return { entry: e, score: matchScore(promptWords, e.words || tokenize(e.content + " " + e.summary)) };
|
|
158
|
+
}).filter(function(s) { return s.score > 0.05; });
|
|
159
|
+
scored.sort(function(a, b) { return b.score - a.score; });
|
|
160
|
+
var top = scored.slice(0, 5);
|
|
161
|
+
if (!top.length) return null;
|
|
162
|
+
var prevMatched = sessionGet("lastMatchedPatterns");
|
|
163
|
+
var matchedIds = top.map(function(s) { return s.entry.id; });
|
|
164
|
+
sessionSet("lastMatchedPatterns", matchedIds);
|
|
165
|
+
var lines = ["[INTELLIGENCE] Relevant patterns for this task:"];
|
|
166
|
+
for (var j = 0; j < top.length; j++) {
|
|
167
|
+
var e = top[j];
|
|
168
|
+
var conf = e.entry.confidence || 0.5;
|
|
169
|
+
var summary = (e.entry.summary || e.entry.content || "").substring(0, 80);
|
|
170
|
+
lines.push(" * (" + conf.toFixed(2) + ") " + summary);
|
|
171
|
+
}
|
|
172
|
+
return lines.join("\n");
|
|
173
|
+
},
|
|
174
|
+
|
|
175
|
+
recordEdit: function(file) {
|
|
176
|
+
if (!file) return;
|
|
177
|
+
ensureDir(DATA_DIR);
|
|
178
|
+
var line = JSON.stringify({ type: "edit", file: file, timestamp: Date.now() }) + "\n";
|
|
179
|
+
fs.appendFileSync(PENDING_PATH, line, "utf-8");
|
|
180
|
+
},
|
|
181
|
+
|
|
182
|
+
feedback: function(success) {
|
|
183
|
+
// Stub: no-op in minimal version
|
|
184
|
+
},
|
|
185
|
+
|
|
186
|
+
consolidate: function() {
|
|
187
|
+
var count = 0;
|
|
188
|
+
if (fs.existsSync(PENDING_PATH)) {
|
|
189
|
+
try {
|
|
190
|
+
var content = fs.readFileSync(PENDING_PATH, "utf-8").trim();
|
|
191
|
+
count = content ? content.split("\n").length : 0;
|
|
192
|
+
fs.writeFileSync(PENDING_PATH, "", "utf-8");
|
|
193
|
+
} catch (e) { /* skip */ }
|
|
194
|
+
}
|
|
195
|
+
return { entries: count, edges: 0, newEntries: 0 };
|
|
196
|
+
},
|
|
197
|
+
|
|
198
|
+
stats: function(json) {
|
|
199
|
+
var ranked = readJSON(RANKED_PATH);
|
|
200
|
+
var count = ranked && ranked.entries ? ranked.entries.length : 0;
|
|
201
|
+
if (json) {
|
|
202
|
+
console.log(JSON.stringify({ entries: count, computedAt: ranked ? ranked.computedAt : null }));
|
|
203
|
+
} else {
|
|
204
|
+
console.log('[INTELLIGENCE] Stats: ' + count + ' entries loaded');
|
|
205
|
+
}
|
|
206
|
+
},
|
|
207
|
+
};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { execSync } from 'child_process';
|
|
3
|
+
import { resolve } from 'path';
|
|
4
|
+
|
|
5
|
+
// Read stdin JSON from Claude Code
|
|
6
|
+
var stdinData = '';
|
|
7
|
+
try {
|
|
8
|
+
stdinData = await new Promise(function(res) {
|
|
9
|
+
var data = '';
|
|
10
|
+
var timeout = setTimeout(function() { res(data); }, 500);
|
|
11
|
+
process.stdin.setEncoding('utf-8');
|
|
12
|
+
process.stdin.on('data', function(chunk) { data += chunk; });
|
|
13
|
+
process.stdin.on('end', function() { clearTimeout(timeout); res(data); });
|
|
14
|
+
process.stdin.on('error', function() { clearTimeout(timeout); res(''); });
|
|
15
|
+
if (process.stdin.isTTY) { clearTimeout(timeout); res(''); }
|
|
16
|
+
});
|
|
17
|
+
} catch (e) { /* no stdin */ }
|
|
18
|
+
|
|
19
|
+
var hookContext = {};
|
|
20
|
+
try { if (stdinData.trim()) hookContext = JSON.parse(stdinData); } catch (e) {}
|
|
21
|
+
|
|
22
|
+
var userPrompt = hookContext.user_prompt || hookContext.prompt || '';
|
|
23
|
+
var env = Object.assign({}, process.env, { CLAUDE_USER_PROMPT: userPrompt });
|
|
24
|
+
|
|
25
|
+
// Run prompt-reminder via gate.cjs
|
|
26
|
+
var projectDir = (env.CLAUDE_PROJECT_DIR || process.cwd()).replace(/^\/([a-z])\//i, '$1:/');
|
|
27
|
+
var gateScript = resolve(projectDir, '.claude/helpers/gate.cjs');
|
|
28
|
+
var output = '';
|
|
29
|
+
try {
|
|
30
|
+
output = execSync('node "' + gateScript + '" prompt-reminder', {
|
|
31
|
+
env: env, encoding: 'utf-8', timeout: 3000, stdio: ['pipe', 'pipe', 'pipe']
|
|
32
|
+
});
|
|
33
|
+
} catch (err) { output = (err && err.stdout) || ''; }
|
|
34
|
+
|
|
35
|
+
// Classify prompt for namespace hint
|
|
36
|
+
var lower = userPrompt.toLowerCase();
|
|
37
|
+
|
|
38
|
+
var KNOWLEDGE_ONLY = /\b(knowledge|remember|recall)\b|we (decid|agree|chose|said)/;
|
|
39
|
+
var EXPLICIT_NS = [
|
|
40
|
+
{ pattern: /\b(pattern|convention|best practice|style|coding rule)\b/, ns: 'patterns', label: 'code patterns and conventions' },
|
|
41
|
+
{ pattern: /\b(code.?map|file structure|project structure|directory)\b/, ns: 'code-map', label: 'codebase navigation' },
|
|
42
|
+
];
|
|
43
|
+
var PATTERN_HINTS = [/\b(template|example|similar to|how do we|how should)\b/];
|
|
44
|
+
var DOMAIN_HINTS = [
|
|
45
|
+
/\b(guidance|guide|docs|documentation|rules|how-to)\b/,
|
|
46
|
+
/\b(architecture|design|domain|tenant|migrat|schema|deploy)/,
|
|
47
|
+
/\b(rule|requirement|constraint|compliance)\b/,
|
|
48
|
+
];
|
|
49
|
+
var NAV_PATTERNS = [
|
|
50
|
+
/\b(find|where|which file|look up|locate|endpoint|route|url|path)\b/,
|
|
51
|
+
/\b(class|function|method|component|service|entity|module)\b/,
|
|
52
|
+
];
|
|
53
|
+
|
|
54
|
+
var nsHint = '';
|
|
55
|
+
if (KNOWLEDGE_ONLY.test(lower)) {
|
|
56
|
+
nsHint = 'Memory namespace hint: use "knowledge" for user-directed project decisions.';
|
|
57
|
+
} else {
|
|
58
|
+
var found = EXPLICIT_NS.find(function(e) { return e.pattern.test(lower); });
|
|
59
|
+
if (found) {
|
|
60
|
+
nsHint = 'Memory namespace hint: use "' + found.ns + '" for ' + found.label + '.';
|
|
61
|
+
} else if (DOMAIN_HINTS.some(function(p) { return p.test(lower); })) {
|
|
62
|
+
nsHint = 'Memory namespace hint: search "guidance" and "knowledge" for domain rules and project decisions.';
|
|
63
|
+
} else if (PATTERN_HINTS.some(function(p) { return p.test(lower); })) {
|
|
64
|
+
nsHint = 'Memory namespace hint: use "patterns" for code patterns and conventions.';
|
|
65
|
+
} else if (NAV_PATTERNS.some(function(p) { return p.test(lower); })) {
|
|
66
|
+
nsHint = 'Memory namespace hint: use "code-map" for codebase navigation.';
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
var parts = [output.trim(), nsHint].filter(Boolean);
|
|
71
|
+
if (parts.length) process.stdout.write(parts.join('\n') + '\n');
|
|
72
|
+
process.exit(0);
|