@dragonflymcp/plugin 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude-plugin/plugin.json +26 -0
- package/LICENSE +21 -0
- package/README.md +126 -0
- package/dist/core/annotations.d.ts +71 -0
- package/dist/core/annotations.d.ts.map +1 -0
- package/dist/core/annotations.js +61 -0
- package/dist/core/annotations.js.map +1 -0
- package/dist/core/config.d.ts +66 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +131 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/dispatcher.d.ts +77 -0
- package/dist/core/dispatcher.d.ts.map +1 -0
- package/dist/core/dispatcher.js +132 -0
- package/dist/core/dispatcher.js.map +1 -0
- package/dist/core/server.d.ts +24 -0
- package/dist/core/server.d.ts.map +1 -0
- package/dist/core/server.js +41 -0
- package/dist/core/server.js.map +1 -0
- package/dist/core/store.d.ts +91 -0
- package/dist/core/store.d.ts.map +1 -0
- package/dist/core/store.js +157 -0
- package/dist/core/store.js.map +1 -0
- package/dist/core/types.d.ts +128 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +5 -0
- package/dist/core/types.js.map +1 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +81 -0
- package/dist/index.js.map +1 -0
- package/dist/test-utils/store-harness.d.ts +41 -0
- package/dist/test-utils/store-harness.d.ts.map +1 -0
- package/dist/test-utils/store-harness.js +61 -0
- package/dist/test-utils/store-harness.js.map +1 -0
- package/dist/tools/analytics/aggregators.d.ts +18 -0
- package/dist/tools/analytics/aggregators.d.ts.map +1 -0
- package/dist/tools/analytics/aggregators.js +260 -0
- package/dist/tools/analytics/aggregators.js.map +1 -0
- package/dist/tools/analytics/aggregators.test.d.ts +2 -0
- package/dist/tools/analytics/aggregators.test.d.ts.map +1 -0
- package/dist/tools/analytics/aggregators.test.js +177 -0
- package/dist/tools/analytics/aggregators.test.js.map +1 -0
- package/dist/tools/analytics/drift.d.ts +15 -0
- package/dist/tools/analytics/drift.d.ts.map +1 -0
- package/dist/tools/analytics/drift.js +135 -0
- package/dist/tools/analytics/drift.js.map +1 -0
- package/dist/tools/analytics/drift.test.d.ts +2 -0
- package/dist/tools/analytics/drift.test.d.ts.map +1 -0
- package/dist/tools/analytics/drift.test.js +99 -0
- package/dist/tools/analytics/drift.test.js.map +1 -0
- package/dist/tools/analytics/index.d.ts +10 -0
- package/dist/tools/analytics/index.d.ts.map +1 -0
- package/dist/tools/analytics/index.js +192 -0
- package/dist/tools/analytics/index.js.map +1 -0
- package/dist/tools/analytics/learner.d.ts +29 -0
- package/dist/tools/analytics/learner.d.ts.map +1 -0
- package/dist/tools/analytics/learner.js +135 -0
- package/dist/tools/analytics/learner.js.map +1 -0
- package/dist/tools/analytics/learner.test.d.ts +2 -0
- package/dist/tools/analytics/learner.test.d.ts.map +1 -0
- package/dist/tools/analytics/learner.test.js +118 -0
- package/dist/tools/analytics/learner.test.js.map +1 -0
- package/dist/tools/analytics/observe.d.ts +22 -0
- package/dist/tools/analytics/observe.d.ts.map +1 -0
- package/dist/tools/analytics/observe.js +143 -0
- package/dist/tools/analytics/observe.js.map +1 -0
- package/dist/tools/analytics/observe.test.d.ts +2 -0
- package/dist/tools/analytics/observe.test.d.ts.map +1 -0
- package/dist/tools/analytics/observe.test.js +95 -0
- package/dist/tools/analytics/observe.test.js.map +1 -0
- package/dist/tools/analytics/store.d.ts +29 -0
- package/dist/tools/analytics/store.d.ts.map +1 -0
- package/dist/tools/analytics/store.js +192 -0
- package/dist/tools/analytics/store.js.map +1 -0
- package/dist/tools/analytics/types.d.ts +290 -0
- package/dist/tools/analytics/types.d.ts.map +1 -0
- package/dist/tools/analytics/types.js +7 -0
- package/dist/tools/analytics/types.js.map +1 -0
- package/dist/tools/ast/index.d.ts +8 -0
- package/dist/tools/ast/index.d.ts.map +1 -0
- package/dist/tools/ast/index.js +242 -0
- package/dist/tools/ast/index.js.map +1 -0
- package/dist/tools/ast/indexer.d.ts +41 -0
- package/dist/tools/ast/indexer.d.ts.map +1 -0
- package/dist/tools/ast/indexer.js +617 -0
- package/dist/tools/ast/indexer.js.map +1 -0
- package/dist/tools/ast/store.d.ts +87 -0
- package/dist/tools/ast/store.d.ts.map +1 -0
- package/dist/tools/ast/store.js +280 -0
- package/dist/tools/ast/store.js.map +1 -0
- package/dist/tools/ast/store.test.d.ts +6 -0
- package/dist/tools/ast/store.test.d.ts.map +1 -0
- package/dist/tools/ast/store.test.js +257 -0
- package/dist/tools/ast/store.test.js.map +1 -0
- package/dist/tools/bridge/bridge.d.ts +37 -0
- package/dist/tools/bridge/bridge.d.ts.map +1 -0
- package/dist/tools/bridge/bridge.js +82 -0
- package/dist/tools/bridge/bridge.js.map +1 -0
- package/dist/tools/bridge/bridge.test.d.ts +2 -0
- package/dist/tools/bridge/bridge.test.d.ts.map +1 -0
- package/dist/tools/bridge/bridge.test.js +119 -0
- package/dist/tools/bridge/bridge.test.js.map +1 -0
- package/dist/tools/bridge/index.d.ts +8 -0
- package/dist/tools/bridge/index.d.ts.map +1 -0
- package/dist/tools/bridge/index.js +153 -0
- package/dist/tools/bridge/index.js.map +1 -0
- package/dist/tools/bridge/store.d.ts +45 -0
- package/dist/tools/bridge/store.d.ts.map +1 -0
- package/dist/tools/bridge/store.js +307 -0
- package/dist/tools/bridge/store.js.map +1 -0
- package/dist/tools/bridge/store.test.d.ts +2 -0
- package/dist/tools/bridge/store.test.d.ts.map +1 -0
- package/dist/tools/bridge/store.test.js +180 -0
- package/dist/tools/bridge/store.test.js.map +1 -0
- package/dist/tools/bridge/types.d.ts +44 -0
- package/dist/tools/bridge/types.d.ts.map +1 -0
- package/dist/tools/bridge/types.js +6 -0
- package/dist/tools/bridge/types.js.map +1 -0
- package/dist/tools/evolve/algorithm.d.ts +33 -0
- package/dist/tools/evolve/algorithm.d.ts.map +1 -0
- package/dist/tools/evolve/algorithm.js +64 -0
- package/dist/tools/evolve/algorithm.js.map +1 -0
- package/dist/tools/evolve/algorithm.test.d.ts +6 -0
- package/dist/tools/evolve/algorithm.test.d.ts.map +1 -0
- package/dist/tools/evolve/algorithm.test.js +138 -0
- package/dist/tools/evolve/algorithm.test.js.map +1 -0
- package/dist/tools/evolve/index.d.ts +11 -0
- package/dist/tools/evolve/index.d.ts.map +1 -0
- package/dist/tools/evolve/index.js +300 -0
- package/dist/tools/evolve/index.js.map +1 -0
- package/dist/tools/evolve/store.d.ts +27 -0
- package/dist/tools/evolve/store.d.ts.map +1 -0
- package/dist/tools/evolve/store.js +147 -0
- package/dist/tools/evolve/store.js.map +1 -0
- package/dist/tools/evolve/store.test.d.ts +6 -0
- package/dist/tools/evolve/store.test.d.ts.map +1 -0
- package/dist/tools/evolve/store.test.js +162 -0
- package/dist/tools/evolve/store.test.js.map +1 -0
- package/dist/tools/evolve/types.d.ts +38 -0
- package/dist/tools/evolve/types.d.ts.map +1 -0
- package/dist/tools/evolve/types.js +6 -0
- package/dist/tools/evolve/types.js.map +1 -0
- package/dist/tools/framework/content-loader.d.ts +45 -0
- package/dist/tools/framework/content-loader.d.ts.map +1 -0
- package/dist/tools/framework/content-loader.js +258 -0
- package/dist/tools/framework/content-loader.js.map +1 -0
- package/dist/tools/framework/content-loader.test.d.ts +5 -0
- package/dist/tools/framework/content-loader.test.d.ts.map +1 -0
- package/dist/tools/framework/content-loader.test.js +262 -0
- package/dist/tools/framework/content-loader.test.js.map +1 -0
- package/dist/tools/framework/index.d.ts +30 -0
- package/dist/tools/framework/index.d.ts.map +1 -0
- package/dist/tools/framework/index.js +517 -0
- package/dist/tools/framework/index.js.map +1 -0
- package/dist/tools/framework/session.d.ts +85 -0
- package/dist/tools/framework/session.d.ts.map +1 -0
- package/dist/tools/framework/session.js +311 -0
- package/dist/tools/framework/session.js.map +1 -0
- package/dist/tools/framework/session.test.d.ts +5 -0
- package/dist/tools/framework/session.test.d.ts.map +1 -0
- package/dist/tools/framework/session.test.js +291 -0
- package/dist/tools/framework/session.test.js.map +1 -0
- package/dist/tools/framework/sync-evaluator.d.ts +41 -0
- package/dist/tools/framework/sync-evaluator.d.ts.map +1 -0
- package/dist/tools/framework/sync-evaluator.js +298 -0
- package/dist/tools/framework/sync-evaluator.js.map +1 -0
- package/dist/tools/framework/sync-evaluator.test.d.ts +5 -0
- package/dist/tools/framework/sync-evaluator.test.d.ts.map +1 -0
- package/dist/tools/framework/sync-evaluator.test.js +288 -0
- package/dist/tools/framework/sync-evaluator.test.js.map +1 -0
- package/dist/tools/framework/types.d.ts +279 -0
- package/dist/tools/framework/types.d.ts.map +1 -0
- package/dist/tools/framework/types.js +6 -0
- package/dist/tools/framework/types.js.map +1 -0
- package/dist/tools/framework/workflow-intelligence.d.ts +55 -0
- package/dist/tools/framework/workflow-intelligence.d.ts.map +1 -0
- package/dist/tools/framework/workflow-intelligence.js +199 -0
- package/dist/tools/framework/workflow-intelligence.js.map +1 -0
- package/dist/tools/framework/workflow-intelligence.test.d.ts +6 -0
- package/dist/tools/framework/workflow-intelligence.test.d.ts.map +1 -0
- package/dist/tools/framework/workflow-intelligence.test.js +257 -0
- package/dist/tools/framework/workflow-intelligence.test.js.map +1 -0
- package/dist/tools/framework/workflow-planner.d.ts +10 -0
- package/dist/tools/framework/workflow-planner.d.ts.map +1 -0
- package/dist/tools/framework/workflow-planner.js +214 -0
- package/dist/tools/framework/workflow-planner.js.map +1 -0
- package/dist/tools/framework/workflow-planner.test.d.ts +5 -0
- package/dist/tools/framework/workflow-planner.test.d.ts.map +1 -0
- package/dist/tools/framework/workflow-planner.test.js +137 -0
- package/dist/tools/framework/workflow-planner.test.js.map +1 -0
- package/dist/tools/knowledge/bridge.d.ts +34 -0
- package/dist/tools/knowledge/bridge.d.ts.map +1 -0
- package/dist/tools/knowledge/bridge.js +249 -0
- package/dist/tools/knowledge/bridge.js.map +1 -0
- package/dist/tools/knowledge/bridge.test.d.ts +5 -0
- package/dist/tools/knowledge/bridge.test.d.ts.map +1 -0
- package/dist/tools/knowledge/bridge.test.js +221 -0
- package/dist/tools/knowledge/bridge.test.js.map +1 -0
- package/dist/tools/knowledge/extractor.d.ts +22 -0
- package/dist/tools/knowledge/extractor.d.ts.map +1 -0
- package/dist/tools/knowledge/extractor.js +154 -0
- package/dist/tools/knowledge/extractor.js.map +1 -0
- package/dist/tools/knowledge/index.d.ts +12 -0
- package/dist/tools/knowledge/index.d.ts.map +1 -0
- package/dist/tools/knowledge/index.js +505 -0
- package/dist/tools/knowledge/index.js.map +1 -0
- package/dist/tools/knowledge/retrieval.d.ts +28 -0
- package/dist/tools/knowledge/retrieval.d.ts.map +1 -0
- package/dist/tools/knowledge/retrieval.js +164 -0
- package/dist/tools/knowledge/retrieval.js.map +1 -0
- package/dist/tools/knowledge/store.d.ts +96 -0
- package/dist/tools/knowledge/store.d.ts.map +1 -0
- package/dist/tools/knowledge/store.js +562 -0
- package/dist/tools/knowledge/store.js.map +1 -0
- package/dist/tools/knowledge/store.test.d.ts +6 -0
- package/dist/tools/knowledge/store.test.d.ts.map +1 -0
- package/dist/tools/knowledge/store.test.js +385 -0
- package/dist/tools/knowledge/store.test.js.map +1 -0
- package/dist/tools/knowledge/types.d.ts +168 -0
- package/dist/tools/knowledge/types.d.ts.map +1 -0
- package/dist/tools/knowledge/types.js +6 -0
- package/dist/tools/knowledge/types.js.map +1 -0
- package/dist/tools/memory/evolution.d.ts +31 -0
- package/dist/tools/memory/evolution.d.ts.map +1 -0
- package/dist/tools/memory/evolution.js +130 -0
- package/dist/tools/memory/evolution.js.map +1 -0
- package/dist/tools/memory/index.d.ts +11 -0
- package/dist/tools/memory/index.d.ts.map +1 -0
- package/dist/tools/memory/index.js +239 -0
- package/dist/tools/memory/index.js.map +1 -0
- package/dist/tools/memory/store.d.ts +75 -0
- package/dist/tools/memory/store.d.ts.map +1 -0
- package/dist/tools/memory/store.js +398 -0
- package/dist/tools/memory/store.js.map +1 -0
- package/dist/tools/memory/store.test.d.ts +6 -0
- package/dist/tools/memory/store.test.d.ts.map +1 -0
- package/dist/tools/memory/store.test.js +429 -0
- package/dist/tools/memory/store.test.js.map +1 -0
- package/dist/tools/memory/types.d.ts +171 -0
- package/dist/tools/memory/types.d.ts.map +1 -0
- package/dist/tools/memory/types.js +6 -0
- package/dist/tools/memory/types.js.map +1 -0
- package/dist/tools/pipeline/composer.d.ts +29 -0
- package/dist/tools/pipeline/composer.d.ts.map +1 -0
- package/dist/tools/pipeline/composer.js +225 -0
- package/dist/tools/pipeline/composer.js.map +1 -0
- package/dist/tools/pipeline/composer.test.d.ts +2 -0
- package/dist/tools/pipeline/composer.test.d.ts.map +1 -0
- package/dist/tools/pipeline/composer.test.js +162 -0
- package/dist/tools/pipeline/composer.test.js.map +1 -0
- package/dist/tools/pipeline/index.d.ts +8 -0
- package/dist/tools/pipeline/index.d.ts.map +1 -0
- package/dist/tools/pipeline/index.js +102 -0
- package/dist/tools/pipeline/index.js.map +1 -0
- package/dist/tools/pipeline/planner.d.ts +10 -0
- package/dist/tools/pipeline/planner.d.ts.map +1 -0
- package/dist/tools/pipeline/planner.js +147 -0
- package/dist/tools/pipeline/planner.js.map +1 -0
- package/dist/tools/pipeline/planner.test.d.ts +2 -0
- package/dist/tools/pipeline/planner.test.d.ts.map +1 -0
- package/dist/tools/pipeline/planner.test.js +96 -0
- package/dist/tools/pipeline/planner.test.js.map +1 -0
- package/dist/tools/pipeline/preconditions.d.ts +14 -0
- package/dist/tools/pipeline/preconditions.d.ts.map +1 -0
- package/dist/tools/pipeline/preconditions.js +65 -0
- package/dist/tools/pipeline/preconditions.js.map +1 -0
- package/dist/tools/pipeline/preconditions.test.d.ts +2 -0
- package/dist/tools/pipeline/preconditions.test.d.ts.map +1 -0
- package/dist/tools/pipeline/preconditions.test.js +74 -0
- package/dist/tools/pipeline/preconditions.test.js.map +1 -0
- package/dist/tools/pipeline/types.d.ts +105 -0
- package/dist/tools/pipeline/types.d.ts.map +1 -0
- package/dist/tools/pipeline/types.js +6 -0
- package/dist/tools/pipeline/types.js.map +1 -0
- package/dist/tools/repair/index.d.ts +8 -0
- package/dist/tools/repair/index.d.ts.map +1 -0
- package/dist/tools/repair/index.js +384 -0
- package/dist/tools/repair/index.js.map +1 -0
- package/dist/tools/repair/repairer.d.ts +67 -0
- package/dist/tools/repair/repairer.d.ts.map +1 -0
- package/dist/tools/repair/repairer.js +257 -0
- package/dist/tools/repair/repairer.js.map +1 -0
- package/dist/tools/repair/repairer.test.d.ts +6 -0
- package/dist/tools/repair/repairer.test.d.ts.map +1 -0
- package/dist/tools/repair/repairer.test.js +159 -0
- package/dist/tools/repair/repairer.test.js.map +1 -0
- package/dist/tools/semantic/chunker.d.ts +23 -0
- package/dist/tools/semantic/chunker.d.ts.map +1 -0
- package/dist/tools/semantic/chunker.js +244 -0
- package/dist/tools/semantic/chunker.js.map +1 -0
- package/dist/tools/semantic/embedder.d.ts +16 -0
- package/dist/tools/semantic/embedder.d.ts.map +1 -0
- package/dist/tools/semantic/embedder.js +88 -0
- package/dist/tools/semantic/embedder.js.map +1 -0
- package/dist/tools/semantic/index.d.ts +8 -0
- package/dist/tools/semantic/index.d.ts.map +1 -0
- package/dist/tools/semantic/index.js +144 -0
- package/dist/tools/semantic/index.js.map +1 -0
- package/dist/tools/semantic/store.d.ts +31 -0
- package/dist/tools/semantic/store.d.ts.map +1 -0
- package/dist/tools/semantic/store.js +168 -0
- package/dist/tools/semantic/store.js.map +1 -0
- package/dist/tools/semantic/store.test.d.ts +6 -0
- package/dist/tools/semantic/store.test.d.ts.map +1 -0
- package/dist/tools/semantic/store.test.js +240 -0
- package/dist/tools/semantic/store.test.js.map +1 -0
- package/dist/tools/spec/generator.d.ts +32 -0
- package/dist/tools/spec/generator.d.ts.map +1 -0
- package/dist/tools/spec/generator.js +278 -0
- package/dist/tools/spec/generator.js.map +1 -0
- package/dist/tools/spec/generator.test.d.ts +6 -0
- package/dist/tools/spec/generator.test.d.ts.map +1 -0
- package/dist/tools/spec/generator.test.js +208 -0
- package/dist/tools/spec/generator.test.js.map +1 -0
- package/dist/tools/spec/index.d.ts +11 -0
- package/dist/tools/spec/index.d.ts.map +1 -0
- package/dist/tools/spec/index.js +426 -0
- package/dist/tools/spec/index.js.map +1 -0
- package/dist/tools/spec/store.d.ts +24 -0
- package/dist/tools/spec/store.d.ts.map +1 -0
- package/dist/tools/spec/store.js +104 -0
- package/dist/tools/spec/store.js.map +1 -0
- package/dist/tools/spec/store.test.d.ts +6 -0
- package/dist/tools/spec/store.test.d.ts.map +1 -0
- package/dist/tools/spec/store.test.js +173 -0
- package/dist/tools/spec/store.test.js.map +1 -0
- package/dist/tools/spec/types.d.ts +61 -0
- package/dist/tools/spec/types.d.ts.map +1 -0
- package/dist/tools/spec/types.js +6 -0
- package/dist/tools/spec/types.js.map +1 -0
- package/dist/tools/state/index.d.ts +11 -0
- package/dist/tools/state/index.d.ts.map +1 -0
- package/dist/tools/state/index.js +386 -0
- package/dist/tools/state/index.js.map +1 -0
- package/dist/tools/state/migrate.d.ts +39 -0
- package/dist/tools/state/migrate.d.ts.map +1 -0
- package/dist/tools/state/migrate.js +242 -0
- package/dist/tools/state/migrate.js.map +1 -0
- package/dist/tools/state/migrate.test.d.ts +2 -0
- package/dist/tools/state/migrate.test.d.ts.map +1 -0
- package/dist/tools/state/migrate.test.js +265 -0
- package/dist/tools/state/migrate.test.js.map +1 -0
- package/dist/tools/state/store.d.ts +107 -0
- package/dist/tools/state/store.d.ts.map +1 -0
- package/dist/tools/state/store.js +365 -0
- package/dist/tools/state/store.js.map +1 -0
- package/dist/tools/state/store.test.d.ts +5 -0
- package/dist/tools/state/store.test.d.ts.map +1 -0
- package/dist/tools/state/store.test.js +293 -0
- package/dist/tools/state/store.test.js.map +1 -0
- package/dist/tools/state/types.d.ts +90 -0
- package/dist/tools/state/types.d.ts.map +1 -0
- package/dist/tools/state/types.js +6 -0
- package/dist/tools/state/types.js.map +1 -0
- package/dist/tools/testing/analyzer.d.ts +44 -0
- package/dist/tools/testing/analyzer.d.ts.map +1 -0
- package/dist/tools/testing/analyzer.js +280 -0
- package/dist/tools/testing/analyzer.js.map +1 -0
- package/dist/tools/testing/generator.d.ts +57 -0
- package/dist/tools/testing/generator.d.ts.map +1 -0
- package/dist/tools/testing/generator.js +478 -0
- package/dist/tools/testing/generator.js.map +1 -0
- package/dist/tools/testing/generator.test.d.ts +6 -0
- package/dist/tools/testing/generator.test.d.ts.map +1 -0
- package/dist/tools/testing/generator.test.js +285 -0
- package/dist/tools/testing/generator.test.js.map +1 -0
- package/dist/tools/testing/index.d.ts +8 -0
- package/dist/tools/testing/index.d.ts.map +1 -0
- package/dist/tools/testing/index.js +373 -0
- package/dist/tools/testing/index.js.map +1 -0
- package/dist/utils/embedder.d.ts +7 -0
- package/dist/utils/embedder.d.ts.map +1 -0
- package/dist/utils/embedder.js +13 -0
- package/dist/utils/embedder.js.map +1 -0
- package/dist/utils/execution.d.ts +68 -0
- package/dist/utils/execution.d.ts.map +1 -0
- package/dist/utils/execution.js +467 -0
- package/dist/utils/execution.js.map +1 -0
- package/dist/utils/graph.d.ts +26 -0
- package/dist/utils/graph.d.ts.map +1 -0
- package/dist/utils/graph.js +32 -0
- package/dist/utils/graph.js.map +1 -0
- package/dist/utils/guards.d.ts +32 -0
- package/dist/utils/guards.d.ts.map +1 -0
- package/dist/utils/guards.js +40 -0
- package/dist/utils/guards.js.map +1 -0
- package/dist/utils/ids.d.ts +5 -0
- package/dist/utils/ids.d.ts.map +1 -0
- package/dist/utils/ids.js +7 -0
- package/dist/utils/ids.js.map +1 -0
- package/dist/utils/languages.d.ts +34 -0
- package/dist/utils/languages.d.ts.map +1 -0
- package/dist/utils/languages.js +153 -0
- package/dist/utils/languages.js.map +1 -0
- package/dist/utils/lazy.d.ts +17 -0
- package/dist/utils/lazy.d.ts.map +1 -0
- package/dist/utils/lazy.js +35 -0
- package/dist/utils/lazy.js.map +1 -0
- package/dist/utils/project.d.ts +41 -0
- package/dist/utils/project.d.ts.map +1 -0
- package/dist/utils/project.js +82 -0
- package/dist/utils/project.js.map +1 -0
- package/dist/utils/responses.d.ts +27 -0
- package/dist/utils/responses.d.ts.map +1 -0
- package/dist/utils/responses.js +72 -0
- package/dist/utils/responses.js.map +1 -0
- package/dist/utils/vectors.d.ts +33 -0
- package/dist/utils/vectors.d.ts.map +1 -0
- package/dist/utils/vectors.js +80 -0
- package/dist/utils/vectors.js.map +1 -0
- package/dist/utils/vectors.test.d.ts +6 -0
- package/dist/utils/vectors.test.d.ts.map +1 -0
- package/dist/utils/vectors.test.js +96 -0
- package/dist/utils/vectors.test.js.map +1 -0
- package/package.json +69 -0
- package/scripts/init.js +142 -0
- package/templates/CLAUDE.md.template +96 -0
- package/templates/agents/architecture-concept.md +237 -0
- package/templates/agents/checkpoint-concept.md +218 -0
- package/templates/agents/code-analysis-concept.md +171 -0
- package/templates/agents/compete-control.md +44 -0
- package/templates/agents/compete-evaluator.md +87 -0
- package/templates/agents/compete-treatment.md +55 -0
- package/templates/agents/context-concept.md +254 -0
- package/templates/agents/debate-advocate.md +127 -0
- package/templates/agents/debate-critic.md +119 -0
- package/templates/agents/debate-synthesis.md +160 -0
- package/templates/agents/documentation-concept.md +294 -0
- package/templates/agents/implementation-concept.md +165 -0
- package/templates/agents/quality-concept.md +299 -0
- package/templates/agents/research-concept.md +169 -0
- package/templates/agents/security-concept.md +255 -0
- package/templates/agents/story-concept.md +207 -0
- package/templates/agents/verification-concept.md +456 -0
- package/templates/agents/version-concept.md +163 -0
- package/templates/anchors/directory.anchor.yaml.template +53 -0
- package/templates/anchors/rules.anchor.yaml.template +70 -0
- package/templates/anchors/safety.anchor.yaml.template +96 -0
- package/templates/claude-md-managed.template +105 -0
- package/templates/commands/cache.md.template +439 -0
- package/templates/commands/checkpoint.md.template +121 -0
- package/templates/commands/classify.md.template +138 -0
- package/templates/commands/compete.md.template +90 -0
- package/templates/commands/costs.md.template +111 -0
- package/templates/commands/estimate.md.template +196 -0
- package/templates/commands/explore.md.template +186 -0
- package/templates/commands/feature.md.template +216 -0
- package/templates/commands/forget.md.template +104 -0
- package/templates/commands/global-recall.md.template +250 -0
- package/templates/commands/global-remember.md.template +187 -0
- package/templates/commands/health.md.template +107 -0
- package/templates/commands/help.md.template +253 -0
- package/templates/commands/observe.md.template +211 -0
- package/templates/commands/pr-review.md.template +164 -0
- package/templates/commands/predict-cost.md.template +251 -0
- package/templates/commands/profile.md.template +142 -0
- package/templates/commands/reasoning.md.template +228 -0
- package/templates/commands/recall.md.template +197 -0
- package/templates/commands/remember.md.template +148 -0
- package/templates/commands/replay.md.template +449 -0
- package/templates/commands/restore.md.template +87 -0
- package/templates/commands/retrospective.md.template +47 -0
- package/templates/commands/slo.md.template +286 -0
- package/templates/commands/spec.md.template +164 -0
- package/templates/commands/status.md.template +53 -0
- package/templates/commands/sync.md.template +321 -0
- package/templates/commands/task.md.template +86 -0
- package/templates/commands/trace.md.template +86 -0
- package/templates/commands/visualize.md.template +216 -0
- package/templates/commands/workflow.md.template +375 -0
- package/templates/concepts/README.md +329 -0
- package/templates/concepts/architecture.md.template +74 -0
- package/templates/concepts/code-analysis.md.template +186 -0
- package/templates/concepts/context-compactor.md.template +393 -0
- package/templates/concepts/context.md.template +62 -0
- package/templates/concepts/documentation.md.template +452 -0
- package/templates/concepts/estimator.md.template +214 -0
- package/templates/concepts/exploration.md.template +257 -0
- package/templates/concepts/global-memory.md.template +222 -0
- package/templates/concepts/implementation.md.template +62 -0
- package/templates/concepts/pr-review.md.template +277 -0
- package/templates/concepts/project-profile.md.template +358 -0
- package/templates/concepts/quality.md.template +63 -0
- package/templates/concepts/react-fallback.md.template +286 -0
- package/templates/concepts/research.md.template +221 -0
- package/templates/concepts/retrospective.md.template +93 -0
- package/templates/concepts/security.md.template +442 -0
- package/templates/concepts/slo.md.template +274 -0
- package/templates/concepts/spec.md.template +71 -0
- package/templates/concepts/story.md.template +50 -0
- package/templates/concepts/tool-router.md.template +289 -0
- package/templates/concepts/verification-synthesizer.md.template +279 -0
- package/templates/concepts/version.md.template +61 -0
- package/templates/config.yaml.template +347 -0
- package/templates/examples/README.md +77 -0
- package/templates/examples/architecture/api-design.yaml.template +286 -0
- package/templates/examples/architecture/oauth-authentication.yaml.template +305 -0
- package/templates/health/status.yaml.template +120 -0
- package/templates/hooks/concept-complete.sh.template +45 -0
- package/templates/hooks/lib/common.sh.template +160 -0
- package/templates/hooks/post-commit.sh.template +37 -0
- package/templates/hooks/post-concept-action.template +39 -0
- package/templates/hooks/post-tool-structure-check.sh.template +138 -0
- package/templates/hooks/post-tool-use.sh.template +51 -0
- package/templates/hooks/pre-compact.sh.template +48 -0
- package/templates/hooks/pre-tool-grounding.template +148 -0
- package/templates/hooks/session-exit-checkpoint.sh.template +35 -0
- package/templates/hooks/session-start.sh.template +67 -0
- package/templates/hooks/statusline.sh.template +148 -0
- package/templates/hooks/stop.sh.template +45 -0
- package/templates/hooks/subagent-stop.sh.template +40 -0
- package/templates/hooks/sync-blocked.sh.template +45 -0
- package/templates/hooks/timeout.sh.template +48 -0
- package/templates/hooks/user-prompt-submit.sh.template +68 -0
- package/templates/koan/README.md +58 -0
- package/templates/memory/index.yaml.template +48 -0
- package/templates/memory/procedural/debugging.yaml.template +24 -0
- package/templates/memory/procedural/workflows.yaml.template +22 -0
- package/templates/memory/semantic/architecture.yaml.template +21 -0
- package/templates/memory/semantic/conventions.yaml.template +18 -0
- package/templates/memory/semantic/patterns.yaml.template +21 -0
- package/templates/memory/semantic/preferences.yaml.template +18 -0
- package/templates/prompts/architecture.yaml.template +349 -0
- package/templates/prompts/context.yaml.template +384 -0
- package/templates/prompts/implementation.yaml.template +365 -0
- package/templates/prompts/planning.yaml.template +303 -0
- package/templates/prompts/quality.yaml.template +345 -0
- package/templates/prompts/retrospective.yaml.template +231 -0
- package/templates/prompts/slo.yaml.template +360 -0
- package/templates/prompts/story.yaml.template +236 -0
- package/templates/prompts/tree-of-thoughts.yaml.template +299 -0
- package/templates/prompts/verification.yaml.template +286 -0
- package/templates/prompts/version.yaml.template +279 -0
- package/templates/schemas/agent-schema.json +98 -0
- package/templates/schemas/architecture.schema.json +69 -0
- package/templates/schemas/config-schema.json +165 -0
- package/templates/schemas/implementation.schema.json +75 -0
- package/templates/schemas/planning.schema.json +243 -0
- package/templates/schemas/provenance.schema.json +111 -0
- package/templates/schemas/retrospective.schema.json +174 -0
- package/templates/schemas/review.schema.json +284 -0
- package/templates/schemas/slo.schema.json +443 -0
- package/templates/schemas/story.schema.json +68 -0
- package/templates/schemas/sync-schema.json +196 -0
- package/templates/schemas/task.schema.json +127 -0
- package/templates/schemas/tree-of-thoughts.schema.json +175 -0
- package/templates/schemas/verification.schema.json +106 -0
- package/templates/settings.full.json.template +135 -0
- package/templates/settings.minimal.json.template +68 -0
- package/templates/settings.standard.json.template +135 -0
- package/templates/skills/acceptance-criteria-generation.md.template +330 -0
- package/templates/skills/accessibility-checking.md.template +341 -0
- package/templates/skills/api-design-patterns.md.template +395 -0
- package/templates/skills/batch-processing.md.template +605 -0
- package/templates/skills/branch-strategy.md.template +362 -0
- package/templates/skills/changelog-generation.md.template +403 -0
- package/templates/skills/code-coverage-analysis.md.template +362 -0
- package/templates/skills/code-style-enforcement.md.template +294 -0
- package/templates/skills/code-template-patterns.md.template +419 -0
- package/templates/skills/concept-development.md.template +159 -0
- package/templates/skills/context-prioritization.md.template +306 -0
- package/templates/skills/cost-optimization.md.template +482 -0
- package/templates/skills/cross-project-knowledge.md.template +316 -0
- package/templates/skills/dependency-impact-analysis.md.template +263 -0
- package/templates/skills/documentation-generation.md.template +409 -0
- package/templates/skills/effort-estimation.md.template +350 -0
- package/templates/skills/error-classification.md.template +709 -0
- package/templates/skills/error-messages.md.template +339 -0
- package/templates/skills/ide-diagnostics.md.template +480 -0
- package/templates/skills/incremental-loading.md.template +574 -0
- package/templates/skills/output-caching.md.template +524 -0
- package/templates/skills/performance-estimation.md.template +325 -0
- package/templates/skills/performance-testing-patterns.md.template +341 -0
- package/templates/skills/phase2-optimizations-summary.md.template +458 -0
- package/templates/skills/progressive-disclosure-pattern.md.template +190 -0
- package/templates/skills/project-structure.md.template +372 -0
- package/templates/skills/provenance-analysis.md.template +609 -0
- package/templates/skills/react-executor.md.template +366 -0
- package/templates/skills/refactoring-patterns.md.template +422 -0
- package/templates/skills/release-management.md.template +373 -0
- package/templates/skills/requirement-prioritization.md.template +357 -0
- package/templates/skills/schema-validation.md.template +321 -0
- package/templates/skills/security-design-patterns.md.template +692 -0
- package/templates/skills/security-vulnerability-scanning.md.template +663 -0
- package/templates/skills/semantic-memory.md.template +266 -0
- package/templates/skills/semantic-versioning.md.template +371 -0
- package/templates/skills/smart-retry.md.template +676 -0
- package/templates/skills/smart-summarization.md.template +358 -0
- package/templates/skills/story-decomposition.md.template +278 -0
- package/templates/skills/synchronization-patterns.md.template +303 -0
- package/templates/skills/test-generation-strategy.md.template +247 -0
- package/templates/skills/workflow-replay.md.template +478 -0
- package/templates/skills/wysiwid-principles.md.template +364 -0
- package/templates/skills-manifest.yaml.template +526 -0
- package/templates/stubs/agents/architecture-concept.md +20 -0
- package/templates/stubs/agents/checkpoint-concept.md +19 -0
- package/templates/stubs/agents/code-analysis-concept.md +36 -0
- package/templates/stubs/agents/context-concept.md +37 -0
- package/templates/stubs/agents/debate-advocate.md +12 -0
- package/templates/stubs/agents/debate-critic.md +12 -0
- package/templates/stubs/agents/debate-synthesis.md +12 -0
- package/templates/stubs/agents/documentation-concept.md +39 -0
- package/templates/stubs/agents/implementation-concept.md +41 -0
- package/templates/stubs/agents/quality-concept.md +41 -0
- package/templates/stubs/agents/research-concept.md +35 -0
- package/templates/stubs/agents/security-concept.md +40 -0
- package/templates/stubs/agents/spec-concept.md +35 -0
- package/templates/stubs/agents/story-concept.md +36 -0
- package/templates/stubs/agents/verification-concept.md +39 -0
- package/templates/stubs/agents/version-concept.md +37 -0
- package/templates/stubs/commands/cache.md.template +2 -0
- package/templates/stubs/commands/checkpoint.md.template +2 -0
- package/templates/stubs/commands/classify.md.template +2 -0
- package/templates/stubs/commands/compete.md.template +2 -0
- package/templates/stubs/commands/costs.md.template +2 -0
- package/templates/stubs/commands/estimate.md.template +2 -0
- package/templates/stubs/commands/explore.md.template +2 -0
- package/templates/stubs/commands/feature.md.template +2 -0
- package/templates/stubs/commands/forget.md.template +2 -0
- package/templates/stubs/commands/global-recall.md.template +2 -0
- package/templates/stubs/commands/global-remember.md.template +2 -0
- package/templates/stubs/commands/health.md.template +2 -0
- package/templates/stubs/commands/help.md.template +2 -0
- package/templates/stubs/commands/observe.md.template +2 -0
- package/templates/stubs/commands/pr-review.md.template +2 -0
- package/templates/stubs/commands/predict-cost.md.template +2 -0
- package/templates/stubs/commands/profile.md.template +2 -0
- package/templates/stubs/commands/reasoning.md.template +2 -0
- package/templates/stubs/commands/recall.md.template +2 -0
- package/templates/stubs/commands/remember.md.template +2 -0
- package/templates/stubs/commands/replay.md.template +2 -0
- package/templates/stubs/commands/restore.md.template +2 -0
- package/templates/stubs/commands/retrospective.md.template +2 -0
- package/templates/stubs/commands/slo.md.template +2 -0
- package/templates/stubs/commands/spec.md.template +2 -0
- package/templates/stubs/commands/sync.md.template +2 -0
- package/templates/stubs/commands/task.md.template +2 -0
- package/templates/stubs/commands/trace.md.template +2 -0
- package/templates/stubs/commands/visualize.md.template +2 -0
- package/templates/stubs/commands/workflow.md.template +2 -0
- package/templates/synchronizations/archive/adaptive-learning.yaml.template +595 -0
- package/templates/synchronizations/archive/code-understanding-flow.yaml.template +533 -0
- package/templates/synchronizations/archive/collaboration-flow.yaml.template +521 -0
- package/templates/synchronizations/archive/context-folding.yaml.template +353 -0
- package/templates/synchronizations/archive/dead-letter-queue.yaml.template +530 -0
- package/templates/synchronizations/archive/documentation-flow.yaml.template +560 -0
- package/templates/synchronizations/archive/error-recovery-flow.yaml.template +1031 -0
- package/templates/synchronizations/archive/execution-loop.yaml.template +336 -0
- package/templates/synchronizations/archive/exploration-flow.yaml.template +369 -0
- package/templates/synchronizations/archive/feature-development.yaml.template +2145 -0
- package/templates/synchronizations/archive/learning-loop.yaml.template +657 -0
- package/templates/synchronizations/archive/multi-verify.yaml.template +346 -0
- package/templates/synchronizations/archive/planning-flow.yaml.template +312 -0
- package/templates/synchronizations/archive/retrospective-flow.yaml.template +277 -0
- package/templates/synchronizations/archive/security-flow.yaml.template +477 -0
- package/templates/synchronizations/archive/slo-monitoring.yaml.template +209 -0
- package/templates/synchronizations/archive/task-routing.yaml.template +489 -0
- package/templates/synchronizations/archive/test-driven.yaml.template +291 -0
- package/templates/synchronizations/archive/tool-routing.yaml.template +326 -0
- package/templates/synchronizations/archive/verification-flow.yaml.template +407 -0
- package/templates/synchronizations/error-policy.yaml.template +188 -0
- package/templates/synchronizations/main.sync.template +319 -0
- package/templates/synchronizations/slo-registry.yaml.template +229 -0
- package/templates/tasks/task.yaml.template +67 -0
- package/templates/zen-profile.yaml.template +14 -0
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Evolution Algorithm
|
|
3
|
+
* Tournament selection, elite preservation, and convergence detection.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Tournament selection: pick k random candidates, return the best.
|
|
7
|
+
* Repeat `count` times to get multiple parents.
|
|
8
|
+
*/
|
|
9
|
+
export function tournamentSelect(variants, count, k = 3) {
|
|
10
|
+
const parents = [];
|
|
11
|
+
for (let i = 0; i < count; i++) {
|
|
12
|
+
const candidates = [];
|
|
13
|
+
for (let j = 0; j < k; j++) {
|
|
14
|
+
candidates.push(variants[Math.floor(Math.random() * variants.length)]);
|
|
15
|
+
}
|
|
16
|
+
candidates.sort((a, b) => (b.fitnessScore ?? 0) - (a.fitnessScore ?? 0));
|
|
17
|
+
parents.push(candidates[0]);
|
|
18
|
+
}
|
|
19
|
+
return parents;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Get elite variants (top N by fitness) that always survive to the next generation.
|
|
23
|
+
*/
|
|
24
|
+
export function getElites(variants, count = 2) {
|
|
25
|
+
return [...variants]
|
|
26
|
+
.sort((a, b) => (b.fitnessScore ?? 0) - (a.fitnessScore ?? 0))
|
|
27
|
+
.slice(0, count);
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Check if evolution has converged.
|
|
31
|
+
* Converged = best fitness hasn't improved by more than `threshold`
|
|
32
|
+
* for `window` consecutive generations.
|
|
33
|
+
*/
|
|
34
|
+
export function checkConvergence(fitnessHistory, window = 3, threshold = 0.01) {
|
|
35
|
+
if (fitnessHistory.length < window + 1)
|
|
36
|
+
return false;
|
|
37
|
+
const recent = fitnessHistory.slice(-window);
|
|
38
|
+
const baseline = fitnessHistory[fitnessHistory.length - window - 1];
|
|
39
|
+
return recent.every((f) => f - baseline < threshold);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Build mutation instructions for the next generation.
|
|
43
|
+
* For each parent, identify weaknesses and create instructions.
|
|
44
|
+
*/
|
|
45
|
+
export function buildMutationInstructions(parents, conceptName, populationSize) {
|
|
46
|
+
const parentInfo = parents.map((p) => ({
|
|
47
|
+
prompt: p.prompt,
|
|
48
|
+
fitness: p.fitnessScore ?? 0,
|
|
49
|
+
weaknesses: p.notes ?? "No specific weaknesses noted",
|
|
50
|
+
}));
|
|
51
|
+
const instructions = [
|
|
52
|
+
`Generate ${populationSize} variant prompts for "${conceptName}".`,
|
|
53
|
+
`Use these top-performing parents as starting points:`,
|
|
54
|
+
...parentInfo.map((p, i) => ` Parent ${i + 1} (fitness: ${p.fitness.toFixed(2)}): "${p.prompt.slice(0, 100)}..."${p.weaknesses !== "No specific weaknesses noted" ? ` — Weakness: ${p.weaknesses}` : ""}`),
|
|
55
|
+
``,
|
|
56
|
+
`For each variant:`,
|
|
57
|
+
`1. Take a parent prompt and modify it to improve weaknesses`,
|
|
58
|
+
`2. Keep the parts that scored well`,
|
|
59
|
+
`3. Evaluate each variant against the test cases`,
|
|
60
|
+
`4. Call evolve_submit with the scored variants`,
|
|
61
|
+
].join("\n");
|
|
62
|
+
return { parents: parentInfo, instructions };
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=algorithm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"algorithm.js","sourceRoot":"","sources":["../../../src/tools/evolve/algorithm.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"algorithm.test.d.ts","sourceRoot":"","sources":["../../../src/tools/evolve/algorithm.test.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Evolution Algorithm Tests
|
|
3
|
+
* Pure function tests — no DB needed
|
|
4
|
+
*/
|
|
5
|
+
import { describe, it, expect } from 'vitest';
|
|
6
|
+
import { tournamentSelect, getElites, checkConvergence, buildMutationInstructions, } from './algorithm.js';
|
|
7
|
+
function makeVariant(overrides = {}) {
|
|
8
|
+
return {
|
|
9
|
+
id: `var-${Math.random().toString(36).slice(2, 6)}`,
|
|
10
|
+
sessionId: 'evo-test',
|
|
11
|
+
generation: 0,
|
|
12
|
+
prompt: 'Test prompt',
|
|
13
|
+
fitnessScore: 0.5,
|
|
14
|
+
notes: null,
|
|
15
|
+
parentId: null,
|
|
16
|
+
createdAt: new Date().toISOString(),
|
|
17
|
+
...overrides,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
describe('tournamentSelect', () => {
|
|
21
|
+
it('should return the requested number of parents', () => {
|
|
22
|
+
const variants = Array.from({ length: 10 }, (_, i) => makeVariant({ fitnessScore: i * 0.1 }));
|
|
23
|
+
const parents = tournamentSelect(variants, 3);
|
|
24
|
+
expect(parents).toHaveLength(3);
|
|
25
|
+
});
|
|
26
|
+
it('should return variants from the input pool', () => {
|
|
27
|
+
const variants = [
|
|
28
|
+
makeVariant({ prompt: 'A', fitnessScore: 0.9 }),
|
|
29
|
+
makeVariant({ prompt: 'B', fitnessScore: 0.1 }),
|
|
30
|
+
makeVariant({ prompt: 'C', fitnessScore: 0.5 }),
|
|
31
|
+
];
|
|
32
|
+
const parents = tournamentSelect(variants, 2, 2);
|
|
33
|
+
for (const p of parents) {
|
|
34
|
+
expect(['A', 'B', 'C']).toContain(p.prompt);
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
it('should bias toward higher-fitness variants', () => {
|
|
38
|
+
const high = makeVariant({ prompt: 'high', fitnessScore: 1.0 });
|
|
39
|
+
const low = makeVariant({ prompt: 'low', fitnessScore: 0.0 });
|
|
40
|
+
const variants = [high, low, low, low]; // 3:1 ratio of low:high
|
|
41
|
+
// With tournament k=3 from 4 variants (3 low, 1 high), the high should still win often
|
|
42
|
+
const parents = tournamentSelect(variants, 50, 3);
|
|
43
|
+
const highCount = parents.filter((p) => p.prompt === 'high').length;
|
|
44
|
+
// High should appear more often than pure random (12.5 out of 50 = 25%)
|
|
45
|
+
expect(highCount).toBeGreaterThan(15);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
describe('getElites', () => {
|
|
49
|
+
it('should return top N variants sorted by fitness descending', () => {
|
|
50
|
+
const variants = [
|
|
51
|
+
makeVariant({ prompt: 'low', fitnessScore: 0.2 }),
|
|
52
|
+
makeVariant({ prompt: 'high', fitnessScore: 0.9 }),
|
|
53
|
+
makeVariant({ prompt: 'mid', fitnessScore: 0.5 }),
|
|
54
|
+
makeVariant({ prompt: 'very-high', fitnessScore: 0.95 }),
|
|
55
|
+
];
|
|
56
|
+
const elites = getElites(variants, 2);
|
|
57
|
+
expect(elites).toHaveLength(2);
|
|
58
|
+
expect(elites[0].prompt).toBe('very-high');
|
|
59
|
+
expect(elites[1].prompt).toBe('high');
|
|
60
|
+
});
|
|
61
|
+
it('should handle count larger than variants', () => {
|
|
62
|
+
const variants = [makeVariant({ fitnessScore: 0.5 })];
|
|
63
|
+
const elites = getElites(variants, 5);
|
|
64
|
+
expect(elites).toHaveLength(1);
|
|
65
|
+
});
|
|
66
|
+
it('should not mutate the original array', () => {
|
|
67
|
+
const variants = [
|
|
68
|
+
makeVariant({ fitnessScore: 0.1 }),
|
|
69
|
+
makeVariant({ fitnessScore: 0.9 }),
|
|
70
|
+
];
|
|
71
|
+
const originalFirst = variants[0];
|
|
72
|
+
getElites(variants, 1);
|
|
73
|
+
expect(variants[0]).toBe(originalFirst);
|
|
74
|
+
});
|
|
75
|
+
it('should handle null fitness scores as 0', () => {
|
|
76
|
+
const variants = [
|
|
77
|
+
makeVariant({ fitnessScore: null }),
|
|
78
|
+
makeVariant({ fitnessScore: 0.5 }),
|
|
79
|
+
];
|
|
80
|
+
const elites = getElites(variants, 1);
|
|
81
|
+
expect(elites[0].fitnessScore).toBe(0.5);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('checkConvergence', () => {
|
|
85
|
+
it('should return false when history is too short', () => {
|
|
86
|
+
expect(checkConvergence([0.5, 0.6])).toBe(false);
|
|
87
|
+
expect(checkConvergence([0.5, 0.6, 0.7])).toBe(false);
|
|
88
|
+
});
|
|
89
|
+
it('should return true when fitness stagnates', () => {
|
|
90
|
+
// window=3: need at least 4 entries
|
|
91
|
+
// baseline = history[-4] = 0.8
|
|
92
|
+
// recent 3 all <= 0.8 + 0.01
|
|
93
|
+
const history = [0.5, 0.6, 0.7, 0.8, 0.8, 0.8, 0.8];
|
|
94
|
+
expect(checkConvergence(history)).toBe(true);
|
|
95
|
+
});
|
|
96
|
+
it('should return false when fitness is still improving', () => {
|
|
97
|
+
const history = [0.5, 0.6, 0.7, 0.8, 0.85, 0.9, 0.95];
|
|
98
|
+
expect(checkConvergence(history)).toBe(false);
|
|
99
|
+
});
|
|
100
|
+
it('should respect custom window and threshold', () => {
|
|
101
|
+
// window=2, threshold=0.05
|
|
102
|
+
// baseline = history[-3] = 0.8
|
|
103
|
+
// recent 2: [0.81, 0.82] — both < 0.8 + 0.05 = 0.85
|
|
104
|
+
const history = [0.5, 0.7, 0.8, 0.81, 0.82];
|
|
105
|
+
expect(checkConvergence(history, 2, 0.05)).toBe(true);
|
|
106
|
+
});
|
|
107
|
+
it('should return false when one recent value shows improvement', () => {
|
|
108
|
+
// baseline = 0.8, one recent value exceeds threshold
|
|
109
|
+
const history = [0.5, 0.7, 0.8, 0.8, 0.8, 0.82];
|
|
110
|
+
expect(checkConvergence(history, 3, 0.01)).toBe(false);
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
describe('buildMutationInstructions', () => {
|
|
114
|
+
it('should include concept name in instructions', () => {
|
|
115
|
+
const parents = [makeVariant({ prompt: 'Parent A', fitnessScore: 0.8 })];
|
|
116
|
+
const result = buildMutationInstructions(parents, 'code-review', 5);
|
|
117
|
+
expect(result.instructions).toContain('code-review');
|
|
118
|
+
});
|
|
119
|
+
it('should include parent fitness info', () => {
|
|
120
|
+
const parents = [
|
|
121
|
+
makeVariant({ prompt: 'Parent A', fitnessScore: 0.8, notes: 'Too verbose' }),
|
|
122
|
+
makeVariant({ prompt: 'Parent B', fitnessScore: 0.6 }),
|
|
123
|
+
];
|
|
124
|
+
const result = buildMutationInstructions(parents, 'summarizer', 3);
|
|
125
|
+
expect(result.parents).toHaveLength(2);
|
|
126
|
+
expect(result.parents[0].fitness).toBe(0.8);
|
|
127
|
+
expect(result.parents[0].weaknesses).toBe('Too verbose');
|
|
128
|
+
expect(result.parents[1].weaknesses).toBe('No specific weaknesses noted');
|
|
129
|
+
expect(result.instructions).toContain('0.80');
|
|
130
|
+
expect(result.instructions).toContain('Too verbose');
|
|
131
|
+
});
|
|
132
|
+
it('should mention population size', () => {
|
|
133
|
+
const parents = [makeVariant({ fitnessScore: 0.5 })];
|
|
134
|
+
const result = buildMutationInstructions(parents, 'test', 7);
|
|
135
|
+
expect(result.instructions).toContain('7');
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
//# sourceMappingURL=algorithm.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"algorithm.test.js","sourceRoot":"","sources":["../../../src/tools/evolve/algorithm.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Evolve Module
|
|
3
|
+
* Orchestrated prompt evolution where Claude drives mutation/evaluation
|
|
4
|
+
* and dragonfly manages state, selection, and convergence.
|
|
5
|
+
*
|
|
6
|
+
* 4 tools: evolve_start, evolve_submit, evolve_status, evolve_best
|
|
7
|
+
*/
|
|
8
|
+
import { Tool } from "@modelcontextprotocol/sdk/types.js";
|
|
9
|
+
export declare const tools: Tool[];
|
|
10
|
+
export declare const evolveModule: import("../../core/types.js").ToolModule;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tools/evolve/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC;AAmC1D,eAAO,MAAM,KAAK,EAAE,IAAI,EA2GvB,CAAC;AA8MF,eAAO,MAAM,YAAY,0CAAkC,CAAC"}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Evolve Module
|
|
3
|
+
* Orchestrated prompt evolution where Claude drives mutation/evaluation
|
|
4
|
+
* and dragonfly manages state, selection, and convergence.
|
|
5
|
+
*
|
|
6
|
+
* 4 tools: evolve_start, evolve_submit, evolve_status, evolve_best
|
|
7
|
+
*/
|
|
8
|
+
import { successResponse, errorResponse, args as a } from "../../utils/responses.js";
|
|
9
|
+
import { createDispatcher, createModule } from "../../core/dispatcher.js";
|
|
10
|
+
import { createLazyLoader } from "../../utils/lazy.js";
|
|
11
|
+
import { requireEvolve } from "../../utils/guards.js";
|
|
12
|
+
import { config } from "../../core/config.js";
|
|
13
|
+
import { EvolveStore } from "./store.js";
|
|
14
|
+
import { tournamentSelect, getElites, checkConvergence, buildMutationInstructions, } from "./algorithm.js";
|
|
15
|
+
const dispatcher = createDispatcher();
|
|
16
|
+
const getStore = createLazyLoader(() => new EvolveStore(config().stateDbPath));
|
|
17
|
+
/** Build fitness history (best score per generation, sorted by generation). */
|
|
18
|
+
function buildFitnessHistory(store, sessionId) {
|
|
19
|
+
const allVariants = store.getVariants(sessionId);
|
|
20
|
+
const fitnessByGen = new Map();
|
|
21
|
+
for (const v of allVariants) {
|
|
22
|
+
const current = fitnessByGen.get(v.generation) ?? 0;
|
|
23
|
+
if ((v.fitnessScore ?? 0) > current) {
|
|
24
|
+
fitnessByGen.set(v.generation, v.fitnessScore ?? 0);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return Array.from(fitnessByGen.entries())
|
|
28
|
+
.sort(([a], [b]) => a - b)
|
|
29
|
+
.map(([, f]) => f);
|
|
30
|
+
}
|
|
31
|
+
// ─── Tool Definitions ────────────────────────────────────
|
|
32
|
+
export const tools = [
|
|
33
|
+
{
|
|
34
|
+
name: "evolve_start",
|
|
35
|
+
description: "Create an evolution session for prompt optimization. Returns instructions for Claude to generate and evaluate variant prompts.",
|
|
36
|
+
inputSchema: {
|
|
37
|
+
type: "object",
|
|
38
|
+
properties: {
|
|
39
|
+
concept_name: {
|
|
40
|
+
type: "string",
|
|
41
|
+
description: "What's being optimized (e.g., 'code-review-prompt')",
|
|
42
|
+
},
|
|
43
|
+
initial_prompt: {
|
|
44
|
+
type: "string",
|
|
45
|
+
description: "Starting prompt to evolve",
|
|
46
|
+
},
|
|
47
|
+
test_cases: {
|
|
48
|
+
type: "array",
|
|
49
|
+
items: {
|
|
50
|
+
type: "object",
|
|
51
|
+
properties: {
|
|
52
|
+
input: { type: "string" },
|
|
53
|
+
expected: { type: "string" },
|
|
54
|
+
},
|
|
55
|
+
required: ["input", "expected"],
|
|
56
|
+
},
|
|
57
|
+
description: "Fitness evaluation criteria",
|
|
58
|
+
},
|
|
59
|
+
population_size: {
|
|
60
|
+
type: "number",
|
|
61
|
+
description: "Variants per generation (default: 5)",
|
|
62
|
+
},
|
|
63
|
+
max_generations: {
|
|
64
|
+
type: "number",
|
|
65
|
+
description: "Maximum generations (default: 10)",
|
|
66
|
+
},
|
|
67
|
+
mutation_rate: {
|
|
68
|
+
type: "number",
|
|
69
|
+
description: "Mutation rate 0-1 (default: 0.7)",
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
required: ["concept_name", "initial_prompt", "test_cases"],
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
name: "evolve_submit",
|
|
77
|
+
description: "Submit evaluated variants and advance the evolution. Returns selection results and mutation instructions for the next generation, or convergence/completion status.",
|
|
78
|
+
inputSchema: {
|
|
79
|
+
type: "object",
|
|
80
|
+
properties: {
|
|
81
|
+
session_id: {
|
|
82
|
+
type: "string",
|
|
83
|
+
description: "Evolution session ID",
|
|
84
|
+
},
|
|
85
|
+
variants: {
|
|
86
|
+
type: "array",
|
|
87
|
+
items: {
|
|
88
|
+
type: "object",
|
|
89
|
+
properties: {
|
|
90
|
+
prompt: { type: "string" },
|
|
91
|
+
fitness_score: {
|
|
92
|
+
type: "number",
|
|
93
|
+
description: "Fitness score 0.0-1.0",
|
|
94
|
+
},
|
|
95
|
+
notes: {
|
|
96
|
+
type: "string",
|
|
97
|
+
description: "What worked/didn't",
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
required: ["prompt", "fitness_score"],
|
|
101
|
+
},
|
|
102
|
+
description: "Evaluated variant prompts with fitness scores",
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
required: ["session_id", "variants"],
|
|
106
|
+
},
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
name: "evolve_status",
|
|
110
|
+
description: "Check evolution session progress and statistics.",
|
|
111
|
+
inputSchema: {
|
|
112
|
+
type: "object",
|
|
113
|
+
properties: {
|
|
114
|
+
session_id: {
|
|
115
|
+
type: "string",
|
|
116
|
+
description: "Evolution session ID",
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
required: ["session_id"],
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
name: "evolve_best",
|
|
124
|
+
description: "Get the winning variant from an evolution session. Returns the best prompt, its fitness score, and improvement over the initial prompt.",
|
|
125
|
+
inputSchema: {
|
|
126
|
+
type: "object",
|
|
127
|
+
properties: {
|
|
128
|
+
session_id: {
|
|
129
|
+
type: "string",
|
|
130
|
+
description: "Evolution session ID",
|
|
131
|
+
},
|
|
132
|
+
},
|
|
133
|
+
required: ["session_id"],
|
|
134
|
+
},
|
|
135
|
+
},
|
|
136
|
+
];
|
|
137
|
+
// ─── Handlers ────────────────────────────────────────────
|
|
138
|
+
dispatcher
|
|
139
|
+
.register("evolve_start", requireEvolve(async (args) => {
|
|
140
|
+
const conceptName = a.string(args, "concept_name");
|
|
141
|
+
const initialPrompt = a.string(args, "initial_prompt");
|
|
142
|
+
const testCases = a.array(args, "test_cases");
|
|
143
|
+
const populationSize = a.number(args, "population_size", 5);
|
|
144
|
+
const maxGenerations = a.number(args, "max_generations", 10);
|
|
145
|
+
const mutationRate = a.number(args, "mutation_rate", 0.7);
|
|
146
|
+
if (!conceptName)
|
|
147
|
+
return errorResponse("concept_name is required");
|
|
148
|
+
if (!initialPrompt)
|
|
149
|
+
return errorResponse("initial_prompt is required");
|
|
150
|
+
if (!testCases.length)
|
|
151
|
+
return errorResponse("test_cases must contain at least one test case");
|
|
152
|
+
const store = getStore();
|
|
153
|
+
const session = store.createSession(conceptName, initialPrompt, testCases, {
|
|
154
|
+
populationSize,
|
|
155
|
+
maxGenerations,
|
|
156
|
+
mutationRate,
|
|
157
|
+
});
|
|
158
|
+
const instructions = [
|
|
159
|
+
`Generate ${populationSize} variant prompts for "${conceptName}".`,
|
|
160
|
+
`Start from this initial prompt: "${initialPrompt.slice(0, 200)}${initialPrompt.length > 200 ? "..." : ""}"`,
|
|
161
|
+
``,
|
|
162
|
+
`Evaluate each variant against these test cases:`,
|
|
163
|
+
...testCases.map((tc, i) => ` ${i + 1}. Input: "${tc.input}" → Expected: "${tc.expected}"`),
|
|
164
|
+
``,
|
|
165
|
+
`For each variant, assign a fitness_score from 0.0 to 1.0 based on how well it meets the expected outputs.`,
|
|
166
|
+
`Then call evolve_submit with the session_id and scored variants.`,
|
|
167
|
+
].join("\n");
|
|
168
|
+
return successResponse({
|
|
169
|
+
session_id: session.id,
|
|
170
|
+
generation: 0,
|
|
171
|
+
instructions,
|
|
172
|
+
});
|
|
173
|
+
}))
|
|
174
|
+
.register("evolve_submit", requireEvolve(async (args) => {
|
|
175
|
+
const sessionId = a.string(args, "session_id");
|
|
176
|
+
if (!sessionId)
|
|
177
|
+
return errorResponse("session_id is required");
|
|
178
|
+
const variants = a.array(args, "variants");
|
|
179
|
+
if (!variants.length)
|
|
180
|
+
return errorResponse("variants must contain at least one variant");
|
|
181
|
+
const store = getStore();
|
|
182
|
+
const session = store.getSession(sessionId);
|
|
183
|
+
if (!session)
|
|
184
|
+
return errorResponse(`Session "${sessionId}" not found`);
|
|
185
|
+
if (session.status !== "active") {
|
|
186
|
+
return errorResponse(`Session is ${session.status}, not active`);
|
|
187
|
+
}
|
|
188
|
+
// Insert variants for current generation
|
|
189
|
+
const nextGen = session.currentGeneration + 1;
|
|
190
|
+
const inserted = store.insertVariants(sessionId, nextGen, variants.map((v) => ({
|
|
191
|
+
prompt: v.prompt,
|
|
192
|
+
fitnessScore: v.fitness_score,
|
|
193
|
+
notes: v.notes,
|
|
194
|
+
})));
|
|
195
|
+
// Find best variant across all generations
|
|
196
|
+
const bestVariant = store.getBestVariant(sessionId);
|
|
197
|
+
const bestFitness = bestVariant?.fitnessScore ?? 0;
|
|
198
|
+
// Build fitness history for convergence check
|
|
199
|
+
const fitnessHistory = buildFitnessHistory(store, sessionId);
|
|
200
|
+
// Check convergence and max generations
|
|
201
|
+
const converged = checkConvergence(fitnessHistory);
|
|
202
|
+
const maxReached = nextGen >= session.config.maxGenerations;
|
|
203
|
+
const status = converged ? "converged" : maxReached ? "completed" : "active";
|
|
204
|
+
// Update session
|
|
205
|
+
store.updateSession(sessionId, {
|
|
206
|
+
currentGeneration: nextGen,
|
|
207
|
+
status,
|
|
208
|
+
bestFitness,
|
|
209
|
+
bestVariantId: bestVariant?.id ?? null,
|
|
210
|
+
});
|
|
211
|
+
if (status !== "active") {
|
|
212
|
+
return successResponse({
|
|
213
|
+
generation: nextGen,
|
|
214
|
+
best_fitness: bestFitness,
|
|
215
|
+
status,
|
|
216
|
+
message: status === "converged"
|
|
217
|
+
? `Evolution converged at generation ${nextGen}. Call evolve_best to get the winning prompt.`
|
|
218
|
+
: `Reached maximum generations (${session.config.maxGenerations}). Call evolve_best to get the winning prompt.`,
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
// Select parents for next generation
|
|
222
|
+
const genVariants = inserted;
|
|
223
|
+
const elites = getElites(genVariants, 2);
|
|
224
|
+
const parents = tournamentSelect(genVariants, session.config.populationSize);
|
|
225
|
+
// Deduplicate parents with elites
|
|
226
|
+
const parentSet = new Map();
|
|
227
|
+
for (const e of elites)
|
|
228
|
+
parentSet.set(e.id, e);
|
|
229
|
+
for (const p of parents)
|
|
230
|
+
parentSet.set(p.id, p);
|
|
231
|
+
const uniqueParents = Array.from(parentSet.values()).slice(0, session.config.populationSize);
|
|
232
|
+
const { parents: parentInfo, instructions } = buildMutationInstructions(uniqueParents, session.conceptName, session.config.populationSize);
|
|
233
|
+
return successResponse({
|
|
234
|
+
generation: nextGen,
|
|
235
|
+
best_fitness: bestFitness,
|
|
236
|
+
status: "active",
|
|
237
|
+
parents: parentInfo,
|
|
238
|
+
instructions,
|
|
239
|
+
});
|
|
240
|
+
}))
|
|
241
|
+
.registerQuick("evolve_status", requireEvolve(async (args) => {
|
|
242
|
+
const sessionId = a.string(args, "session_id");
|
|
243
|
+
if (!sessionId)
|
|
244
|
+
return errorResponse("session_id is required");
|
|
245
|
+
const store = getStore();
|
|
246
|
+
const session = store.getSession(sessionId);
|
|
247
|
+
if (!session)
|
|
248
|
+
return errorResponse(`Session "${sessionId}" not found`);
|
|
249
|
+
const variantCount = store.getVariantCount(sessionId);
|
|
250
|
+
// Build fitness history for convergence window display
|
|
251
|
+
const fitnessHistory = buildFitnessHistory(store, sessionId);
|
|
252
|
+
const initialFitness = fitnessHistory[0] ?? 0;
|
|
253
|
+
const improvementPct = initialFitness > 0
|
|
254
|
+
? ((session.bestFitness - initialFitness) / initialFitness) * 100
|
|
255
|
+
: 0;
|
|
256
|
+
return successResponse({
|
|
257
|
+
session_id: session.id,
|
|
258
|
+
concept_name: session.conceptName,
|
|
259
|
+
status: session.status,
|
|
260
|
+
current_generation: session.currentGeneration,
|
|
261
|
+
max_generations: session.config.maxGenerations,
|
|
262
|
+
best_fitness: session.bestFitness,
|
|
263
|
+
improvement_pct: Math.round(improvementPct * 10) / 10,
|
|
264
|
+
variants_evaluated: variantCount,
|
|
265
|
+
convergence_window: fitnessHistory.slice(-3),
|
|
266
|
+
});
|
|
267
|
+
}))
|
|
268
|
+
.registerQuick("evolve_best", requireEvolve(async (args) => {
|
|
269
|
+
const sessionId = a.string(args, "session_id");
|
|
270
|
+
if (!sessionId)
|
|
271
|
+
return errorResponse("session_id is required");
|
|
272
|
+
const store = getStore();
|
|
273
|
+
const session = store.getSession(sessionId);
|
|
274
|
+
if (!session)
|
|
275
|
+
return errorResponse(`Session "${sessionId}" not found`);
|
|
276
|
+
const bestVariant = store.getBestVariant(sessionId);
|
|
277
|
+
if (!bestVariant) {
|
|
278
|
+
return errorResponse("No variants found. Submit variants first with evolve_submit.");
|
|
279
|
+
}
|
|
280
|
+
const variantCount = store.getVariantCount(sessionId);
|
|
281
|
+
// Calculate improvement over initial
|
|
282
|
+
const allVariants = store.getVariants(sessionId);
|
|
283
|
+
const gen1Variants = allVariants.filter((v) => v.generation === 1);
|
|
284
|
+
const initialBestFitness = gen1Variants.length > 0
|
|
285
|
+
? Math.max(...gen1Variants.map((v) => v.fitnessScore ?? 0))
|
|
286
|
+
: 0;
|
|
287
|
+
const improvementPct = initialBestFitness > 0
|
|
288
|
+
? ((bestVariant.fitnessScore - initialBestFitness) / initialBestFitness) * 100
|
|
289
|
+
: 0;
|
|
290
|
+
return successResponse({
|
|
291
|
+
prompt: bestVariant.prompt,
|
|
292
|
+
fitness_score: bestVariant.fitnessScore,
|
|
293
|
+
generation: bestVariant.generation,
|
|
294
|
+
improvement_pct: Math.round(improvementPct * 10) / 10,
|
|
295
|
+
initial_prompt: session.initialPrompt,
|
|
296
|
+
total_variants_evaluated: variantCount,
|
|
297
|
+
});
|
|
298
|
+
}));
|
|
299
|
+
export const evolveModule = createModule(tools, dispatcher);
|
|
300
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/evolve/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Evolution Store
|
|
3
|
+
* SQLite-backed storage for evolution sessions and variants.
|
|
4
|
+
* Uses the existing state.db via shared stateDbPath config.
|
|
5
|
+
*/
|
|
6
|
+
import { BaseStore } from "../../core/store.js";
|
|
7
|
+
import type { EvolutionSession, EvolutionVariant, EvolutionConfig, TestCase } from "./types.js";
|
|
8
|
+
export declare class EvolveStore extends BaseStore {
|
|
9
|
+
constructor(dbPath: string);
|
|
10
|
+
private initTables;
|
|
11
|
+
createSession(conceptName: string, initialPrompt: string, testCases: TestCase[], config: EvolutionConfig): EvolutionSession;
|
|
12
|
+
getSession(id: string): EvolutionSession | null;
|
|
13
|
+
private static readonly sessionFields;
|
|
14
|
+
updateSession(id: string, updates: Partial<Pick<EvolutionSession, "currentGeneration" | "status" | "bestFitness" | "bestVariantId">>): void;
|
|
15
|
+
insertVariants(sessionId: string, generation: number, variants: Array<{
|
|
16
|
+
prompt: string;
|
|
17
|
+
fitnessScore: number;
|
|
18
|
+
notes?: string;
|
|
19
|
+
parentId?: string;
|
|
20
|
+
}>): EvolutionVariant[];
|
|
21
|
+
getVariants(sessionId: string, generation?: number): EvolutionVariant[];
|
|
22
|
+
getBestVariant(sessionId: string): EvolutionVariant | null;
|
|
23
|
+
getVariantCount(sessionId: string): number;
|
|
24
|
+
private rowToSession;
|
|
25
|
+
private rowToVariant;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/tools/evolve/store.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,SAAS,EAAqB,MAAM,qBAAqB,CAAC;AAEnE,OAAO,KAAK,EACV,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,EAEf,QAAQ,EACT,MAAM,YAAY,CAAC;AA2BpB,qBAAa,WAAY,SAAQ,SAAS;gBAC5B,MAAM,EAAE,MAAM;IAK1B,OAAO,CAAC,UAAU;IAoClB,aAAa,CACX,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,MAAM,EACrB,SAAS,EAAE,QAAQ,EAAE,EACrB,MAAM,EAAE,eAAe,GACtB,gBAAgB;IA0BnB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,gBAAgB,GAAG,IAAI;IAQ/C,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,CAKnC;IAEF,aAAa,CACX,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,QAAQ,GAAG,aAAa,GAAG,eAAe,CAAC,CAAC,GACzG,IAAI;IAMP,cAAc,CACZ,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,GAC3F,gBAAgB,EAAE;IA6BrB,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,gBAAgB,EAAE;IAavE,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,GAAG,IAAI;IAQ1D,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAU1C,OAAO,CAAC,YAAY;IAgBpB,OAAO,CAAC,YAAY;CAYrB"}
|