@monoes/monomindcli 1.7.0 → 1.9.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/.claude/agents/design/design-monodesign.md +121 -0
- package/.claude/agents/github/issue-tracker.md +12 -12
- package/.claude/agents/github/pr-manager.md +10 -10
- package/.claude/agents/github/release-manager.md +49 -105
- package/.claude/agents/github/repo-architect.md +73 -92
- package/.claude/agents/github/sync-coordinator.md +55 -123
- package/.claude/agents/marketing/marketing-competitive-content.md +155 -0
- package/.claude/agents/marketing/marketing-content-creator.md +13 -0
- package/.claude/agents/marketing/marketing-cro-specialist.md +147 -0
- package/.claude/agents/marketing/marketing-email-specialist.md +90 -0
- package/.claude/agents/marketing/marketing-launch-strategist.md +129 -0
- package/.claude/agents/marketing/marketing-pricing-strategist.md +127 -0
- package/.claude/agents/specialists/integration-architect.md +94 -0
- package/.claude/commands/agents/README.md +4 -0
- package/.claude/commands/agents/agent-capabilities.md +6 -2
- package/.claude/commands/agents/agent-coordination.md +4 -0
- package/.claude/commands/agents/agent-spawning.md +4 -0
- package/.claude/commands/agents/agent-types.md +6 -2
- package/.claude/commands/analysis/README.md +14 -5
- package/.claude/commands/analysis/bottleneck-detect.md +30 -123
- package/.claude/commands/analysis/performance-bottlenecks.md +14 -14
- package/.claude/commands/analysis/performance-report.md +38 -11
- package/.claude/commands/analysis/token-efficiency.md +13 -16
- package/.claude/commands/analysis/token-usage.md +34 -12
- package/.claude/commands/automation/README.md +15 -5
- package/.claude/commands/automation/auto-agent.md +49 -85
- package/.claude/commands/automation/self-healing.md +20 -18
- package/.claude/commands/automation/session-memory.md +28 -29
- package/.claude/commands/automation/smart-agents.md +17 -9
- package/.claude/commands/automation/smart-spawn.md +52 -11
- package/.claude/commands/automation/workflow-select.md +46 -11
- package/.claude/commands/browse.md +5 -0
- package/.claude/commands/coordination/README.md +9 -5
- package/.claude/commands/coordination/agent-spawn.md +53 -9
- package/.claude/commands/coordination/swarm-init.md +39 -42
- package/.claude/commands/coordination/task-orchestrate.md +65 -11
- package/.claude/commands/github/README.md +21 -8
- package/.claude/commands/github/github-modes.md +9 -5
- package/.claude/commands/github/issue-tracker.md +34 -33
- package/.claude/commands/github/pr-manager.md +20 -17
- package/.claude/commands/github/release-manager.md +37 -49
- package/.claude/commands/github/repo-architect.md +39 -41
- package/.claude/commands/github/sync-coordinator.md +45 -49
- package/.claude/commands/hive-mind/README.md +42 -17
- package/.claude/commands/hive-mind/hive-mind-consensus.md +68 -4
- package/.claude/commands/hive-mind/hive-mind-init.md +55 -5
- package/.claude/commands/hive-mind/hive-mind-memory.md +69 -4
- package/.claude/commands/hive-mind/hive-mind-spawn.md +71 -10
- package/.claude/commands/hive-mind/hive-mind-status.md +52 -4
- package/.claude/commands/hive-mind/hive-mind-stop.md +51 -4
- package/.claude/commands/hive-mind/hive-mind.md +74 -14
- package/.claude/commands/hooks/README.md +62 -7
- package/.claude/commands/hooks/overview.md +94 -35
- package/.claude/commands/hooks/post-edit.md +48 -87
- package/.claude/commands/hooks/post-task.md +37 -87
- package/.claude/commands/hooks/pre-edit.md +52 -84
- package/.claude/commands/hooks/pre-task.md +46 -81
- package/.claude/commands/hooks/session-end.md +49 -85
- package/.claude/commands/hooks/setup.md +87 -58
- package/.claude/commands/mastermind/_repeat.md +308 -0
- package/.claude/commands/mastermind/architect.md +49 -0
- package/.claude/commands/mastermind/brain.md +98 -0
- package/.claude/commands/mastermind/build.md +22 -0
- package/.claude/commands/mastermind/content.md +22 -0
- package/.claude/commands/mastermind/createorg.md +94 -0
- package/.claude/commands/mastermind/finance.md +22 -0
- package/.claude/commands/mastermind/idea.md +22 -0
- package/.claude/commands/mastermind/marketing.md +22 -0
- package/.claude/commands/mastermind/master.md +379 -0
- package/.claude/commands/mastermind/ops.md +22 -0
- package/.claude/commands/mastermind/release.md +22 -0
- package/.claude/commands/mastermind/research.md +22 -0
- package/.claude/commands/mastermind/review.md +22 -0
- package/.claude/commands/mastermind/runorg.md +106 -0
- package/.claude/commands/mastermind/sales.md +22 -0
- package/.claude/commands/mastermind/techport.md +17 -0
- package/.claude/commands/memory/README.md +75 -5
- package/.claude/commands/memory/memory-search.md +63 -11
- package/.claude/commands/monitoring/README.md +64 -4
- package/.claude/commands/monitoring/agent-metrics.md +50 -10
- package/.claude/commands/monitoring/agents.md +59 -32
- package/.claude/commands/monitoring/status.md +96 -34
- package/.claude/commands/monograph/README.md +102 -0
- package/.claude/commands/monograph/monograph-build.md +79 -0
- package/.claude/commands/monograph/monograph-search.md +96 -0
- package/.claude/commands/monograph/monograph-stats.md +53 -0
- package/.claude/commands/monograph/monograph-watch.md +63 -0
- package/.claude/commands/monograph/monograph-wiki.md +91 -0
- package/.claude/commands/monomind/createtask.md +277 -0
- package/.claude/commands/{monomind-do.md → monomind/do.md} +22 -9
- package/.claude/commands/monomind/help.md +118 -0
- package/.claude/commands/{monomind-idea.md → monomind/idea.md} +23 -29
- package/.claude/commands/{monomind-improve.md → monomind/improve.md} +24 -30
- package/.claude/commands/monomind/memory.md +230 -0
- package/.claude/commands/monomind/repeat.md +201 -0
- package/.claude/commands/monomind/review.md +313 -0
- package/.claude/commands/monomind/specialagents.md +125 -0
- package/.claude/commands/monomind/swarm.md +161 -0
- package/.claude/commands/monomind/understand.md +148 -0
- package/.claude/commands/optimization/README.md +69 -5
- package/.claude/commands/optimization/auto-topology.md +66 -43
- package/.claude/commands/optimization/parallel-execution.md +65 -39
- package/.claude/commands/optimization/performance-optimize.md +79 -0
- package/.claude/commands/pair/README.md +48 -230
- package/.claude/commands/pair/examples.md +85 -441
- package/.claude/commands/pair/modes.md +77 -303
- package/.claude/commands/pair/session.md +76 -359
- package/.claude/commands/sparc/analyzer.md +9 -26
- package/.claude/commands/sparc/architect.md +8 -25
- package/.claude/commands/sparc/ask.md +27 -68
- package/.claude/commands/sparc/batch-executor.md +8 -25
- package/.claude/commands/sparc/code.md +12 -53
- package/.claude/commands/sparc/coder.md +8 -25
- package/.claude/commands/sparc/debug.md +12 -53
- package/.claude/commands/sparc/debugger.md +8 -25
- package/.claude/commands/sparc/designer.md +8 -25
- package/.claude/commands/sparc/devops.md +16 -57
- package/.claude/commands/sparc/docs-writer.md +12 -53
- package/.claude/commands/sparc/documenter.md +8 -25
- package/.claude/commands/sparc/innovator.md +8 -25
- package/.claude/commands/sparc/integration.md +12 -53
- package/.claude/commands/sparc/mcp.md +12 -53
- package/.claude/commands/sparc/memory-manager.md +28 -25
- package/.claude/commands/sparc/optimizer.md +8 -25
- package/.claude/commands/sparc/orchestrator.md +35 -97
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +13 -54
- package/.claude/commands/sparc/refinement-optimization-mode.md +13 -54
- package/.claude/commands/sparc/researcher.md +8 -25
- package/.claude/commands/sparc/reviewer.md +8 -25
- package/.claude/commands/sparc/security-review.md +13 -54
- package/.claude/commands/sparc/sparc-modes.md +97 -151
- package/.claude/commands/sparc/sparc.md +16 -56
- package/.claude/commands/sparc/spec-pseudocode.md +13 -54
- package/.claude/commands/sparc/supabase-admin.md +19 -66
- package/.claude/commands/sparc/swarm-coordinator.md +21 -25
- package/.claude/commands/sparc/tdd.md +8 -25
- package/.claude/commands/sparc/tester.md +8 -25
- package/.claude/commands/sparc/tutorial.md +12 -53
- package/.claude/commands/sparc/workflow-manager.md +8 -25
- package/.claude/commands/sparc.md +76 -130
- package/.claude/commands/stream-chain/pipeline.md +72 -77
- package/.claude/commands/stream-chain/run.md +133 -47
- package/.claude/commands/swarm/README.md +37 -12
- package/.claude/commands/swarm/analysis.md +47 -69
- package/.claude/commands/swarm/development.md +45 -69
- package/.claude/commands/swarm/examples.md +77 -142
- package/.claude/commands/swarm/maintenance.md +47 -74
- package/.claude/commands/swarm/optimization.md +54 -87
- package/.claude/commands/swarm/research.md +47 -107
- package/.claude/commands/swarm/swarm-analysis.md +58 -4
- package/.claude/commands/swarm/swarm-background.md +61 -4
- package/.claude/commands/swarm/swarm-modes.md +63 -4
- package/.claude/commands/swarm/swarm-monitor.md +50 -4
- package/.claude/commands/swarm/swarm-status.md +40 -4
- package/.claude/commands/swarm/swarm-strategies.md +73 -5
- package/.claude/commands/swarm/swarm.md +70 -18
- package/.claude/commands/swarm/testing.md +51 -102
- package/.claude/commands/tokens.md +6 -1
- package/.claude/commands/training/README.md +36 -6
- package/.claude/commands/training/model-update.md +68 -15
- package/.claude/commands/training/neural-patterns.md +54 -55
- package/.claude/commands/training/neural-train.md +70 -16
- package/.claude/commands/training/pattern-learn.md +60 -16
- package/.claude/commands/training/specialization.md +78 -49
- package/.claude/commands/truth/start.md +87 -109
- package/.claude/commands/ts.md +7 -2
- package/.claude/commands/verify/check.md +90 -34
- package/.claude/commands/verify/start.md +71 -94
- package/.claude/commands/workflows/README.md +62 -6
- package/.claude/commands/workflows/development.md +69 -61
- package/.claude/commands/workflows/research.md +73 -47
- package/.claude/commands/workflows/workflow-create.md +75 -16
- package/.claude/commands/workflows/workflow-execute.md +94 -16
- package/.claude/commands/workflows/workflow-export.md +81 -16
- package/.claude/helpers/control-start.cjs +91 -0
- package/.claude/helpers/extras-registry.json +4104 -1991
- package/.claude/helpers/graphify-freshen.cjs +44 -13
- package/.claude/helpers/hook-handler.cjs +256 -1
- package/.claude/helpers/loop-tracker.cjs +107 -0
- package/.claude/helpers/router.cjs +48 -68
- package/.claude/helpers/skill-registry.json +89 -104
- package/.claude/helpers/statusline.cjs +33 -2
- package/.claude/skills/.monomind/data/ranked-context.json +5 -0
- package/.claude/skills/.monomind/sessions/current.json +13 -0
- package/.claude/skills/.monomind/sessions/session-1777829336455.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777831614725.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777832095857.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777839814183.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777841847131.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777843309463.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777880867159.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777881884593.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777884090471.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777884808221.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777885672155.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777886852818.json +15 -0
- package/.claude/skills/.monomind/sessions/session-1777896532690.json +15 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +11 -12
- package/.claude/skills/agentdb-learning/SKILL.md +20 -21
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +28 -30
- package/.claude/skills/agentdb-optimization/SKILL.md +11 -12
- package/.claude/skills/agentdb-vector-search/SKILL.md +37 -41
- package/.claude/skills/{v3-integration-deep → agentic-integration}/SKILL.md +20 -13
- package/.claude/skills/agentic-jujutsu/SKILL.md +22 -22
- package/.claude/skills/{v3-cli-modernization → cli-modernization}/SKILL.md +17 -8
- package/.claude/skills/{v3-core-implementation → core-implementation}/SKILL.md +33 -8
- package/.claude/skills/{v3-ddd-architecture → ddd-architecture}/SKILL.md +18 -25
- package/.claude/skills/github-code-review/SKILL.md +82 -83
- package/.claude/skills/github-multi-repo/SKILL.md +42 -46
- package/.claude/skills/github-project-management/SKILL.md +83 -88
- package/.claude/skills/github-release-management/SKILL.md +12 -18
- package/.claude/skills/github-workflow-automation/SKILL.md +70 -74
- package/.claude/skills/hooks-automation/SKILL.md +9 -13
- package/.claude/skills/mastermind/_intake.md +83 -0
- package/.claude/skills/mastermind/_protocol.md +275 -0
- package/.claude/skills/mastermind/architect.md +847 -0
- package/.claude/skills/mastermind/build.md +158 -0
- package/.claude/skills/mastermind/content.md +185 -0
- package/.claude/skills/mastermind/createorg.md +318 -0
- package/.claude/skills/mastermind/finance.md +154 -0
- package/.claude/skills/mastermind/idea.md +158 -0
- package/.claude/skills/mastermind/marketing.md +216 -0
- package/.claude/skills/mastermind/monotask.md +350 -0
- package/.claude/skills/mastermind/ops.md +156 -0
- package/.claude/skills/mastermind/references/copywriting-frameworks.md +181 -0
- package/.claude/skills/mastermind/references/persuasion-psychology.md +158 -0
- package/.claude/skills/mastermind/release.md +156 -0
- package/.claude/skills/mastermind/research.md +156 -0
- package/.claude/skills/mastermind/review.md +157 -0
- package/.claude/skills/mastermind/runorg.md +308 -0
- package/.claude/skills/mastermind/sales.md +158 -0
- package/.claude/skills/mastermind/techport.md +743 -0
- package/.claude/skills/{v3-mcp-optimization → mcp-optimization}/SKILL.md +35 -14
- package/.claude/skills/{v3-memory-unification → memory-unification}/SKILL.md +20 -4
- package/.claude/skills/monodesign/SKILL.md +302 -0
- package/.claude/skills/monodesign/reference/adapt.md +190 -0
- package/.claude/skills/monodesign/reference/animate.md +175 -0
- package/.claude/skills/monodesign/reference/antipatterns-catalog.md +187 -0
- package/.claude/skills/monodesign/reference/audit.md +133 -0
- package/.claude/skills/monodesign/reference/bolder.md +113 -0
- package/.claude/skills/monodesign/reference/brand-workflow.md +180 -0
- package/.claude/skills/monodesign/reference/brand.md +114 -0
- package/.claude/skills/monodesign/reference/clarify.md +174 -0
- package/.claude/skills/monodesign/reference/cognitive-load.md +106 -0
- package/.claude/skills/monodesign/reference/color-and-contrast.md +105 -0
- package/.claude/skills/monodesign/reference/colorize.md +154 -0
- package/.claude/skills/monodesign/reference/component-specs.md +260 -0
- package/.claude/skills/monodesign/reference/component-states.md +274 -0
- package/.claude/skills/monodesign/reference/component-system.md +358 -0
- package/.claude/skills/monodesign/reference/copy-formulas.md +160 -0
- package/.claude/skills/monodesign/reference/craft.md +193 -0
- package/.claude/skills/monodesign/reference/critique.md +213 -0
- package/.claude/skills/monodesign/reference/delight.md +302 -0
- package/.claude/skills/monodesign/reference/design-principles.md +246 -0
- package/.claude/skills/monodesign/reference/distill.md +111 -0
- package/.claude/skills/monodesign/reference/document.md +427 -0
- package/.claude/skills/monodesign/reference/extract.md +69 -0
- package/.claude/skills/monodesign/reference/harden.md +347 -0
- package/.claude/skills/monodesign/reference/heuristics-scoring.md +234 -0
- package/.claude/skills/monodesign/reference/image-prompts.md +118 -0
- package/.claude/skills/monodesign/reference/interaction-design.md +195 -0
- package/.claude/skills/monodesign/reference/layout.md +141 -0
- package/.claude/skills/monodesign/reference/live.md +622 -0
- package/.claude/skills/monodesign/reference/motion-design.md +109 -0
- package/.claude/skills/monodesign/reference/onboard.md +234 -0
- package/.claude/skills/monodesign/reference/optimize.md +258 -0
- package/.claude/skills/monodesign/reference/overdrive.md +130 -0
- package/.claude/skills/monodesign/reference/personas.md +179 -0
- package/.claude/skills/monodesign/reference/polish.md +233 -0
- package/.claude/skills/monodesign/reference/pre-delivery-checklist.md +108 -0
- package/.claude/skills/monodesign/reference/product.md +62 -0
- package/.claude/skills/monodesign/reference/quieter.md +99 -0
- package/.claude/skills/monodesign/reference/responsive-design.md +114 -0
- package/.claude/skills/monodesign/reference/shape.md +151 -0
- package/.claude/skills/monodesign/reference/spatial-design.md +100 -0
- package/.claude/skills/monodesign/reference/teach.md +156 -0
- package/.claude/skills/monodesign/reference/token-architecture.md +222 -0
- package/.claude/skills/monodesign/reference/typeset.md +124 -0
- package/.claude/skills/monodesign/reference/typography.md +159 -0
- package/.claude/skills/monodesign/reference/ux-research.md +143 -0
- package/.claude/skills/monodesign/reference/ux-rules.md +211 -0
- package/.claude/skills/monodesign/reference/ux-writing.md +107 -0
- package/.claude/skills/monomotion/SKILL.md +145 -0
- package/.claude/skills/monomotion/rules/api-control.md +139 -0
- package/.claude/skills/monomotion/rules/effects.md +109 -0
- package/.claude/skills/monomotion/rules/integration.md +140 -0
- package/.claude/skills/monomotion/rules/scroll.md +131 -0
- package/.claude/skills/monomotion/rules/sequencing.md +105 -0
- package/.claude/skills/monomotion/rules/svg.md +101 -0
- package/.claude/skills/monomotion/rules/text.md +119 -0
- package/.claude/skills/pair-programming/SKILL.md +1 -1
- package/.claude/skills/performance-analysis/SKILL.md +3 -3
- package/.claude/skills/{v3-performance-optimization → performance-optimization}/SKILL.md +16 -8
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +17 -19
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +4 -6
- package/.claude/skills/{v3-security-overhaul → security-hardening}/SKILL.md +13 -3
- package/.claude/skills/skill-builder/SKILL.md +19 -19
- package/.claude/skills/sparc-methodology/SKILL.md +55 -211
- package/.claude/skills/stop-slop/SKILL.md +67 -0
- package/.claude/skills/stop-slop/references/examples.md +61 -0
- package/.claude/skills/stop-slop/references/phrases.md +130 -0
- package/.claude/skills/stop-slop/references/structures.md +136 -0
- package/.claude/skills/swarm-advanced/SKILL.md +13 -43
- package/.claude/skills/{v3-swarm-coordination → swarm-coordination}/SKILL.md +39 -21
- package/.claude/skills/swarm-orchestration/SKILL.md +12 -12
- package/.claude/skills/verification-quality/SKILL.md +5 -5
- package/README.md +5 -5
- package/bin/cli.js +78 -13
- package/dist/src/agents/halt-signal.d.ts.map +1 -1
- package/dist/src/agents/halt-signal.js +33 -7
- package/dist/src/agents/halt-signal.js.map +1 -1
- package/dist/src/agents/managed-agent.d.ts.map +1 -1
- package/dist/src/agents/managed-agent.js +5 -2
- package/dist/src/agents/managed-agent.js.map +1 -1
- package/dist/src/agents/prompt-experiment.d.ts +3 -2
- package/dist/src/agents/prompt-experiment.d.ts.map +1 -1
- package/dist/src/agents/prompt-experiment.js +1 -1
- package/dist/src/agents/prompt-experiment.js.map +1 -1
- package/dist/src/agents/prompt-version-manager.d.ts +5 -2
- package/dist/src/agents/prompt-version-manager.d.ts.map +1 -1
- package/dist/src/agents/prompt-version-manager.js +26 -4
- package/dist/src/agents/prompt-version-manager.js.map +1 -1
- package/dist/src/agents/specialization-scorer.d.ts.map +1 -1
- package/dist/src/agents/specialization-scorer.js +17 -9
- package/dist/src/agents/specialization-scorer.js.map +1 -1
- package/dist/src/agents/trigger-scanner.d.ts +5 -3
- package/dist/src/agents/trigger-scanner.d.ts.map +1 -1
- package/dist/src/agents/trigger-scanner.js +58 -10
- package/dist/src/agents/trigger-scanner.js.map +1 -1
- package/dist/src/agents/version-store.d.ts +0 -1
- package/dist/src/agents/version-store.d.ts.map +1 -1
- package/dist/src/agents/version-store.js +44 -21
- package/dist/src/agents/version-store.js.map +1 -1
- package/dist/src/autopilot-state.d.ts.map +1 -1
- package/dist/src/autopilot-state.js +79 -28
- package/dist/src/autopilot-state.js.map +1 -1
- package/dist/src/benchmarks/benchmark-runner.d.ts +7 -2
- package/dist/src/benchmarks/benchmark-runner.d.ts.map +1 -1
- package/dist/src/benchmarks/benchmark-runner.js +20 -8
- package/dist/src/benchmarks/benchmark-runner.js.map +1 -1
- package/dist/src/benchmarks/metric-evaluators.d.ts +2 -1
- package/dist/src/benchmarks/metric-evaluators.d.ts.map +1 -1
- package/dist/src/benchmarks/metric-evaluators.js +25 -2
- package/dist/src/benchmarks/metric-evaluators.js.map +1 -1
- package/dist/src/commands/agent.d.ts.map +1 -1
- package/dist/src/commands/agent.js +6 -4
- package/dist/src/commands/agent.js.map +1 -1
- package/dist/src/commands/appliance-advanced.d.ts.map +1 -1
- package/dist/src/commands/appliance-advanced.js +23 -0
- package/dist/src/commands/appliance-advanced.js.map +1 -1
- package/dist/src/commands/autopilot.d.ts.map +1 -1
- package/dist/src/commands/autopilot.js +3 -3
- package/dist/src/commands/autopilot.js.map +1 -1
- package/dist/src/commands/benchmark.d.ts.map +1 -1
- package/dist/src/commands/benchmark.js +119 -8
- package/dist/src/commands/benchmark.js.map +1 -1
- package/dist/src/commands/claims.d.ts.map +1 -1
- package/dist/src/commands/claims.js +22 -14
- package/dist/src/commands/claims.js.map +1 -1
- package/dist/src/commands/config.d.ts.map +1 -1
- package/dist/src/commands/config.js +32 -0
- package/dist/src/commands/config.js.map +1 -1
- package/dist/src/commands/daemon.d.ts.map +1 -1
- package/dist/src/commands/daemon.js +13 -11
- package/dist/src/commands/daemon.js.map +1 -1
- package/dist/src/commands/deployment.d.ts.map +1 -1
- package/dist/src/commands/deployment.js +21 -2
- package/dist/src/commands/deployment.js.map +1 -1
- package/dist/src/commands/doctor.d.ts.map +1 -1
- package/dist/src/commands/doctor.js +28 -62
- package/dist/src/commands/doctor.js.map +1 -1
- package/dist/src/commands/embeddings.d.ts.map +1 -1
- package/dist/src/commands/embeddings.js +124 -48
- package/dist/src/commands/embeddings.js.map +1 -1
- package/dist/src/commands/hive-mind.d.ts.map +1 -1
- package/dist/src/commands/hive-mind.js +15 -14
- package/dist/src/commands/hive-mind.js.map +1 -1
- package/dist/src/commands/hooks.d.ts.map +1 -1
- package/dist/src/commands/hooks.js +45 -41
- package/dist/src/commands/hooks.js.map +1 -1
- package/dist/src/commands/index.d.ts +2 -0
- package/dist/src/commands/index.d.ts.map +1 -1
- package/dist/src/commands/index.js +20 -7
- package/dist/src/commands/index.js.map +1 -1
- package/dist/src/commands/init.d.ts.map +1 -1
- package/dist/src/commands/init.js +53 -19
- package/dist/src/commands/init.js.map +1 -1
- package/dist/src/commands/mcp.d.ts.map +1 -1
- package/dist/src/commands/mcp.js +31 -44
- package/dist/src/commands/mcp.js.map +1 -1
- package/dist/src/commands/memory.d.ts.map +1 -1
- package/dist/src/commands/memory.js +47 -15
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/commands/migrate.d.ts.map +1 -1
- package/dist/src/commands/migrate.js +156 -108
- package/dist/src/commands/migrate.js.map +1 -1
- package/dist/src/commands/monograph.d.ts +8 -0
- package/dist/src/commands/monograph.d.ts.map +1 -0
- package/dist/src/commands/monograph.js +526 -0
- package/dist/src/commands/monograph.js.map +1 -0
- package/dist/src/commands/neural.d.ts.map +1 -1
- package/dist/src/commands/neural.js +96 -56
- package/dist/src/commands/neural.js.map +1 -1
- package/dist/src/commands/performance.d.ts.map +1 -1
- package/dist/src/commands/performance.js +30 -8
- package/dist/src/commands/performance.js.map +1 -1
- package/dist/src/commands/plugins.d.ts.map +1 -1
- package/dist/src/commands/plugins.js +13 -37
- package/dist/src/commands/plugins.js.map +1 -1
- package/dist/src/commands/process.d.ts.map +1 -1
- package/dist/src/commands/process.js +25 -2
- package/dist/src/commands/process.js.map +1 -1
- package/dist/src/commands/providers.d.ts.map +1 -1
- package/dist/src/commands/providers.js +37 -5
- package/dist/src/commands/providers.js.map +1 -1
- package/dist/src/commands/replay.js +4 -4
- package/dist/src/commands/replay.js.map +1 -1
- package/dist/src/commands/route.d.ts.map +1 -1
- package/dist/src/commands/route.js +37 -5
- package/dist/src/commands/route.js.map +1 -1
- package/dist/src/commands/ruvector/import.d.ts.map +1 -1
- package/dist/src/commands/ruvector/import.js +12 -2
- package/dist/src/commands/ruvector/import.js.map +1 -1
- package/dist/src/commands/ruvector/init.d.ts.map +1 -1
- package/dist/src/commands/ruvector/init.js +15 -0
- package/dist/src/commands/ruvector/init.js.map +1 -1
- package/dist/src/commands/ruvector/status.d.ts.map +1 -1
- package/dist/src/commands/ruvector/status.js +16 -3
- package/dist/src/commands/ruvector/status.js.map +1 -1
- package/dist/src/commands/security.d.ts.map +1 -1
- package/dist/src/commands/security.js +342 -193
- package/dist/src/commands/security.js.map +1 -1
- package/dist/src/commands/session.d.ts.map +1 -1
- package/dist/src/commands/session.js +51 -8
- package/dist/src/commands/session.js.map +1 -1
- package/dist/src/commands/start.d.ts.map +1 -1
- package/dist/src/commands/start.js +18 -4
- package/dist/src/commands/start.js.map +1 -1
- package/dist/src/commands/swarm.d.ts.map +1 -1
- package/dist/src/commands/swarm.js +47 -36
- package/dist/src/commands/swarm.js.map +1 -1
- package/dist/src/commands/tokens.js +11 -11
- package/dist/src/commands/tokens.js.map +1 -1
- package/dist/src/commands/transfer-store.js +1 -1
- package/dist/src/commands/transfer-store.js.map +1 -1
- package/dist/src/commands/workflow.d.ts.map +1 -1
- package/dist/src/commands/workflow.js +31 -4
- package/dist/src/commands/workflow.js.map +1 -1
- package/dist/src/config-adapter.d.ts +2 -1
- package/dist/src/config-adapter.d.ts.map +1 -1
- package/dist/src/config-adapter.js.map +1 -1
- package/dist/src/consensus/audit-writer.d.ts.map +1 -1
- package/dist/src/consensus/audit-writer.js +46 -13
- package/dist/src/consensus/audit-writer.js.map +1 -1
- package/dist/src/consensus/vote-signer.d.ts +0 -3
- package/dist/src/consensus/vote-signer.d.ts.map +1 -1
- package/dist/src/consensus/vote-signer.js +9 -1
- package/dist/src/consensus/vote-signer.js.map +1 -1
- package/dist/src/dlq/dlq-reader.d.ts +4 -2
- package/dist/src/dlq/dlq-reader.d.ts.map +1 -1
- package/dist/src/dlq/dlq-reader.js +25 -8
- package/dist/src/dlq/dlq-reader.js.map +1 -1
- package/dist/src/dlq/dlq-replayer.d.ts +10 -3
- package/dist/src/dlq/dlq-replayer.d.ts.map +1 -1
- package/dist/src/dlq/dlq-replayer.js +50 -16
- package/dist/src/dlq/dlq-replayer.js.map +1 -1
- package/dist/src/dlq/dlq-writer.d.ts.map +1 -1
- package/dist/src/dlq/dlq-writer.js +27 -5
- package/dist/src/dlq/dlq-writer.js.map +1 -1
- package/dist/src/eval/dataset-manager.d.ts +2 -2
- package/dist/src/eval/dataset-manager.d.ts.map +1 -1
- package/dist/src/eval/dataset-manager.js +26 -16
- package/dist/src/eval/dataset-manager.js.map +1 -1
- package/dist/src/eval/trace-collector.d.ts.map +1 -1
- package/dist/src/eval/trace-collector.js +23 -3
- package/dist/src/eval/trace-collector.js.map +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +12 -10
- package/dist/src/index.js.map +1 -1
- package/dist/src/init/claudemd-generator.js +8 -8
- package/dist/src/init/claudemd-generator.js.map +1 -1
- package/dist/src/init/executor.d.ts.map +1 -1
- package/dist/src/init/executor.js +163 -137
- package/dist/src/init/executor.js.map +1 -1
- package/dist/src/init/helpers-generator.d.ts.map +1 -1
- package/dist/src/init/helpers-generator.js +49 -36
- package/dist/src/init/helpers-generator.js.map +1 -1
- package/dist/src/init/mcp-generator.js +3 -3
- package/dist/src/init/mcp-generator.js.map +1 -1
- package/dist/src/init/settings-generator.d.ts.map +1 -1
- package/dist/src/init/settings-generator.js +10 -3
- package/dist/src/init/settings-generator.js.map +1 -1
- package/dist/src/init/shared-instructions-generator.d.ts.map +1 -1
- package/dist/src/init/shared-instructions-generator.js +18 -3
- package/dist/src/init/shared-instructions-generator.js.map +1 -1
- package/dist/src/init/statusline-generator.d.ts.map +1 -1
- package/dist/src/init/statusline-generator.js +3 -1
- package/dist/src/init/statusline-generator.js.map +1 -1
- package/dist/src/init/types.d.ts +35 -11
- package/dist/src/init/types.d.ts.map +1 -1
- package/dist/src/init/types.js +5 -9
- package/dist/src/init/types.js.map +1 -1
- package/dist/src/interactive/interrupt.d.ts.map +1 -1
- package/dist/src/interactive/interrupt.js +8 -3
- package/dist/src/interactive/interrupt.js.map +1 -1
- package/dist/src/mcp/tool-registry.d.ts.map +1 -1
- package/dist/src/mcp/tool-registry.js +38 -4
- package/dist/src/mcp/tool-registry.js.map +1 -1
- package/dist/src/mcp-client.d.ts.map +1 -1
- package/dist/src/mcp-client.js +15 -6
- package/dist/src/mcp-client.js.map +1 -1
- package/dist/src/mcp-server.d.ts +9 -2
- package/dist/src/mcp-server.d.ts.map +1 -1
- package/dist/src/mcp-server.js +182 -35
- package/dist/src/mcp-server.js.map +1 -1
- package/dist/src/mcp-tools/agent-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/agent-tools.js +66 -34
- package/dist/src/mcp-tools/agent-tools.js.map +1 -1
- package/dist/src/mcp-tools/agentdb-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/agentdb-tools.js +34 -7
- package/dist/src/mcp-tools/agentdb-tools.js.map +1 -1
- package/dist/src/mcp-tools/analyze-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/analyze-tools.js +25 -16
- package/dist/src/mcp-tools/analyze-tools.js.map +1 -1
- package/dist/src/mcp-tools/auto-install.d.ts.map +1 -1
- package/dist/src/mcp-tools/auto-install.js +4 -6
- package/dist/src/mcp-tools/auto-install.js.map +1 -1
- package/dist/src/mcp-tools/autopilot-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/autopilot-tools.js +12 -2
- package/dist/src/mcp-tools/autopilot-tools.js.map +1 -1
- package/dist/src/mcp-tools/browser-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/browser-tools.js +199 -20
- package/dist/src/mcp-tools/browser-tools.js.map +1 -1
- package/dist/src/mcp-tools/claims-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/claims-tools.js +68 -18
- package/dist/src/mcp-tools/claims-tools.js.map +1 -1
- package/dist/src/mcp-tools/config-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/config-tools.js +33 -5
- package/dist/src/mcp-tools/config-tools.js.map +1 -1
- package/dist/src/mcp-tools/coordination-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/coordination-tools.js +59 -4
- package/dist/src/mcp-tools/coordination-tools.js.map +1 -1
- package/dist/src/mcp-tools/daa-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/daa-tools.js +46 -10
- package/dist/src/mcp-tools/daa-tools.js.map +1 -1
- package/dist/src/mcp-tools/embeddings-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/embeddings-tools.js +46 -5
- package/dist/src/mcp-tools/embeddings-tools.js.map +1 -1
- package/dist/src/mcp-tools/github-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/github-tools.js +29 -16
- package/dist/src/mcp-tools/github-tools.js.map +1 -1
- package/dist/src/mcp-tools/graphify-tools.d.ts +4 -67
- package/dist/src/mcp-tools/graphify-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/graphify-tools.js +40 -1250
- package/dist/src/mcp-tools/graphify-tools.js.map +1 -1
- package/dist/src/mcp-tools/guidance-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/guidance-tools.js +38 -10
- package/dist/src/mcp-tools/guidance-tools.js.map +1 -1
- package/dist/src/mcp-tools/hive-mind-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/hive-mind-tools.js +96 -33
- package/dist/src/mcp-tools/hive-mind-tools.js.map +1 -1
- package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/hooks-tools.js +70 -37
- package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
- package/dist/src/mcp-tools/index.d.ts +1 -0
- package/dist/src/mcp-tools/index.d.ts.map +1 -1
- package/dist/src/mcp-tools/index.js +1 -0
- package/dist/src/mcp-tools/index.js.map +1 -1
- package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/memory-tools.js +29 -13
- package/dist/src/mcp-tools/memory-tools.js.map +1 -1
- package/dist/src/mcp-tools/monograph-tools.d.ts +9 -0
- package/dist/src/mcp-tools/monograph-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/monograph-tools.js +6306 -0
- package/dist/src/mcp-tools/monograph-tools.js.map +1 -0
- package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/neural-tools.js +121 -37
- package/dist/src/mcp-tools/neural-tools.js.map +1 -1
- package/dist/src/mcp-tools/performance-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/performance-tools.js +21 -8
- package/dist/src/mcp-tools/performance-tools.js.map +1 -1
- package/dist/src/mcp-tools/progress-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/progress-tools.js +10 -8
- package/dist/src/mcp-tools/progress-tools.js.map +1 -1
- package/dist/src/mcp-tools/request-tracker.d.ts.map +1 -1
- package/dist/src/mcp-tools/request-tracker.js +4 -1
- package/dist/src/mcp-tools/request-tracker.js.map +1 -1
- package/dist/src/mcp-tools/ruvllm-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/ruvllm-tools.js +19 -8
- package/dist/src/mcp-tools/ruvllm-tools.js.map +1 -1
- package/dist/src/mcp-tools/session-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/session-tools.js +57 -17
- package/dist/src/mcp-tools/session-tools.js.map +1 -1
- package/dist/src/mcp-tools/swarm-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/swarm-tools.js +35 -17
- package/dist/src/mcp-tools/swarm-tools.js.map +1 -1
- package/dist/src/mcp-tools/system-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/system-tools.js +4 -3
- package/dist/src/mcp-tools/system-tools.js.map +1 -1
- package/dist/src/mcp-tools/task-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/task-tools.js +53 -13
- package/dist/src/mcp-tools/task-tools.js.map +1 -1
- package/dist/src/mcp-tools/terminal-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/terminal-tools.js +63 -14
- package/dist/src/mcp-tools/terminal-tools.js.map +1 -1
- package/dist/src/mcp-tools/transfer-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/transfer-tools.js +21 -16
- package/dist/src/mcp-tools/transfer-tools.js.map +1 -1
- package/dist/src/mcp-tools/workflow-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/workflow-tools.js +92 -23
- package/dist/src/mcp-tools/workflow-tools.js.map +1 -1
- package/dist/src/memory/ewc-consolidation.d.ts.map +1 -1
- package/dist/src/memory/ewc-consolidation.js +41 -10
- package/dist/src/memory/ewc-consolidation.js.map +1 -1
- package/dist/src/memory/intelligence.d.ts +2 -2
- package/dist/src/memory/intelligence.d.ts.map +1 -1
- package/dist/src/memory/intelligence.js +39 -13
- package/dist/src/memory/intelligence.js.map +1 -1
- package/dist/src/memory/memory-bridge.d.ts +1 -0
- package/dist/src/memory/memory-bridge.d.ts.map +1 -1
- package/dist/src/memory/memory-bridge.js +149 -56
- package/dist/src/memory/memory-bridge.js.map +1 -1
- package/dist/src/memory/memory-initializer.d.ts.map +1 -1
- package/dist/src/memory/memory-initializer.js +107 -45
- package/dist/src/memory/memory-initializer.js.map +1 -1
- package/dist/src/memory/sona-optimizer.d.ts +8 -1
- package/dist/src/memory/sona-optimizer.d.ts.map +1 -1
- package/dist/src/memory/sona-optimizer.js +25 -8
- package/dist/src/memory/sona-optimizer.js.map +1 -1
- package/dist/src/observability/replay-reader.d.ts +40 -0
- package/dist/src/observability/replay-reader.d.ts.map +1 -0
- package/dist/src/observability/replay-reader.js +138 -0
- package/dist/src/observability/replay-reader.js.map +1 -0
- package/dist/src/orchestration/routing-modes.d.ts.map +1 -1
- package/dist/src/orchestration/routing-modes.js +35 -5
- package/dist/src/orchestration/routing-modes.js.map +1 -1
- package/dist/src/parser.d.ts +8 -0
- package/dist/src/parser.d.ts.map +1 -1
- package/dist/src/parser.js +48 -14
- package/dist/src/parser.js.map +1 -1
- package/dist/src/plugins/manager.d.ts.map +1 -1
- package/dist/src/plugins/manager.js +112 -19
- package/dist/src/plugins/manager.js.map +1 -1
- package/dist/src/plugins/store/discovery.d.ts +1 -1
- package/dist/src/plugins/store/discovery.d.ts.map +1 -1
- package/dist/src/plugins/store/discovery.js +80 -62
- package/dist/src/plugins/store/discovery.js.map +1 -1
- package/dist/src/production/circuit-breaker.d.ts.map +1 -1
- package/dist/src/production/circuit-breaker.js +8 -1
- package/dist/src/production/circuit-breaker.js.map +1 -1
- package/dist/src/production/error-handler.d.ts +4 -2
- package/dist/src/production/error-handler.d.ts.map +1 -1
- package/dist/src/production/error-handler.js +27 -5
- package/dist/src/production/error-handler.js.map +1 -1
- package/dist/src/production/monitoring.d.ts.map +1 -1
- package/dist/src/production/monitoring.js +8 -4
- package/dist/src/production/monitoring.js.map +1 -1
- package/dist/src/production/rate-limiter.d.ts.map +1 -1
- package/dist/src/production/rate-limiter.js +30 -22
- package/dist/src/production/rate-limiter.js.map +1 -1
- package/dist/src/ruvector/agent-wasm.js +2 -2
- package/dist/src/ruvector/agent-wasm.js.map +1 -1
- package/dist/src/ruvector/coverage-router.d.ts.map +1 -1
- package/dist/src/ruvector/coverage-router.js +19 -9
- package/dist/src/ruvector/coverage-router.js.map +1 -1
- package/dist/src/ruvector/diff-classifier.d.ts +1 -0
- package/dist/src/ruvector/diff-classifier.d.ts.map +1 -1
- package/dist/src/ruvector/diff-classifier.js +26 -6
- package/dist/src/ruvector/diff-classifier.js.map +1 -1
- package/dist/src/ruvector/enhanced-model-router.d.ts.map +1 -1
- package/dist/src/ruvector/enhanced-model-router.js +24 -2
- package/dist/src/ruvector/enhanced-model-router.js.map +1 -1
- package/dist/src/ruvector/index.d.ts +1 -2
- package/dist/src/ruvector/index.d.ts.map +1 -1
- package/dist/src/ruvector/index.js +2 -2
- package/dist/src/ruvector/index.js.map +1 -1
- package/dist/src/ruvector/model-router.d.ts +4 -2
- package/dist/src/ruvector/model-router.d.ts.map +1 -1
- package/dist/src/ruvector/model-router.js +30 -6
- package/dist/src/ruvector/model-router.js.map +1 -1
- package/dist/src/ruvector/moe-router.d.ts +7 -0
- package/dist/src/ruvector/moe-router.d.ts.map +1 -1
- package/dist/src/ruvector/moe-router.js +35 -12
- package/dist/src/ruvector/moe-router.js.map +1 -1
- package/dist/src/ruvector/q-learning-router.d.ts +7 -1
- package/dist/src/ruvector/q-learning-router.d.ts.map +1 -1
- package/dist/src/ruvector/q-learning-router.js +40 -9
- package/dist/src/ruvector/q-learning-router.js.map +1 -1
- package/dist/src/services/claim-service.d.ts +3 -1
- package/dist/src/services/claim-service.d.ts.map +1 -1
- package/dist/src/services/claim-service.js +33 -2
- package/dist/src/services/claim-service.js.map +1 -1
- package/dist/src/services/config-file-manager.d.ts +16 -2
- package/dist/src/services/config-file-manager.d.ts.map +1 -1
- package/dist/src/services/config-file-manager.js +105 -17
- package/dist/src/services/config-file-manager.js.map +1 -1
- package/dist/src/services/container-worker-pool.d.ts.map +1 -1
- package/dist/src/services/container-worker-pool.js +51 -11
- package/dist/src/services/container-worker-pool.js.map +1 -1
- package/dist/src/services/headless-worker-executor.d.ts +7 -0
- package/dist/src/services/headless-worker-executor.d.ts.map +1 -1
- package/dist/src/services/headless-worker-executor.js +188 -45
- package/dist/src/services/headless-worker-executor.js.map +1 -1
- package/dist/src/services/registry-api.d.ts.map +1 -1
- package/dist/src/services/registry-api.js +62 -9
- package/dist/src/services/registry-api.js.map +1 -1
- package/dist/src/services/ruvector-training.d.ts.map +1 -1
- package/dist/src/services/ruvector-training.js +8 -0
- package/dist/src/services/ruvector-training.js.map +1 -1
- package/dist/src/services/worker-daemon.d.ts +4 -1
- package/dist/src/services/worker-daemon.d.ts.map +1 -1
- package/dist/src/services/worker-daemon.js +112 -28
- package/dist/src/services/worker-daemon.js.map +1 -1
- package/dist/src/services/worker-queue.d.ts +9 -2
- package/dist/src/services/worker-queue.d.ts.map +1 -1
- package/dist/src/services/worker-queue.js +86 -5
- package/dist/src/services/worker-queue.js.map +1 -1
- package/dist/src/suggest.d.ts.map +1 -1
- package/dist/src/suggest.js +9 -0
- package/dist/src/suggest.js.map +1 -1
- package/dist/src/swarm/flow-enforcer.d.ts +5 -3
- package/dist/src/swarm/flow-enforcer.d.ts.map +1 -1
- package/dist/src/swarm/flow-enforcer.js +17 -5
- package/dist/src/swarm/flow-enforcer.js.map +1 -1
- package/dist/src/swarm/flow-visualizer.d.ts +3 -0
- package/dist/src/swarm/flow-visualizer.d.ts.map +1 -1
- package/dist/src/swarm/flow-visualizer.js +30 -6
- package/dist/src/swarm/flow-visualizer.js.map +1 -1
- package/dist/src/transfer/anonymization/index.d.ts.map +1 -1
- package/dist/src/transfer/anonymization/index.js +5 -3
- package/dist/src/transfer/anonymization/index.js.map +1 -1
- package/dist/src/transfer/export.d.ts.map +1 -1
- package/dist/src/transfer/export.js +5 -3
- package/dist/src/transfer/export.js.map +1 -1
- package/dist/src/transfer/ipfs/client.d.ts.map +1 -1
- package/dist/src/transfer/ipfs/client.js +84 -7
- package/dist/src/transfer/ipfs/client.js.map +1 -1
- package/dist/src/transfer/ipfs/upload.d.ts.map +1 -1
- package/dist/src/transfer/ipfs/upload.js +13 -4
- package/dist/src/transfer/ipfs/upload.js.map +1 -1
- package/dist/src/transfer/storage/gcs.d.ts.map +1 -1
- package/dist/src/transfer/storage/gcs.js +19 -10
- package/dist/src/transfer/storage/gcs.js.map +1 -1
- package/dist/src/transfer/store/discovery.d.ts +9 -2
- package/dist/src/transfer/store/discovery.d.ts.map +1 -1
- package/dist/src/transfer/store/discovery.js +68 -13
- package/dist/src/transfer/store/discovery.js.map +1 -1
- package/dist/src/transfer/store/download.d.ts +15 -6
- package/dist/src/transfer/store/download.d.ts.map +1 -1
- package/dist/src/transfer/store/download.js +113 -24
- package/dist/src/transfer/store/download.js.map +1 -1
- package/dist/src/transfer/store/publish.d.ts +1 -1
- package/dist/src/transfer/store/publish.d.ts.map +1 -1
- package/dist/src/transfer/store/publish.js +13 -14
- package/dist/src/transfer/store/publish.js.map +1 -1
- package/dist/src/transfer/store/registry.d.ts +3 -3
- package/dist/src/transfer/store/registry.d.ts.map +1 -1
- package/dist/src/transfer/store/registry.js +32 -16
- package/dist/src/transfer/store/registry.js.map +1 -1
- package/dist/src/ui/.monomind/sessions/current.json +2 -2
- package/dist/src/ui/dashboard.html +2507 -187
- package/dist/src/ui/server.mjs +1343 -153
- package/dist/src/update/checker.d.ts.map +1 -1
- package/dist/src/update/checker.js +17 -4
- package/dist/src/update/checker.js.map +1 -1
- package/dist/src/update/executor.d.ts.map +1 -1
- package/dist/src/update/executor.js +25 -20
- package/dist/src/update/executor.js.map +1 -1
- package/dist/src/update/rate-limiter.d.ts +11 -0
- package/dist/src/update/rate-limiter.d.ts.map +1 -1
- package/dist/src/update/rate-limiter.js +23 -3
- package/dist/src/update/rate-limiter.js.map +1 -1
- package/dist/src/utils/parse-jsonl.d.ts +6 -0
- package/dist/src/utils/parse-jsonl.d.ts.map +1 -0
- package/dist/src/utils/parse-jsonl.js +22 -0
- package/dist/src/utils/parse-jsonl.js.map +1 -0
- package/dist/src/workflow/condition-evaluator.d.ts.map +1 -1
- package/dist/src/workflow/condition-evaluator.js +37 -3
- package/dist/src/workflow/condition-evaluator.js.map +1 -1
- package/dist/src/workflow/dag-builder.d.ts.map +1 -1
- package/dist/src/workflow/dag-builder.js +27 -11
- package/dist/src/workflow/dag-builder.js.map +1 -1
- package/dist/src/workflow/dag-executor.d.ts.map +1 -1
- package/dist/src/workflow/dag-executor.js +51 -13
- package/dist/src/workflow/dag-executor.js.map +1 -1
- package/dist/src/workflow/dsl-schema.d.ts +3 -0
- package/dist/src/workflow/dsl-schema.d.ts.map +1 -1
- package/dist/src/workflow/dsl-schema.js +6 -2
- package/dist/src/workflow/dsl-schema.js.map +1 -1
- package/dist/src/workflow/template-engine.js +7 -0
- package/dist/src/workflow/template-engine.js.map +1 -1
- package/dist/src/workflow/workflow-executor.d.ts.map +1 -1
- package/dist/src/workflow/workflow-executor.js +95 -14
- package/dist/src/workflow/workflow-executor.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -2
- package/.claude/agents/design/design-brand-guardian.md +0 -323
- package/.claude/agents/design/design-image-prompt-engineer.md +0 -237
- package/.claude/agents/design/design-inclusive-visuals-specialist.md +0 -72
- package/.claude/agents/design/design-ui-designer.md +0 -384
- package/.claude/agents/design/design-ux-architect.md +0 -470
- package/.claude/agents/design/design-ux-researcher.md +0 -330
- package/.claude/agents/design/design-visual-storyteller.md +0 -150
- package/.claude/agents/design/design-whimsy-injector.md +0 -439
- package/.claude/agents/v3/integration-architect.md +0 -338
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
- package/.claude/commands/coordination/init.md +0 -44
- package/.claude/commands/coordination/orchestrate.md +0 -43
- package/.claude/commands/coordination/spawn.md +0 -45
- package/.claude/commands/github/code-review-swarm.md +0 -550
- package/.claude/commands/github/code-review.md +0 -25
- package/.claude/commands/github/github-swarm.md +0 -121
- package/.claude/commands/github/issue-triage.md +0 -25
- package/.claude/commands/github/multi-repo-swarm.md +0 -519
- package/.claude/commands/github/pr-enhance.md +0 -26
- package/.claude/commands/github/project-board-sync.md +0 -471
- package/.claude/commands/github/release-swarm.md +0 -590
- package/.claude/commands/github/repo-analyze.md +0 -25
- package/.claude/commands/github/swarm-issue.md +0 -482
- package/.claude/commands/github/swarm-pr.md +0 -310
- package/.claude/commands/github/workflow-automation.md +0 -468
- package/.claude/commands/hive-mind/hive-mind-metrics.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-resume.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-sessions.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-wizard.md +0 -8
- package/.claude/commands/list-agents.md +0 -17
- package/.claude/commands/memory/memory-persist.md +0 -25
- package/.claude/commands/memory/memory-usage.md +0 -25
- package/.claude/commands/memory/neural.md +0 -47
- package/.claude/commands/metrics.md +0 -11
- package/.claude/commands/monitoring/real-time-view.md +0 -25
- package/.claude/commands/monitoring/swarm-monitor.md +0 -25
- package/.claude/commands/monomind-createtask.md +0 -302
- package/.claude/commands/monomind-help.md +0 -103
- package/.claude/commands/monomind-memory.md +0 -107
- package/.claude/commands/monomind-repeat.md +0 -149
- package/.claude/commands/monomind-swarm.md +0 -205
- package/.claude/commands/optimization/cache-manage.md +0 -25
- package/.claude/commands/optimization/topology-optimize.md +0 -25
- package/.claude/commands/pair/commands.md +0 -546
- package/.claude/commands/pair/config.md +0 -510
- package/.claude/commands/pair/start.md +0 -209
- package/.claude/commands/use-agent.md +0 -67
- package/.claude/skills/monomind-createtask/SKILL.md +0 -269
- package/.claude/skills/monomind-task-engine/SKILL.md +0 -358
- /package/.claude/agents/{v3 → specialists}/memory-specialist.md +0 -0
- /package/.claude/agents/{v3 → specialists}/performance-engineer.md +0 -0
- /package/.claude/agents/{v3 → specialists}/queen-coordinator.md +0 -0
- /package/.claude/agents/{v3 → specialists}/security-architect.md +0 -0
|
@@ -0,0 +1,743 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: mastermind:techport
|
|
3
|
+
description: Tech Port — deep-analyzes a foreign project, reviews the current monomind target to avoid conflicts and duplication, produces a scored port plan with mono-branded naming, and executes approved ports with full brand normalization.
|
|
4
|
+
type: domain-skill
|
|
5
|
+
default_mode: confirm
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Mastermind TechPort
|
|
9
|
+
|
|
10
|
+
Five-phase porting skill. Phases 0–1 run in parallel. Phase 2 builds the gap matrix. Phase 3 produces the port plan and is the confirm gate (STOP — wait for user approval). Phase 4 is pre-execution setup (snapshot + secrets check). Phase 5 executes with full mono branding normalization.
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## Standalone Execution
|
|
15
|
+
|
|
16
|
+
If invoked directly (not by `mastermind:master`):
|
|
17
|
+
1. Load brain context following `_protocol.md` Brain Load Procedure (namespace: `techport`)
|
|
18
|
+
2. Parse `source_path`, `focus_hint`, `mode` from user input
|
|
19
|
+
3. Proceed with Phase 0 below
|
|
20
|
+
4. At the end of every run — regardless of which phase concluded — execute `_protocol.md` Brain Write Procedure, writing output to namespace `mastermind:techport:raw`. This includes Phase 1A license-gate STOPs and secrets STOPs. Never skip Brain Write.
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## Inputs
|
|
25
|
+
|
|
26
|
+
- `source_path`: absolute or relative path to the foreign project root
|
|
27
|
+
- `focus_hint`: optional — what to look for ("CLI commands", "animation", "hooks", "skills"); default: `"core architecture skills commands hooks agents"`
|
|
28
|
+
- `mode`: confirm | auto
|
|
29
|
+
- `partial`: boolean — if true, skip strategy (a) Copy-As-Is; force (b) Adapt or (c) Extract only
|
|
30
|
+
- `source_brand`: derived in Phase 1A — PascalCase brand name of the source project (e.g. `RuvSwarm`, `ClaudeFlow`); used in all `rg -i "{source_brand}"` brand contamination checks
|
|
31
|
+
- `candidate_file`: derived during Phase 1E–1F — absolute path to a specific source file under analysis; substituted before running per-candidate coupling checks
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
## Phase 0 — Target (Monomind) Deep Review
|
|
36
|
+
|
|
37
|
+
**Run before looking at the source project.** This establishes what already exists, what naming conventions are enforced, and what architectural constraints must not be violated.
|
|
38
|
+
|
|
39
|
+
Steps 0B–0D run in parallel with Phase 1. Phase 0A runs first in sequence.
|
|
40
|
+
|
|
41
|
+
### 0A — Existing Capability Inventory
|
|
42
|
+
|
|
43
|
+
**Step 1 — check index freshness, rebuild only if stale (must complete before Step 2):**
|
|
44
|
+
```
|
|
45
|
+
Call mcp__monomind__monograph_health({})
|
|
46
|
+
IF health.commitsBehind > 0 OR health.status != "fresh":
|
|
47
|
+
Call mcp__monomind__monograph_build({ codeOnly: true })
|
|
48
|
+
// monograph_build runs in the background. Poll freshness by re-calling monograph_health
|
|
49
|
+
// every ~10s until health.status == "fresh" or health.commitsBehind == 0, then proceed to Step 2.
|
|
50
|
+
// If index is already fresh, skip monograph_build and proceed directly to Step 2
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
**Step 2 — query the fresh index (run after Step 1 completes):**
|
|
54
|
+
```
|
|
55
|
+
Call mcp__monomind__monograph_god_nodes({}) // load-bearing files — porting near them is dangerous
|
|
56
|
+
Call mcp__monomind__monograph_community({}) // module cluster structure — boundary map
|
|
57
|
+
Call mcp__monomind__monograph_bridge({}) // cross-community connectors — architectural seams
|
|
58
|
+
Call mcp__monomind__monograph_stats({}) // fan-in/out percentile distribution
|
|
59
|
+
Call mcp__monomind__monograph_query({ query: focus_hint OR "core architecture skills commands hooks agents" })
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
Also search for existing equivalents of anything the focus_hint mentions:
|
|
63
|
+
```bash
|
|
64
|
+
# Find existing skills, commands, agents that might overlap
|
|
65
|
+
# LLM substitutes {focus_hint} before running; if focus_hint is empty, use the fallback terms below
|
|
66
|
+
HINT_TERMS="{focus_hint}"
|
|
67
|
+
# If HINT_TERMS is empty or unset (no focus_hint provided), default to: core architecture skills commands hooks agents
|
|
68
|
+
[ -z "$HINT_TERMS" ] && HINT_TERMS="core architecture skills commands hooks agents"
|
|
69
|
+
HINT_PATTERN=$(echo "$HINT_TERMS" | tr ' ' '|')
|
|
70
|
+
find /Users/morteza/Desktop/tools/monobrain/.claude -name "*.md" \
|
|
71
|
+
| xargs grep -liE "$HINT_PATTERN" 2>/dev/null | head -20
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
**Deliverable:** a list of existing capabilities that any ported item must be checked against.
|
|
75
|
+
|
|
76
|
+
### 0B — Naming Convention Extraction (from actual monomind code)
|
|
77
|
+
|
|
78
|
+
Extract the real conventions — not the stated ones — from the codebase itself:
|
|
79
|
+
|
|
80
|
+
```bash
|
|
81
|
+
BASE=/Users/morteza/Desktop/tools/monobrain/packages/@monomind/cli/src
|
|
82
|
+
|
|
83
|
+
# File name convention
|
|
84
|
+
find "$BASE" -name "*.ts" | grep -v dist | sed 's|.*/||' | \
|
|
85
|
+
python3 -c "import sys,re; names=[l.strip() for l in sys.stdin]; \
|
|
86
|
+
camel=sum(1 for n in names if re.match(r'[a-z][a-zA-Z]+\.ts',n)); \
|
|
87
|
+
kebab=sum(1 for n in names if '-' in n); snake=sum(1 for n in names if '_' in n); \
|
|
88
|
+
print(f'kebab={kebab} camelCase={camel} snake={snake}')"
|
|
89
|
+
|
|
90
|
+
# Class/interface name convention
|
|
91
|
+
grep -rhn "^export class\|^export interface\|^export abstract class" "$BASE" \
|
|
92
|
+
| grep -oE "(class|interface) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | sort | uniq | head -60
|
|
93
|
+
|
|
94
|
+
# Suffix patterns (what suffixes dominate)
|
|
95
|
+
grep -rhn "^export" "$BASE" --include="*.ts" \
|
|
96
|
+
| grep -oE "(class|interface|function|const|type|enum) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | \
|
|
97
|
+
python3 -c "import sys,re; words=[l.strip() for l in sys.stdin]; \
|
|
98
|
+
from collections import Counter; \
|
|
99
|
+
suffixes=[re.findall('[A-Z][a-z]+$',w)[0] for w in words if re.findall('[A-Z][a-z]+$',w)]; \
|
|
100
|
+
[print(n,s) for s,n in Counter(suffixes).most_common(15)]"
|
|
101
|
+
|
|
102
|
+
# Domain vocabulary (nouns appearing in 3+ exported names)
|
|
103
|
+
grep -rhn "^export" "$BASE" --include="*.ts" \
|
|
104
|
+
| grep -oE "(class|interface|function|const|type|enum) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | \
|
|
105
|
+
python3 -c "import sys,re; from collections import Counter; \
|
|
106
|
+
words=[]; \
|
|
107
|
+
[words.extend(re.findall('[A-Z][a-z]+', l.strip())) for l in sys.stdin]; \
|
|
108
|
+
[print(n,w) for w,n in Counter(words).most_common(20) if n >= 2]"
|
|
109
|
+
|
|
110
|
+
# Error hierarchy
|
|
111
|
+
grep -rn "extends.*Error\|class.*Error" "$BASE" --include="*.ts" | grep "^export\|export " | head -15
|
|
112
|
+
|
|
113
|
+
# Async model
|
|
114
|
+
echo "async/await count:" && grep -rn "async function\|async (" "$BASE" --include="*.ts" | wc -l
|
|
115
|
+
echo "Promise.then count:" && grep -rn "\.then(" "$BASE" --include="*.ts" | grep -v "//" | wc -l
|
|
116
|
+
|
|
117
|
+
# Dependency injection style
|
|
118
|
+
grep -rn "constructor(" "$BASE" --include="*.ts" | grep "private\|readonly\|protected" | head -10
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
**Deliverable: Monomind Naming Standard (MNS)** — output a concrete standard block:
|
|
122
|
+
|
|
123
|
+
```
|
|
124
|
+
MONOMIND NAMING STANDARD (extracted from codebase)
|
|
125
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
126
|
+
File names: kebab-case (e.g., agent-pool.ts, hook-handler.ts)
|
|
127
|
+
Class names: PascalCase with domain prefix (Agent*, Swarm*, Graph*, Hook*)
|
|
128
|
+
Interface names: PascalCase, no 'I' prefix (Config, Options, Result)
|
|
129
|
+
Skill names: mono<domain> prefix (monomotion, monograph, monodesign)
|
|
130
|
+
Function names: camelCase, no prefix
|
|
131
|
+
Config keys: camelCase
|
|
132
|
+
Env vars: MONOMIND_* (uppercase snake)
|
|
133
|
+
npm packages: @monomind/<name>
|
|
134
|
+
CLI commands: monomind <command>
|
|
135
|
+
Error classes: Extend CLIError or domain error (e.g., GraphError extends CLIError)
|
|
136
|
+
Event names: domain:action kebab (e.g., 'agent:spawned', 'hook:fired')
|
|
137
|
+
Log prefixes: [MODULE_NAME] or [monomind]
|
|
138
|
+
Barrel files: index.ts per directory (all public exports must go through it)
|
|
139
|
+
Async model: async/await (no .then() chains, no callbacks)
|
|
140
|
+
DI style: Constructor injection, no DI container, no decorators
|
|
141
|
+
Domain vocab: Agent, Memory, Swarm, Config, Node, Graph, Session, Task, Worker, Hook, Plugin
|
|
142
|
+
```
|
|
143
|
+
|
|
144
|
+
### 0C — Dependency Direction Constraints
|
|
145
|
+
|
|
146
|
+
```bash
|
|
147
|
+
BASE=/Users/morteza/Desktop/tools/monobrain/packages/@monomind/cli/src
|
|
148
|
+
|
|
149
|
+
# Map import directions by directory layer
|
|
150
|
+
for dir in types utils core commands services; do
|
|
151
|
+
count=$(grep -rn "^import" "$BASE/$dir" --include="*.ts" 2>/dev/null | wc -l)
|
|
152
|
+
refs=$(grep -rn "from.*/$dir/" "$BASE" --include="*.ts" 2>/dev/null | wc -l)
|
|
153
|
+
echo "$dir: imports=$count | imported_by=$refs"
|
|
154
|
+
done
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
Extract the implied layering from the import ratio. High `imported_by` → leaf/utility layer (can be imported anywhere). Low `imported_by` → entry/command layer (should not be imported by core).
|
|
158
|
+
|
|
159
|
+
**Deliverable: Dependency Direction Map** — ported code must not violate this map.
|
|
160
|
+
|
|
161
|
+
### 0D — Build Monomind Vocabulary Name Set (for collision detection)
|
|
162
|
+
|
|
163
|
+
```bash
|
|
164
|
+
grep -rhn "^export" /Users/morteza/Desktop/tools/monobrain/packages/@monomind/cli/src \
|
|
165
|
+
--include="*.ts" | grep -v dist | \
|
|
166
|
+
grep -oE "(class|interface|function|const|type|enum) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | sort -u \
|
|
167
|
+
> /tmp/monomind_names.txt
|
|
168
|
+
echo "Monomind exported names: $(wc -l < /tmp/monomind_names.txt)"
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
---
|
|
172
|
+
|
|
173
|
+
## Phase 1 — Source Project Reconnaissance
|
|
174
|
+
|
|
175
|
+
Run in parallel with Phase 0.
|
|
176
|
+
|
|
177
|
+
### 1A — Identity, Tech Stack, and License (Gate)
|
|
178
|
+
|
|
179
|
+
```bash
|
|
180
|
+
cat "{source_path}/package.json" 2>/dev/null | head -40
|
|
181
|
+
cat "{source_path}/pyproject.toml" 2>/dev/null | head -20
|
|
182
|
+
head -5 "{source_path}/LICENSE" 2>/dev/null
|
|
183
|
+
head -80 "{source_path}/README.md" 2>/dev/null
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
**LICENSE GATE — evaluate before proceeding:**
|
|
187
|
+
- MIT / Apache-2.0 / BSD-2/3 / ISC / Unlicense → **proceed** (all strategies available)
|
|
188
|
+
- MPL-2.0 / LGPL → **proceed with restriction** (no Full Copy-As-Is; Adapt or Extract only; adapter boundary required)
|
|
189
|
+
- GPL-2.0 / GPL-3.0 / AGPL → **STOP** — Inspiration-Only; no code ported; tell user why; then execute Brain Write (status: blocked) before exiting
|
|
190
|
+
- Proprietary / No License → **STOP** — cannot port; tell user to get permission first; then execute Brain Write (status: blocked) before exiting
|
|
191
|
+
|
|
192
|
+
**BRAND EXTRACTION — required before Phase 2B collision detection:**
|
|
193
|
+
|
|
194
|
+
Extract `source_brand` from three signals, pick the most specific:
|
|
195
|
+
1. `package.json` `name` field: strip `@scope/` prefix, convert to PascalCase (e.g., `claude-flow` → `ClaudeFlow`, `ruv-swarm` → `RuvSwarm`)
|
|
196
|
+
2. README H1 title: extract the project name word(s) before any tagline
|
|
197
|
+
3. Class name prefixes: run `grep -rhn "^export class\|^export abstract class" "{source_path}/src" --include="*.ts" 2>/dev/null | grep -oE "(class) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | grep -oE "^[A-Z][a-z]+" | sort | uniq -c | sort -rn | head -5` — the most frequent leading word (e.g., `Ruv` from `RuvSwarm`, `Claude` from `ClaudeFlow`) is the brand prefix; convert to PascalCase compound if needed
|
|
198
|
+
|
|
199
|
+
Set `source_brand` to the PascalCase result (e.g., `RuvSwarm`, `ClaudeFlow`, `SourceProject`). This variable is used verbatim in all subsequent `rg -i "{source_brand}"` calls and the collision-detection Python script.
|
|
200
|
+
|
|
201
|
+
### 1B — Repo-Map (Structural Index)
|
|
202
|
+
|
|
203
|
+
```bash
|
|
204
|
+
# File tree
|
|
205
|
+
find "{source_path}" -maxdepth 4 \
|
|
206
|
+
\( -name node_modules -o -name .git -o -name dist -o -name build \
|
|
207
|
+
-o -name __pycache__ -o -name .cache -o -name coverage \) -prune \
|
|
208
|
+
-o -type f -print | grep -E '\.(ts|tsx|js|mjs|cjs|py|go|rs|java|cs)$' | head -300
|
|
209
|
+
|
|
210
|
+
# Exported symbols
|
|
211
|
+
grep -rhn "^export" "{source_path}/src" --include="*.ts" 2>/dev/null | \
|
|
212
|
+
grep -oE "(class|interface|function|const|type|enum) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | sort -u | head -150
|
|
213
|
+
|
|
214
|
+
# Import relationships
|
|
215
|
+
grep -rn "^import.*from" "{source_path}/src" --include="*.ts" 2>/dev/null | \
|
|
216
|
+
grep -v node_modules | head -80
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
### 1C — Dependency Graph and Circular Dependencies
|
|
220
|
+
|
|
221
|
+
```bash
|
|
222
|
+
command -v madge && madge "{source_path}/src" --circular --extensions ts,js --json 2>/dev/null
|
|
223
|
+
command -v lizard && lizard "{source_path}/src" --json 2>/dev/null | \
|
|
224
|
+
python3 -c "import sys,json; d=json.load(sys.stdin); fns=d.get('function_list',[]); \
|
|
225
|
+
print(f'Functions: {len(fns)}, CC>10: {len([f for f in fns if f[\"cyclomatic_complexity\"]>10])}, CC>30: {len([f for f in fns if f[\"cyclomatic_complexity\"]>30])}')" 2>/dev/null
|
|
226
|
+
if command -v jscpd &>/dev/null; then
|
|
227
|
+
jscpd "{source_path}/src" --reporters json --output /tmp/jscpd-report 2>/dev/null
|
|
228
|
+
python3 -c "
|
|
229
|
+
import json, os
|
|
230
|
+
report = '/tmp/jscpd-report/jscpd-report.json'
|
|
231
|
+
if os.path.exists(report):
|
|
232
|
+
d = json.load(open(report))
|
|
233
|
+
s = d.get('statistics', {})
|
|
234
|
+
print(f'Clone%: {s.get(\"percentage\", 0):.1f}%')
|
|
235
|
+
else:
|
|
236
|
+
print('Clone%: (jscpd report not found)')
|
|
237
|
+
" 2>/dev/null
|
|
238
|
+
fi
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
### 1D — Risk Signal Detection
|
|
242
|
+
|
|
243
|
+
```bash
|
|
244
|
+
src="{source_path}/src"
|
|
245
|
+
echo "Global state:" && grep -rn "^let \|^var " "$src" --include="*.ts" | grep -v "const\|test\|spec\|//" | wc -l
|
|
246
|
+
echo "Import side effects:" && grep -rn "^fetch(\|^axios\.\|^fs\.\|^process\.exit\|mongoose\.connect" "$src" --include="*.ts" | grep -v "test\|spec\|//" | head -5
|
|
247
|
+
echo "Prototype mutations:" && grep -rn "\.prototype\." "$src" --include="*.ts" | grep -v "test\|spec\|\.d\.ts" | wc -l
|
|
248
|
+
echo "Framework coupling:" && grep -rn "@Injectable\|@Module\|@Entity\|app\.use\|useEffect\|componentDidMount" "$src" --include="*.ts" | wc -l
|
|
249
|
+
echo "Env dependencies:" && grep -rn "process\.env\." "$src" --include="*.ts" | sed 's/.*process\.env\.\([A-Z_]*\).*/\1/' | sort -u
|
|
250
|
+
echo "Secrets scan:"
|
|
251
|
+
if command -v gitleaks &>/dev/null; then
|
|
252
|
+
gitleaks detect -s "{source_path}" --report-path /tmp/gl.json -q 2>/dev/null
|
|
253
|
+
gitleaks_exit=$?
|
|
254
|
+
python3 -c "
|
|
255
|
+
import json, os
|
|
256
|
+
if os.path.exists('/tmp/gl.json'):
|
|
257
|
+
d = json.load(open('/tmp/gl.json'))
|
|
258
|
+
print(f'Secrets found: {len(d)}')
|
|
259
|
+
if d:
|
|
260
|
+
files = sorted({e.get('File','?') for e in d})
|
|
261
|
+
print('Affected files (exclude from port plan):')
|
|
262
|
+
for f in files: print(f' {f}')
|
|
263
|
+
else:
|
|
264
|
+
print('Secrets found: unknown (report missing)')
|
|
265
|
+
" 2>/dev/null
|
|
266
|
+
if [ $gitleaks_exit -eq 1 ]; then
|
|
267
|
+
echo "WARNING: files listed above must appear in SKIPPED section of Phase 3 plan — do not include in any port candidate"
|
|
268
|
+
elif [ $gitleaks_exit -ge 2 ]; then
|
|
269
|
+
echo "WARNING: gitleaks scan failed (exit $gitleaks_exit) — secrets scan incomplete, proceed with caution"
|
|
270
|
+
fi
|
|
271
|
+
else
|
|
272
|
+
echo "(gitleaks not installed — skip secrets scan)"
|
|
273
|
+
fi
|
|
274
|
+
```
|
|
275
|
+
|
|
276
|
+
**Risk Score = (circularDeps × 3) + (globalState × 2) + (importSideEffects × 4) + (frameworkCoupling ÷ 10) + (prototypeMutations × 3)**
|
|
277
|
+
- < 5: Low | 5–15: Medium | 15–30: High | > 30: Critical (do not port directly)
|
|
278
|
+
|
|
279
|
+
### 1E — Feature Surface Discovery
|
|
280
|
+
|
|
281
|
+
```bash
|
|
282
|
+
find "{source_path}" -name "SKILL.md" | grep -v node_modules
|
|
283
|
+
find "{source_path}" -path "*/.claude/commands*" -name "*.md" | grep -v node_modules
|
|
284
|
+
find "{source_path}/src" -type d -name "commands" -o -type d -name "cmd" 2>/dev/null | head -10
|
|
285
|
+
find "{source_path}/src" -name "*.tsx" -o -name "*.vue" 2>/dev/null | grep -v node_modules | grep -v test | head -30
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
### 1F — Dependency Graph Analysis of Source Project
|
|
289
|
+
|
|
290
|
+
`monograph_build` only indexes the current monomind workspace and cannot analyze an external project. Use filesystem tooling instead:
|
|
291
|
+
|
|
292
|
+
```bash
|
|
293
|
+
src="{source_path}"
|
|
294
|
+
|
|
295
|
+
# Fan-out per file (how many imports each file has)
|
|
296
|
+
find "$src" -name "*.ts" ! -path "*/node_modules/*" ! -path "*/dist/*" | while read f; do
|
|
297
|
+
count=$(grep -c "^import" "$f" 2>/dev/null); count=${count:-0}
|
|
298
|
+
echo "$count $f"
|
|
299
|
+
done | sort -rn | head -20
|
|
300
|
+
|
|
301
|
+
# Fan-in per file (how many other files import it — proxy for criticality)
|
|
302
|
+
find "$src" -name "*.ts" ! -path "*/node_modules/*" ! -path "*/dist/*" | while read f; do
|
|
303
|
+
base=$(basename "$f" .ts)
|
|
304
|
+
count=$(rg -l "from ['\"].*/${base}['\"]" "$src" --glob "*.ts" 2>/dev/null | grep -v "$f" | wc -l); count=${count:-0}
|
|
305
|
+
echo "$count $f"
|
|
306
|
+
done | sort -rn | head -20
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
For each feature candidate from 1E, measure coupling manually:
|
|
310
|
+
|
|
311
|
+
```bash
|
|
312
|
+
candidate="{candidate_file}"
|
|
313
|
+
echo "=== Fan-out (imports):"
|
|
314
|
+
grep "^import" "$candidate" | wc -l
|
|
315
|
+
echo "=== Fan-in (imported by):"
|
|
316
|
+
grep -rl "from.*$(basename "$candidate" .ts)" "{source_path}/src" --include="*.ts" 2>/dev/null | grep -v "$candidate" | wc -l
|
|
317
|
+
echo "=== Circular dep check (if madge available):"
|
|
318
|
+
command -v madge && madge "$candidate" --circular --extensions ts,js 2>/dev/null || echo "(madge not installed — skip)"
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
**High fan-in (>5) + circular deps = high coupling risk → prefer strategy (c) or (d).**
|
|
322
|
+
|
|
323
|
+
### 1G — Maintenance Activity
|
|
324
|
+
|
|
325
|
+
```bash
|
|
326
|
+
git -C "{source_path}" log --oneline --since="90 days ago" | wc -l
|
|
327
|
+
git -C "{source_path}" log --format='%ae' | sort | uniq -c | sort -rn | head -5
|
|
328
|
+
```
|
|
329
|
+
|
|
330
|
+
---
|
|
331
|
+
|
|
332
|
+
## Phase 2 — Gap Matrix and Collision Analysis
|
|
333
|
+
|
|
334
|
+
Combine Phase 0 and Phase 1 findings.
|
|
335
|
+
|
|
336
|
+
### 2A — Capability Gap Matrix
|
|
337
|
+
|
|
338
|
+
```
|
|
339
|
+
| Capability | Source Has | Monomind Has | Delta | Monograph Match |
|
|
340
|
+
|---------------|-----------|--------------|--------------|-----------------|
|
|
341
|
+
| <feature> | ✓ | ✗ | NEW | none |
|
|
342
|
+
| <feature> | ✓ better | ✓ basic | UPGRADE | <file>:<line> |
|
|
343
|
+
| <feature> | ✓ | ✓ equivalent | SKIP | <file>:<line> |
|
|
344
|
+
```
|
|
345
|
+
|
|
346
|
+
For every "NEW" or "UPGRADE" row, call:
|
|
347
|
+
```
|
|
348
|
+
mcp__monomind__monograph_query({ query: "<feature domain terms>" })
|
|
349
|
+
```
|
|
350
|
+
If it returns results → mark as UPGRADE candidate (something similar exists). If empty → mark as NEW.
|
|
351
|
+
|
|
352
|
+
### 2B — Collision Detection
|
|
353
|
+
|
|
354
|
+
Build the source's post-rename name set and diff against monomind's names:
|
|
355
|
+
|
|
356
|
+
```bash
|
|
357
|
+
# What source names WOULD become after mono-branding (rough pass)
|
|
358
|
+
grep -rhn "^export" "{source_path}/src" --include="*.ts" 2>/dev/null | \
|
|
359
|
+
grep -oE "(class|interface|function|const|type|enum) [A-Z][A-Za-z0-9]+" | awk '{print $2}' | \
|
|
360
|
+
python3 -c "
|
|
361
|
+
import sys, re
|
|
362
|
+
source_brand = '{source_brand}' # LLM substitutes the PascalCase value from Phase 1A before running (e.g. 'RuvSwarm', 'ClaudeFlow')
|
|
363
|
+
# Mono prefix: the domain prefix used in monomind for this context (e.g. 'Mono', 'Agent', 'Graph')
|
|
364
|
+
# LLM: substitute the actual mono prefix from Phase 0B's MNS before running
|
|
365
|
+
mono_prefix = '{mono_prefix}'
|
|
366
|
+
for line in sys.stdin:
|
|
367
|
+
name = line.strip()
|
|
368
|
+
# Strip source brand, then prepend mono prefix to form the intended monomind name
|
|
369
|
+
stripped = re.sub(source_brand, '', name, flags=re.IGNORECASE)
|
|
370
|
+
branded = mono_prefix + stripped if stripped else mono_prefix + name
|
|
371
|
+
print(branded)
|
|
372
|
+
" | sort -u > /tmp/source_renamed.txt
|
|
373
|
+
|
|
374
|
+
# Compare INTENDED monomind names against what already exists — real collision detection
|
|
375
|
+
comm -12 /tmp/monomind_names.txt /tmp/source_renamed.txt > /tmp/collisions.txt
|
|
376
|
+
echo "Collisions found: $(wc -l < /tmp/collisions.txt)"
|
|
377
|
+
cat /tmp/collisions.txt
|
|
378
|
+
```
|
|
379
|
+
|
|
380
|
+
**Collision resolution table:**
|
|
381
|
+
|
|
382
|
+
| Collision type | Resolution |
|
|
383
|
+
|---|---|
|
|
384
|
+
| Same name, same purpose | Do NOT port — use monomind's existing type |
|
|
385
|
+
| Same name, different purpose | Disambiguate: add domain suffix (e.g., `DatabaseSession` vs `AgentSession`) |
|
|
386
|
+
| Same name, superset/subset | Merge or extend the existing monomind interface |
|
|
387
|
+
| Same name, different module only | Namespace import: `import type { X as PortedX }` |
|
|
388
|
+
|
|
389
|
+
All collisions must be resolved before Phase 5 begins.
|
|
390
|
+
|
|
391
|
+
### 2C — Port Value Score (PVS) for Each Candidate
|
|
392
|
+
|
|
393
|
+
```
|
|
394
|
+
PVS = (FunctionalUniqueness × 2) // 0–5: absent from monomind = 5
|
|
395
|
+
+ TestCoverage // 0–5: ≥70% = 5, 40-69% = 3, <40% = 0
|
|
396
|
+
+ ModularityScore // 0–5: fan-out ≤ 2 = 5, >10 = 0
|
|
397
|
+
+ DocumentationQuality // 0–5: JSDoc + README + examples + zero FIXMEs + typed
|
|
398
|
+
+ LicenseScore // 5/3/0: see 1A gate
|
|
399
|
+
+ MaintenanceActivity // 0–5: >10 commits/90d = 5
|
|
400
|
+
- DebtPenalty // 0–5: high CC + low coverage
|
|
401
|
+
- BusFactor_Penalty // 0–2: bus_factor=1 = -2
|
|
402
|
+
```
|
|
403
|
+
|
|
404
|
+
**Port if PVS ≥ 24. Inspect if 12–23. Skip if < 12.**
|
|
405
|
+
|
|
406
|
+
### 2D — Strategy Selection (Decision Tree per Candidate)
|
|
407
|
+
|
|
408
|
+
```
|
|
409
|
+
1. License copyleft / proprietary? → (d) Inspiration-Only
|
|
410
|
+
2. Secrets found in source files for this module? → SKIP entirely
|
|
411
|
+
3. Fan-out > 15 OR circular deps involving it? → (c) Extract-Pattern or (d) Inspiration
|
|
412
|
+
4. Paradigm distance ≥ 3? → (c) Extract-Pattern
|
|
413
|
+
5. Framework coupling > 40%? → (b) Adapt-And-Port or (c) Extract-Pattern
|
|
414
|
+
6. `partial == false` AND CC < 15 AND fan-out ≤ 2 AND coverage ≥ 70%
|
|
415
|
+
AND LOC < 300 AND no global state? → (a) Copy-As-Is → then brand-normalize
|
|
416
|
+
(if `partial == true`: skip to step 7)
|
|
417
|
+
7. Default → (b) Adapt-And-Port
|
|
418
|
+
```
|
|
419
|
+
|
|
420
|
+
---
|
|
421
|
+
|
|
422
|
+
## Phase 3 — Port Plan Report
|
|
423
|
+
|
|
424
|
+
```
|
|
425
|
+
╔══════════════════════════════════════════════════════════════════╗
|
|
426
|
+
║ TECHPORT ANALYSIS: <source_path> ║
|
|
427
|
+
╚══════════════════════════════════════════════════════════════════╝
|
|
428
|
+
|
|
429
|
+
SOURCE PROJECT
|
|
430
|
+
Name: <name> → Will be referenced as: <mono-branded alias>
|
|
431
|
+
Stack: <languages, frameworks>
|
|
432
|
+
Size: <file count, LOC>
|
|
433
|
+
License: <license> (<port permission level>)
|
|
434
|
+
Activity: <commits/90d>, bus factor <N>
|
|
435
|
+
Summary: <2–3 sentences on what it does and its unique value>
|
|
436
|
+
|
|
437
|
+
RISK PROFILE
|
|
438
|
+
Global state: <N> | Import side effects: <N> | Circular deps: <N>
|
|
439
|
+
Framework coupling: <N%> | Risk Score: <N> → Low/Medium/High/Critical
|
|
440
|
+
|
|
441
|
+
MONOMIND CONSTRAINTS ACTIVE
|
|
442
|
+
Naming standard: kebab files, PascalCase domain-prefixed types, mono<domain> skills
|
|
443
|
+
Dependency direction: <extracted layer map>
|
|
444
|
+
Existing equivalents: <list of existing features that may overlap>
|
|
445
|
+
Name collisions found: <N> (resolved: <N>)
|
|
446
|
+
|
|
447
|
+
━━━ HIGH-VALUE PORT CANDIDATES (PVS ≥ 24) ━━━━━━━━━━━━━━━━━━━━━━━
|
|
448
|
+
|
|
449
|
+
🟢 [PVS: N | Risk: N] <Original Name> → <Mono-branded Name>
|
|
450
|
+
Strategy: (a) Copy-As-Is | (b) Adapt | (c) Extract-Pattern | (d) Inspiration
|
|
451
|
+
Source files: <source files involved>
|
|
452
|
+
Lands in: <target path in monomind>
|
|
453
|
+
Branded name: <what the type/skill/command/file will be called in monomind>
|
|
454
|
+
Value: <what capability gap it fills>
|
|
455
|
+
Conflicts: <naming or architectural conflicts, and how resolved>
|
|
456
|
+
Risk: <specific signals found>
|
|
457
|
+
Effort: trivial / hours / days
|
|
458
|
+
|
|
459
|
+
[repeat, ordered by PVS descending]
|
|
460
|
+
|
|
461
|
+
━━━ MEDIUM-VALUE CANDIDATES (PVS 12–23) — include by number ━━━━━
|
|
462
|
+
|
|
463
|
+
🟡 [N+1 | PVS: N | Risk: N] <Original Name> → <Mono-branded Name>
|
|
464
|
+
<one-line value + one-line concern>
|
|
465
|
+
(numbers continue from HIGH-VALUE list; user can include by saying "3" or "1 3 4")
|
|
466
|
+
|
|
467
|
+
━━━ SKIPPED (PVS < 12 / License / Secrets) ━━━━━━━━━━━━━━━━━━━━━━
|
|
468
|
+
|
|
469
|
+
🔴 <Name> — <reason>
|
|
470
|
+
|
|
471
|
+
━━━ COMPATIBILITY NOTES ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
472
|
+
|
|
473
|
+
Module system: <CJS/ESM match or conflict>
|
|
474
|
+
TypeScript: <strict mode match or conflict>
|
|
475
|
+
Async model: <match or must adapt>
|
|
476
|
+
Error model: <source error type → how it maps to monomind CLIError hierarchy>
|
|
477
|
+
Naming delta: <convention distance 0–3, what must change>
|
|
478
|
+
Dependencies: <shared deps at conflicting major versions>
|
|
479
|
+
|
|
480
|
+
━━━ RECOMMENDED PORT ORDER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
481
|
+
|
|
482
|
+
1. <Name> → <Mono name> — <why first>
|
|
483
|
+
2. <Name> → <Mono name>
|
|
484
|
+
...
|
|
485
|
+
|
|
486
|
+
══════════════════════════════════════════════════════════════════
|
|
487
|
+
Proceed? [yes / 1 3 / no]
|
|
488
|
+
```
|
|
489
|
+
|
|
490
|
+
**Confirm mode (default):** STOP HERE. Wait for explicit approval before Phase 4.
|
|
491
|
+
- `yes` → execute all HIGH-VALUE candidates (PVS ≥ 24) in the recommended order
|
|
492
|
+
- Numbers (e.g., `1 3`) → execute only those numbered candidates from the HIGH-VALUE list; Phase 5 iterates only those positions
|
|
493
|
+
- `no` → abort — print the skipped reasons, execute Brain Write (status: blocked), then exit
|
|
494
|
+
- Any medium-value candidate must be named explicitly by number to be included
|
|
495
|
+
|
|
496
|
+
**Auto mode:** proceed immediately with all HIGH-VALUE candidates.
|
|
497
|
+
|
|
498
|
+
---
|
|
499
|
+
|
|
500
|
+
## Phase 4 — Pre-Execution Setup
|
|
501
|
+
|
|
502
|
+
Before writing any code:
|
|
503
|
+
|
|
504
|
+
### 4A — Snapshot
|
|
505
|
+
|
|
506
|
+
Generate a timestamp and save it — reuse the exact same value in Phase 5's diff call:
|
|
507
|
+
```
|
|
508
|
+
SNAPSHOT_NAME = "pre-techport-" + new Date().toISOString().replace(/[:.]/g, '-').slice(0,19)
|
|
509
|
+
Call mcp__monomind__monograph_snapshot({ name: SNAPSHOT_NAME })
|
|
510
|
+
```
|
|
511
|
+
|
|
512
|
+
### 4B — Resolve All Collisions First
|
|
513
|
+
|
|
514
|
+
For each collision from Phase 2B, apply the resolution strategy before any file is written.
|
|
515
|
+
Document the final naming decisions:
|
|
516
|
+
|
|
517
|
+
```
|
|
518
|
+
NAMING DECISIONS
|
|
519
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
520
|
+
Source name → Monomind name Reason
|
|
521
|
+
─────────────────────────────────────────────────
|
|
522
|
+
SourceClass → MonoTargetThing new capability, no conflict
|
|
523
|
+
SourceConfig → GraphConfig (extend) extends existing monomind GraphConfig
|
|
524
|
+
SourceSession → PortedSession SessionAgent collision — disambiguate
|
|
525
|
+
...
|
|
526
|
+
```
|
|
527
|
+
|
|
528
|
+
### 4C — Brand Contamination Audit (Dry Run)
|
|
529
|
+
|
|
530
|
+
```bash
|
|
531
|
+
# Find ALL occurrences of source brand before touching anything
|
|
532
|
+
rg -i "{source_brand}" "{source_path}" --glob "!dist" --glob "!node_modules" --json | \
|
|
533
|
+
python3 -c "import sys,json; lines=[json.loads(l) for l in sys.stdin if l.strip()]; \
|
|
534
|
+
matches=[l for l in lines if l.get('type')=='match']; \
|
|
535
|
+
print(f'Brand occurrences to clean: {len(matches)}')"
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
Verify that any candidate whose source files appeared in the gitleaks report from Phase 1D is NOT in the approved list. (It should already be in SKIPPED in the Phase 3 plan — this is a safety double-check only. If somehow a secrets-contaminated file is in the approved list, STOP and tell the user before proceeding.)
|
|
539
|
+
|
|
540
|
+
---
|
|
541
|
+
|
|
542
|
+
## Phase 5 — Execution with Mono Branding Normalization
|
|
543
|
+
|
|
544
|
+
For each approved item, in recommended order.
|
|
545
|
+
|
|
546
|
+
### Branding Rules (apply to EVERY ported item)
|
|
547
|
+
|
|
548
|
+
**Naming conventions — enforce exactly:**
|
|
549
|
+
|
|
550
|
+
| Element | Convention | Example |
|
|
551
|
+
|---------|-----------|---------|
|
|
552
|
+
| File names | kebab-case | `agent-pool.ts`, `hook-handler.ts` |
|
|
553
|
+
| Class / abstract class | PascalCase, domain prefix | `GraphNode`, `SwarmCoordinator`, `HookHandler` |
|
|
554
|
+
| Interfaces | PascalCase, no `I` prefix | `AgentConfig`, `PortedResult` |
|
|
555
|
+
| Skills (SKILL.md) | `mono<domain>` prefix | `monomotion`, `monograph`, `monodesign` |
|
|
556
|
+
| Exported functions | camelCase, no prefix | `buildGraph()`, `resolveAgent()` |
|
|
557
|
+
| Config keys | camelCase | `projectRoot`, `maxAgents` |
|
|
558
|
+
| Env vars | `MONOMIND_*` uppercase | `MONOMIND_PORT`, `MONOMIND_LOG_LEVEL` |
|
|
559
|
+
| npm packages | `@monomind/<name>` | `@monomind/hooks` |
|
|
560
|
+
| CLI commands | `monomind <command>` | `monomind agent spawn` |
|
|
561
|
+
| Error classes | extend monomind hierarchy | `class PortedError extends CLIError {}` |
|
|
562
|
+
| Event names | `domain:action` kebab | `'hook:fired'`, `'agent:spawned'` |
|
|
563
|
+
| Log prefixes | `[MODULE]` or `[monomind]` | `[GraphBuilder]`, `[monomind]` |
|
|
564
|
+
| Barrel files | `index.ts` per directory | every new directory gets one |
|
|
565
|
+
| Async model | async/await only | no `.then()` chains, no callbacks |
|
|
566
|
+
| DI style | constructor injection | no decorators, no DI container |
|
|
567
|
+
| Socket/IPC paths | `.monomind/` directory | `~/.monomind/ported.sock` |
|
|
568
|
+
| Config file on disk | `.monomind/` directory | `.monomind/ported-config.json` |
|
|
569
|
+
|
|
570
|
+
**Naming prefix rules:**
|
|
571
|
+
- Domain-specific public types: use domain noun as prefix (`GraphNode`, `AgentPool`, `SwarmConfig`)
|
|
572
|
+
- Cross-cutting types: use `Monomind` prefix (`MonomindConfig`, `MonomindSession`)
|
|
573
|
+
- Skill names: use `mono<shortdomain>` (`monomotion`, `monograph`) — not the source project name
|
|
574
|
+
- Do NOT use the source project's brand name anywhere in the ported code, even in comments — exception: a single attribution comment per file (see below)
|
|
575
|
+
|
|
576
|
+
### Attribution Rule
|
|
577
|
+
|
|
578
|
+
In every ported file, add exactly one attribution comment at the top (not in every function):
|
|
579
|
+
```typescript
|
|
580
|
+
// Pattern adapted from <source_project_name> — rebranded for monomind
|
|
581
|
+
```
|
|
582
|
+
No other references to the source brand should appear anywhere in the file.
|
|
583
|
+
|
|
584
|
+
---
|
|
585
|
+
|
|
586
|
+
### Strategy (a) — Copy-As-Is (with brand normalization)
|
|
587
|
+
|
|
588
|
+
1. Read source file completely
|
|
589
|
+
2. Run brand contamination check: `rg -i "{source_brand}" {file}` — note all occurrences
|
|
590
|
+
3. Adapt file:
|
|
591
|
+
- Update import paths to monomind conventions
|
|
592
|
+
- Apply all naming convention rewrites (see table above)
|
|
593
|
+
- Replace `process.env.SOURCE_*` → `process.env.MONOMIND_*`
|
|
594
|
+
- Replace source error classes with monomind error hierarchy
|
|
595
|
+
- Replace source event names with monomind event naming
|
|
596
|
+
- Replace source log prefixes with `[ModuleName]`
|
|
597
|
+
- Remove all source-brand string literals from comments (keep single attribution)
|
|
598
|
+
- Strip any brand-specific URLs, badges, or README references
|
|
599
|
+
4. Write to monomind location:
|
|
600
|
+
- Skills → `.claude/skills/<mono-name>/SKILL.md`
|
|
601
|
+
- Commands → `.claude/commands/<namespace>/<name>.md`
|
|
602
|
+
- Agents → `.claude/agents/<category>/<name>.md`
|
|
603
|
+
- Helpers → `.claude/helpers/<name>.cjs`
|
|
604
|
+
- Source code → `packages/@monomind/cli/src/<module>/`
|
|
605
|
+
5. If it's a skill or command: add CLAUDE.md Behavioral Rule with new mono-branded name
|
|
606
|
+
6. Final verification: `rg -i "{source_brand}" {written_file}` must return zero results (exception: single attribution comment)
|
|
607
|
+
|
|
608
|
+
### Strategy (b) — Adapt-And-Port (with brand normalization)
|
|
609
|
+
|
|
610
|
+
1. Read source module using Interface-Boundary Focus: read imports and exports first, categorize as (a) stdlib, (b) internal, (c) external
|
|
611
|
+
2. List all framework-specific imports → find monomind equivalent for each
|
|
612
|
+
3. Map source error model → monomind CLIError hierarchy
|
|
613
|
+
4. Map source async model → async/await if not already
|
|
614
|
+
5. Write the adapted file applying all branding rules from the table above
|
|
615
|
+
6. Add a minimal test covering the public interface invariants
|
|
616
|
+
7. Final verification: `rg -i "{source_brand}" {written_file}` → zero results
|
|
617
|
+
|
|
618
|
+
### Strategy (c) — Extract-Pattern-And-Rewrite
|
|
619
|
+
|
|
620
|
+
1. Read source module — use Hierarchical Summarization:
|
|
621
|
+
- What does it do? (1 sentence)
|
|
622
|
+
- What is its public API contract?
|
|
623
|
+
- What hidden assumptions does it make?
|
|
624
|
+
- What invariants does it maintain?
|
|
625
|
+
2. Write a completely new implementation in monomind's TypeScript style:
|
|
626
|
+
- No code from source is copied, even partially
|
|
627
|
+
- Types named per monomind MNS (see table)
|
|
628
|
+
- Error handling via monomind error hierarchy
|
|
629
|
+
- Async/await throughout
|
|
630
|
+
- Constructor injection for dependencies
|
|
631
|
+
- `index.ts` barrel for directory
|
|
632
|
+
3. Add attribution comment: `// Pattern adapted from <source_project_name> — rewritten for monomind`
|
|
633
|
+
4. Write tests covering the invariants from step 1
|
|
634
|
+
|
|
635
|
+
### Strategy (d) — Inspiration-Only
|
|
636
|
+
|
|
637
|
+
1. Read the source to understand the design decisions
|
|
638
|
+
2. Document the insight in conversation only (no files)
|
|
639
|
+
3. No code copied, no file written
|
|
640
|
+
4. Note for the user: "Inspired by <source_project_name>'s approach to X — implemented independently"
|
|
641
|
+
|
|
642
|
+
---
|
|
643
|
+
|
|
644
|
+
### Post-Port Verification (Every Item)
|
|
645
|
+
|
|
646
|
+
After writing each file:
|
|
647
|
+
|
|
648
|
+
```bash
|
|
649
|
+
# 1. Zero brand contamination (hard gate — do NOT proceed to next candidate if this fails)
|
|
650
|
+
if rg -i "{source_brand}" "{written_file}" | grep -v "Pattern adapted from" | grep -q .; then
|
|
651
|
+
echo "FAIL: brand contamination — STOP. Fix all occurrences in {written_file} before continuing."
|
|
652
|
+
exit 1
|
|
653
|
+
else
|
|
654
|
+
echo "OK: clean"
|
|
655
|
+
fi
|
|
656
|
+
|
|
657
|
+
# 2. TypeScript validity
|
|
658
|
+
cd /Users/morteza/Desktop/tools/monobrain && npx tsc --noEmit --project packages/@monomind/cli/tsconfig.json 2>&1 | tail -10
|
|
659
|
+
|
|
660
|
+
# 3. Convention spot check
|
|
661
|
+
cat {written_file} | grep -E "^export class|^export interface|^export function" | head -20
|
|
662
|
+
```
|
|
663
|
+
|
|
664
|
+
---
|
|
665
|
+
|
|
666
|
+
### After All Items
|
|
667
|
+
|
|
668
|
+
```bash
|
|
669
|
+
# Rebuild monomind graph
|
|
670
|
+
Call mcp__monomind__monograph_build({ codeOnly: true })
|
|
671
|
+
|
|
672
|
+
# Show what changed
|
|
673
|
+
Call mcp__monomind__monograph_diff({ from: SNAPSHOT_NAME, to: "live" })
|
|
674
|
+
```
|
|
675
|
+
|
|
676
|
+
**Print port summary:**
|
|
677
|
+
```
|
|
678
|
+
PORT SUMMARY
|
|
679
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
680
|
+
Ported: <N items with strategy and mono-branded name>
|
|
681
|
+
Skipped: <N items with reason>
|
|
682
|
+
Graph: +<N> nodes, +<N> edges
|
|
683
|
+
Clean: brand contamination = 0 across all ported files
|
|
684
|
+
|
|
685
|
+
NEXT STEPS
|
|
686
|
+
1. Run tests: cd packages/@monomind/cli && npm test
|
|
687
|
+
2. Wire new skills/commands to CLAUDE.md if not already done
|
|
688
|
+
3. <any follow-up suggestions>
|
|
689
|
+
```
|
|
690
|
+
|
|
691
|
+
---
|
|
692
|
+
|
|
693
|
+
## Output Schema (Brain Write — mastermind:master compatible)
|
|
694
|
+
|
|
695
|
+
After Phase 3 (analysis) or Phase 5 (execution), write brain output using `_protocol.md` Unified Output Schema — the required fields must be present exactly, with techport-specific data embedded in `artifacts` and `decisions`:
|
|
696
|
+
|
|
697
|
+
```yaml
|
|
698
|
+
# _protocol.md Unified Output Schema — namespace: mastermind:techport:raw
|
|
699
|
+
domain: techport
|
|
700
|
+
status: analysis_complete | port_complete | blocked
|
|
701
|
+
artifacts:
|
|
702
|
+
# techport-specific metadata embedded here
|
|
703
|
+
source_path: <absolute path analyzed>
|
|
704
|
+
source_brand: <extracted PascalCase brand name>
|
|
705
|
+
phase: 3 # or 5 if execution ran
|
|
706
|
+
license: <spdx identifier>
|
|
707
|
+
port_permission: proceed | proceed_restricted | stop_inspiration | stop_proprietary
|
|
708
|
+
risk_score: <number>
|
|
709
|
+
risk_level: low | medium | high | critical
|
|
710
|
+
files_written: [] # populated in Phase 5; empty if phase == 3
|
|
711
|
+
brand_clean: true | false # populated in Phase 5
|
|
712
|
+
tsc_errors: <count> # populated in Phase 5
|
|
713
|
+
|
|
714
|
+
decisions:
|
|
715
|
+
- id: techport-candidate-1
|
|
716
|
+
choice: <OriginalName> → <MonoName> via strategy (a|b|c|d)
|
|
717
|
+
rationale: "PVS=<N>, risk=<N>, fills gap: <one-line>"
|
|
718
|
+
confidence: <0.0–1.0>
|
|
719
|
+
# repeat per approved candidate
|
|
720
|
+
|
|
721
|
+
lessons: [] # add any surprising architectural findings here
|
|
722
|
+
next_actions:
|
|
723
|
+
- "Run: cd packages/@monomind/cli && npm test"
|
|
724
|
+
- "Wire new skill/command to CLAUDE.md if not already done"
|
|
725
|
+
- "<any follow-up suggestions>"
|
|
726
|
+
board_url: "" # leave empty; techport has no Kanban board
|
|
727
|
+
run_id: techport-<timestamp>
|
|
728
|
+
```
|
|
729
|
+
|
|
730
|
+
---
|
|
731
|
+
|
|
732
|
+
## Invariants (Always Enforced)
|
|
733
|
+
|
|
734
|
+
- NEVER port GPL / AGPL / proprietary code — Inspiration-Only and tell user why
|
|
735
|
+
- NEVER copy files containing secrets found by gitleaks — STOP and report
|
|
736
|
+
- NEVER use the source project's brand name in ported code (exception: single attribution comment per file)
|
|
737
|
+
- NEVER overwrite an existing monomind file without reading it first
|
|
738
|
+
- NEVER proceed past Phase 3 in confirm mode without explicit approval
|
|
739
|
+
- NEVER port test fixtures, seed data, or hardcoded example data
|
|
740
|
+
- ALWAYS resolve naming collisions before writing any code (Phase 4B must complete first)
|
|
741
|
+
- ALWAYS run `rg -i "{source_brand}"` verification after each written file
|
|
742
|
+
- ALWAYS add `index.ts` barrel for any new directory created
|
|
743
|
+
- ALWAYS use `async/await` — never port `.then()` chains or callback patterns without converting
|