@hongmaple0820/scale-engine 0.5.0 → 0.7.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.
Files changed (128) hide show
  1. package/LICENSE +15 -15
  2. package/README.md +64 -13
  3. package/dist/adapters/ClaudeCodeAdapter.d.ts +1 -1
  4. package/dist/adapters/ClaudeCodeAdapter.js +5 -3
  5. package/dist/adapters/ClaudeCodeAdapter.js.map +1 -1
  6. package/dist/adapters/CodexAdapter.js +33 -31
  7. package/dist/adapters/CodexAdapter.js.map +1 -1
  8. package/dist/adapters/CursorAdapter.js +5 -3
  9. package/dist/adapters/CursorAdapter.js.map +1 -1
  10. package/dist/adapters/GeminiAdapter.js +5 -3
  11. package/dist/adapters/GeminiAdapter.js.map +1 -1
  12. package/dist/adapters/HermesAdapter.js +5 -3
  13. package/dist/adapters/HermesAdapter.js.map +1 -1
  14. package/dist/adapters/OpenClawAdapter.js +5 -3
  15. package/dist/adapters/OpenClawAdapter.js.map +1 -1
  16. package/dist/adapters/OpenCodeAdapter.js +5 -3
  17. package/dist/adapters/OpenCodeAdapter.js.map +1 -1
  18. package/dist/adapters/QCoderAdapter.d.ts +13 -0
  19. package/dist/adapters/QCoderAdapter.js +155 -0
  20. package/dist/adapters/QCoderAdapter.js.map +1 -0
  21. package/dist/adapters/TraeAdapter.d.ts +13 -0
  22. package/dist/adapters/TraeAdapter.js +155 -0
  23. package/dist/adapters/TraeAdapter.js.map +1 -0
  24. package/dist/adapters/VSCAdapter.d.ts +13 -0
  25. package/dist/adapters/VSCAdapter.js +155 -0
  26. package/dist/adapters/VSCAdapter.js.map +1 -0
  27. package/dist/adapters/WorkBuddyAdapter.d.ts +13 -0
  28. package/dist/adapters/WorkBuddyAdapter.js +155 -0
  29. package/dist/adapters/WorkBuddyAdapter.js.map +1 -0
  30. package/dist/adapters/index.d.ts +4 -0
  31. package/dist/adapters/index.js +13 -1
  32. package/dist/adapters/index.js.map +1 -1
  33. package/dist/agents/AgentManager.d.ts +14 -0
  34. package/dist/agents/AgentManager.js +85 -0
  35. package/dist/agents/AgentManager.js.map +1 -0
  36. package/dist/agents/IAgent.d.ts +53 -0
  37. package/dist/agents/IAgent.js +4 -0
  38. package/dist/agents/IAgent.js.map +1 -0
  39. package/dist/agents/definitions/debugger.d.ts +2 -0
  40. package/dist/agents/definitions/debugger.js +6 -0
  41. package/dist/agents/definitions/debugger.js.map +1 -0
  42. package/dist/agents/definitions/doc-writer.d.ts +2 -0
  43. package/dist/agents/definitions/doc-writer.js +6 -0
  44. package/dist/agents/definitions/doc-writer.js.map +1 -0
  45. package/dist/agents/definitions/implementer.d.ts +2 -0
  46. package/dist/agents/definitions/implementer.js +6 -0
  47. package/dist/agents/definitions/implementer.js.map +1 -0
  48. package/dist/agents/definitions/planner.d.ts +2 -0
  49. package/dist/agents/definitions/planner.js +6 -0
  50. package/dist/agents/definitions/planner.js.map +1 -0
  51. package/dist/agents/definitions/researcher.d.ts +2 -0
  52. package/dist/agents/definitions/researcher.js +6 -0
  53. package/dist/agents/definitions/researcher.js.map +1 -0
  54. package/dist/agents/definitions/reviewer.d.ts +2 -0
  55. package/dist/agents/definitions/reviewer.js +6 -0
  56. package/dist/agents/definitions/reviewer.js.map +1 -0
  57. package/dist/agents/definitions/security.d.ts +2 -0
  58. package/dist/agents/definitions/security.js +6 -0
  59. package/dist/agents/definitions/security.js.map +1 -0
  60. package/dist/agents/definitions/tester.d.ts +2 -0
  61. package/dist/agents/definitions/tester.js +6 -0
  62. package/dist/agents/definitions/tester.js.map +1 -0
  63. package/dist/agents/definitions${file}.d.ts +1 -0
  64. package/dist/agents/definitions${file}.js +14 -0
  65. package/dist/agents/definitions${file}.js.map +1 -0
  66. package/dist/agents/index.d.ts +15 -0
  67. package/dist/agents/index.js +34 -0
  68. package/dist/agents/index.js.map +1 -0
  69. package/dist/api/cli.js +6 -5
  70. package/dist/api/cli.js.map +1 -1
  71. package/dist/api/doctor.js +29 -12
  72. package/dist/api/doctor.js.map +1 -1
  73. package/dist/api/mcp.js +0 -5
  74. package/dist/api/mcp.js.map +1 -1
  75. package/dist/artifact/fsm.d.ts +5 -0
  76. package/dist/artifact/fsm.js +25 -3
  77. package/dist/artifact/fsm.js.map +1 -1
  78. package/dist/artifact/sqliteStore.js +90 -103
  79. package/dist/artifact/sqliteStore.js.map +1 -1
  80. package/dist/artifact/store.js +2 -4
  81. package/dist/artifact/store.js.map +1 -1
  82. package/dist/artifact/types.d.ts +3 -3
  83. package/dist/artifact/types.js +0 -3
  84. package/dist/artifact/types.js.map +1 -1
  85. package/dist/context/ContextBuilder.js +1 -4
  86. package/dist/context/ContextBuilder.js.map +1 -1
  87. package/dist/core/container.js +4 -2
  88. package/dist/core/container.js.map +1 -1
  89. package/dist/core/eventBus.js +5 -6
  90. package/dist/core/eventBus.js.map +1 -1
  91. package/dist/dashboard/index.d.ts +2 -0
  92. package/dist/dashboard/index.js +2 -0
  93. package/dist/dashboard/index.js.map +1 -0
  94. package/dist/dashboard/server.d.ts +52 -0
  95. package/dist/dashboard/server.js +83 -0
  96. package/dist/dashboard/server.js.map +1 -0
  97. package/dist/evolution/BehaviorTracker.js +2 -3
  98. package/dist/evolution/BehaviorTracker.js.map +1 -1
  99. package/dist/evolution/EvolutionEngine.js +34 -45
  100. package/dist/evolution/EvolutionEngine.js.map +1 -1
  101. package/dist/evolution/PatternExtractor.d.ts +40 -0
  102. package/dist/evolution/PatternExtractor.js +83 -0
  103. package/dist/evolution/PatternExtractor.js.map +1 -0
  104. package/dist/evolution/SkillCreator.d.ts +40 -0
  105. package/dist/evolution/SkillCreator.js +118 -0
  106. package/dist/evolution/SkillCreator.js.map +1 -0
  107. package/dist/guardrails/Gateway.js +6 -7
  108. package/dist/guardrails/Gateway.js.map +1 -1
  109. package/dist/guardrails/advancedDetectors.d.ts +12 -0
  110. package/dist/guardrails/advancedDetectors.js +78 -28
  111. package/dist/guardrails/advancedDetectors.js.map +1 -1
  112. package/dist/guardrails/detectors.js +24 -14
  113. package/dist/guardrails/detectors.js.map +1 -1
  114. package/dist/index.d.ts +12 -1
  115. package/dist/index.js +11 -2
  116. package/dist/index.js.map +1 -1
  117. package/dist/knowledge/KnowledgeBase.js +2 -3
  118. package/dist/knowledge/KnowledgeBase.js.map +1 -1
  119. package/dist/knowledge/SQLiteKnowledgeBase.d.ts +28 -0
  120. package/dist/knowledge/SQLiteKnowledgeBase.js +175 -0
  121. package/dist/knowledge/SQLiteKnowledgeBase.js.map +1 -0
  122. package/dist/routing/ModelRouter.js +0 -2
  123. package/dist/routing/ModelRouter.js.map +1 -1
  124. package/dist/skills/SkillDiscovery.js +8 -1
  125. package/dist/skills/SkillDiscovery.js.map +1 -1
  126. package/dist/tasks/TaskEngine.js +25 -5
  127. package/dist/tasks/TaskEngine.js.map +1 -1
  128. package/package.json +8 -2
@@ -0,0 +1,155 @@
1
+ // SCALE Engine — WorkBuddy Adapter
2
+ // 生成 .workbuddy/settings.json + WORKBUDDY.md
3
+ // WorkBuddy: 腾讯 CodeBuddy 团队协作 AI (https://copilot.tencent.com/)
4
+ import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'node:fs';
5
+ import { join } from 'node:path';
6
+ import { logger } from '../core/logger.js';
7
+ // ============================================================================
8
+ // WorkBuddy Adapter
9
+ // ============================================================================
10
+ export class WorkBuddyAdapter {
11
+ constructor() {
12
+ this.agentType = 'workbuddy';
13
+ this.projectDir = '.';
14
+ this.scaleDir = '.scale';
15
+ }
16
+ getSettingsPath() {
17
+ return join(this.projectDir, '.workbuddy', 'settings.json');
18
+ }
19
+ getKnowledgeDocPath() {
20
+ return join(this.projectDir, 'WORKBUDDY.md');
21
+ }
22
+ isInstalled() {
23
+ return existsSync(join(this.projectDir, '.workbuddy'));
24
+ }
25
+ generateSettings() {
26
+ return {
27
+ hooks: {
28
+ 'pre-exec': [
29
+ { matcher: '', command: 'scale gate pre-tool Bash --args-json "$ARGS" --session-id "$SESSION_ID"' },
30
+ { matcher: 'edit|write', command: 'scale gate pre-tool Edit --args-json "$ARGS" --session-id "$SESSION_ID"' },
31
+ ],
32
+ 'post-exec': [
33
+ { matcher: 'edit|write', command: 'scale gate post-tool Edit --args-json "$ARGS" --exit-code "$EXIT_CODE" --session-id "$SESSION_ID"' },
34
+ { matcher: '', command: 'scale gate post-tool Bash --args-json "$ARGS" --exit-code "$EXIT_CODE" --session-id "$SESSION_ID"' },
35
+ ],
36
+ 'before-stop': [
37
+ { matcher: '', command: 'scale gate before-stop --session-id "$SESSION_ID"' },
38
+ ],
39
+ },
40
+ permissions: {
41
+ allow: ['scale:*'],
42
+ },
43
+ };
44
+ }
45
+ mergeSettings(existing) {
46
+ const generated = this.generateSettings();
47
+ const merged = { ...existing };
48
+ if (!merged.hooks)
49
+ merged.hooks = {};
50
+ for (const [hookType, entries] of Object.entries(generated.hooks)) {
51
+ if (!merged.hooks[hookType])
52
+ merged.hooks[hookType] = [];
53
+ for (const entry of entries) {
54
+ const alreadyExists = merged.hooks[hookType].some((e) => e.command.includes('scale '));
55
+ if (!alreadyExists) {
56
+ merged.hooks[hookType].push(entry);
57
+ }
58
+ }
59
+ }
60
+ if (!merged.permissions)
61
+ merged.permissions = {};
62
+ if (!merged.permissions.allow)
63
+ merged.permissions.allow = [];
64
+ for (const perm of generated.permissions.allow) {
65
+ if (!merged.permissions.allow.includes(perm)) {
66
+ merged.permissions.allow.push(perm);
67
+ }
68
+ }
69
+ return merged;
70
+ }
71
+ generateKnowledgeDoc(projectName, techStack = []) {
72
+ const stackLine = techStack.length > 0
73
+ ? `\n## Tech Stack\n${techStack.map((t) => `- ${t}`).join('\n')}\n`
74
+ : '';
75
+ return `# ${projectName}
76
+ ${stackLine}
77
+ ## SCALE Engine Integration (WorkBuddy)
78
+
79
+ This project uses SCALE Engine for AI engineering governance via WorkBuddy.
80
+
81
+ ### Commands
82
+ - \`scale create <type> <title>\` — Create artifact
83
+ - \`scale transition <id> <action>\` — Transition artifact state
84
+ - \`scale list --type Spec\` — List artifacts
85
+ - \`scale role activate <role>\` — Switch role
86
+ - \`scale doctor\` — Health check
87
+
88
+ ### Workflow
89
+ 1. **Explore** → Role: explorer (Read/Grep only)
90
+ 2. **Plan** → Create Spec → refine → approve (guard: ambiguity ≤ 0.2)
91
+ 3. **Implement** → Role: implementer (Edit/Write/Bash unlocked)
92
+ 4. **Verify** → Must run tests before claiming done
93
+ 5. **Learn** → Defects → Lessons → Rules → Hooks
94
+
95
+ ### Rules
96
+ - 🔴 Dangerous commands are physically blocked
97
+ - 🔴 Hardcoded secrets are blocked on Edit/Write
98
+ - 🟡 3 identical retries triggers brute-retry detection
99
+ - 🟡 Claiming done without running tests is blocked
100
+ - 🟢 All tool calls are tracked in .scale/events/
101
+ `;
102
+ }
103
+ async init(config) {
104
+ this.projectDir = config.projectDir;
105
+ this.scaleDir = config.scaleDir ?? join(config.projectDir, '.scale');
106
+ const created = [];
107
+ const skipped = [];
108
+ for (const dir of ['events', 'artifacts', 'rules', 'hooks', 'checkpoints']) {
109
+ const fullDir = join(this.scaleDir, dir);
110
+ if (!existsSync(fullDir)) {
111
+ mkdirSync(fullDir, { recursive: true });
112
+ created.push(fullDir);
113
+ }
114
+ else {
115
+ skipped.push(fullDir);
116
+ }
117
+ }
118
+ const workbuddyDir = join(this.projectDir, '.workbuddy');
119
+ mkdirSync(workbuddyDir, { recursive: true });
120
+ const settingsPath = this.getSettingsPath();
121
+ if (existsSync(settingsPath)) {
122
+ const existing = JSON.parse(readFileSync(settingsPath, 'utf-8'));
123
+ const merged = this.mergeSettings(existing);
124
+ writeFileSync(settingsPath, JSON.stringify(merged, null, 2), 'utf-8');
125
+ skipped.push(settingsPath + ' (merged)');
126
+ }
127
+ else {
128
+ writeFileSync(settingsPath, JSON.stringify(this.generateSettings(), null, 2), 'utf-8');
129
+ created.push(settingsPath);
130
+ }
131
+ const knowledgeDocPath = this.getKnowledgeDocPath();
132
+ if (!existsSync(knowledgeDocPath)) {
133
+ const projectName = config.projectDir.split(/[/\\]/).pop() ?? 'Project';
134
+ writeFileSync(knowledgeDocPath, this.generateKnowledgeDoc(projectName), 'utf-8');
135
+ created.push(knowledgeDocPath);
136
+ }
137
+ else {
138
+ skipped.push(knowledgeDocPath);
139
+ }
140
+ const gitignorePath = join(this.scaleDir, '.gitignore');
141
+ if (!existsSync(gitignorePath)) {
142
+ writeFileSync(gitignorePath, `*.db\n*.db-journal\nevents/\ncheckpoints/\nhooks/*.sh\n`, 'utf-8');
143
+ created.push(gitignorePath);
144
+ }
145
+ logger.info({ created: created.length, skipped: skipped.length }, 'SCALE init (workbuddy) completed');
146
+ return {
147
+ settingsPath,
148
+ knowledgeDocPath,
149
+ scaleDir: this.scaleDir,
150
+ created,
151
+ skipped,
152
+ };
153
+ }
154
+ }
155
+ //# sourceMappingURL=WorkBuddyAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WorkBuddyAdapter.js","sourceRoot":"","sources":["../../src/adapters/WorkBuddyAdapter.ts"],"names":[],"mappings":"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"}
@@ -8,6 +8,10 @@ export { CursorAdapter } from './CursorAdapter.js';
8
8
  export { GeminiAdapter } from './GeminiAdapter.js';
9
9
  export { OpenClawAdapter } from './OpenClawAdapter.js';
10
10
  export { HermesAdapter } from './HermesAdapter.js';
11
+ export { TraeAdapter } from './TraeAdapter.js';
12
+ export { WorkBuddyAdapter } from './WorkBuddyAdapter.js';
13
+ export { VSCAdapter } from './VSCAdapter.js';
14
+ export { QCoderAdapter } from './QCoderAdapter.js';
11
15
  /** All supported agent type identifiers */
12
16
  export declare const SUPPORTED_AGENTS: AgentPlatform[];
13
17
  /**
@@ -1,5 +1,5 @@
1
1
  // SCALE Engine — Unified Adapter Factory
2
- // 统一导出所有 7 种 Agent Adapter + createAdapter 工厂函数
2
+ // 统一导出所有 Agent Adapter + createAdapter 工厂函数
3
3
  import { ClaudeCodeAdapter } from './ClaudeCodeAdapter.js';
4
4
  import { CodexAdapter } from './CodexAdapter.js';
5
5
  import { OpenCodeAdapter } from './OpenCodeAdapter.js';
@@ -7,6 +7,10 @@ import { CursorAdapter } from './CursorAdapter.js';
7
7
  import { GeminiAdapter } from './GeminiAdapter.js';
8
8
  import { OpenClawAdapter } from './OpenClawAdapter.js';
9
9
  import { HermesAdapter } from './HermesAdapter.js';
10
+ import { TraeAdapter } from './TraeAdapter.js';
11
+ import { WorkBuddyAdapter } from './WorkBuddyAdapter.js';
12
+ import { VSCAdapter } from './VSCAdapter.js';
13
+ import { QCoderAdapter } from './QCoderAdapter.js';
10
14
  export { ClaudeCodeAdapter } from './ClaudeCodeAdapter.js';
11
15
  export { CodexAdapter } from './CodexAdapter.js';
12
16
  export { OpenCodeAdapter } from './OpenCodeAdapter.js';
@@ -14,6 +18,10 @@ export { CursorAdapter } from './CursorAdapter.js';
14
18
  export { GeminiAdapter } from './GeminiAdapter.js';
15
19
  export { OpenClawAdapter } from './OpenClawAdapter.js';
16
20
  export { HermesAdapter } from './HermesAdapter.js';
21
+ export { TraeAdapter } from './TraeAdapter.js';
22
+ export { WorkBuddyAdapter } from './WorkBuddyAdapter.js';
23
+ export { VSCAdapter } from './VSCAdapter.js';
24
+ export { QCoderAdapter } from './QCoderAdapter.js';
17
25
  // ============================================================================
18
26
  // Adapter Registry
19
27
  // ============================================================================
@@ -25,6 +33,10 @@ const ADAPTER_MAP = {
25
33
  'gemini': GeminiAdapter,
26
34
  'openclaw': OpenClawAdapter,
27
35
  'hermes': HermesAdapter,
36
+ 'trae': TraeAdapter,
37
+ 'workbuddy': WorkBuddyAdapter,
38
+ 'vsc': VSCAdapter,
39
+ 'qcoder': QCoderAdapter,
28
40
  };
29
41
  /** All supported agent type identifiers */
30
42
  export const SUPPORTED_AGENTS = Object.keys(ADAPTER_MAP);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,gDAAgD;AAGhD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAKlD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E,MAAM,WAAW,GAAmD;IAClE,aAAa,EAAE,iBAAiB;IAChC,OAAO,EAAE,YAAY;IACrB,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,aAAa;IACvB,QAAQ,EAAE,aAAa;IACvB,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,aAAa;CACxB,CAAA;AAED,2CAA2C;AAC3C,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAoB,CAAA;AAE3E;;;GAGG;AACH,MAAM,UAAU,aAAa,CAAC,SAAiB;IAC7C,MAAM,YAAY,GAAG,WAAW,CAAC,SAA0B,CAAC,CAAA;IAC5D,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CACb,4BAA4B,SAAS,iBAAiB,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACpF,CAAA;IACH,CAAC;IACD,OAAO,IAAI,YAAY,EAAE,CAAA;AAC3B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,4CAA4C;AAG5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAKlD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E,MAAM,WAAW,GAAmD;IAClE,aAAa,EAAE,iBAAiB;IAChC,OAAO,EAAE,YAAY;IACrB,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,aAAa;IACvB,QAAQ,EAAE,aAAa;IACvB,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,aAAa;IACvB,MAAM,EAAE,WAAW;IACnB,WAAW,EAAE,gBAAgB;IAC7B,KAAK,EAAE,UAAU;IACjB,QAAQ,EAAE,aAAa;CACxB,CAAA;AAED,2CAA2C;AAC3C,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAoB,CAAA;AAE3E;;;GAGG;AACH,MAAM,UAAU,aAAa,CAAC,SAAiB;IAC7C,MAAM,YAAY,GAAG,WAAW,CAAC,SAA0B,CAAC,CAAA;IAC5D,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CACb,4BAA4B,SAAS,iBAAiB,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACpF,CAAA;IACH,CAAC;IACD,OAAO,IAAI,YAAY,EAAE,CAAA;AAC3B,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type { IAgentManager, IAgent, AgentDefinition, AgentTaskContext, AgentResult } from './IAgent.js';
2
+ import { AGENT_MANAGER_TOKEN } from './IAgent.js';
3
+ export declare class AgentManager implements IAgentManager {
4
+ private agents;
5
+ private definitions;
6
+ register(definition: AgentDefinition, implementation?: IAgent): void;
7
+ findBestAgent(userInput: string): AgentDefinition | null;
8
+ dispatch(context: AgentTaskContext): Promise<AgentResult>;
9
+ listAll(): AgentDefinition[];
10
+ getById(id: string): IAgent | undefined;
11
+ hasHandler(userInput: string): boolean;
12
+ }
13
+ export declare function initializeAgentManager(): AgentManager;
14
+ export { AGENT_MANAGER_TOKEN };
@@ -0,0 +1,85 @@
1
+ // SCALE Engine — Agent Manager
2
+ // Purpose: Central registry and dispatcher for subagents
3
+ import { AGENT_MANAGER_TOKEN } from './IAgent.js';
4
+ import { container } from '../core/container.js';
5
+ import { logger } from '../core/logger.js';
6
+ class DefaultAgent {
7
+ constructor(definition) {
8
+ this.definition = definition;
9
+ }
10
+ canHandle(userInput) {
11
+ const lower = userInput.toLowerCase();
12
+ return this.definition.triggers.some((t) => lower.includes(t.toLowerCase()));
13
+ }
14
+ getConfidence(userInput) {
15
+ const lower = userInput.toLowerCase();
16
+ let matches = 0;
17
+ for (const trigger of this.definition.triggers) {
18
+ if (lower.includes(trigger.toLowerCase()))
19
+ matches++;
20
+ }
21
+ return Math.min(matches / this.definition.triggers.length, 1);
22
+ }
23
+ async execute(context) {
24
+ const start = Date.now();
25
+ logger.info('Agent ' + this.definition.id + ' executing: ' + context.userInput.slice(0, 50));
26
+ return {
27
+ success: true,
28
+ output: 'Agent ' + this.definition.name + ' processed task',
29
+ durationMs: Date.now() - start,
30
+ modelUsed: this.definition.modelPreference,
31
+ };
32
+ }
33
+ }
34
+ export class AgentManager {
35
+ constructor() {
36
+ this.agents = new Map();
37
+ this.definitions = new Map();
38
+ }
39
+ register(definition, implementation) {
40
+ const agent = implementation ?? new DefaultAgent(definition);
41
+ this.agents.set(definition.id, agent);
42
+ this.definitions.set(definition.id, definition);
43
+ logger.debug('Registered agent: ' + definition.id + ' (' + definition.name + ')');
44
+ }
45
+ findBestAgent(userInput) {
46
+ const candidates = [];
47
+ for (const def of this.definitions.values()) {
48
+ const agent = this.agents.get(def.id);
49
+ if (!agent)
50
+ continue;
51
+ if (agent.canHandle(userInput)) {
52
+ candidates.push({ def, confidence: agent.getConfidence(userInput) });
53
+ }
54
+ }
55
+ if (candidates.length === 0)
56
+ return null;
57
+ candidates.sort((a, b) => {
58
+ if (a.def.priority !== b.def.priority)
59
+ return b.def.priority - a.def.priority;
60
+ return b.confidence - a.confidence;
61
+ });
62
+ return candidates[0].def;
63
+ }
64
+ async dispatch(context) {
65
+ const best = this.findBestAgent(context.userInput);
66
+ if (!best) {
67
+ return { success: false, error: 'No agent available', durationMs: 0, modelUsed: 'none' };
68
+ }
69
+ const agent = this.agents.get(best.id);
70
+ if (!agent) {
71
+ return { success: false, error: 'Agent ' + best.id + ' not registered', durationMs: 0, modelUsed: 'none' };
72
+ }
73
+ return agent.execute(context);
74
+ }
75
+ listAll() { return Array.from(this.definitions.values()); }
76
+ getById(id) { return this.agents.get(id); }
77
+ hasHandler(userInput) { return this.findBestAgent(userInput) !== null; }
78
+ }
79
+ export function initializeAgentManager() {
80
+ const manager = new AgentManager();
81
+ container.registerInstance(AGENT_MANAGER_TOKEN, manager);
82
+ return manager;
83
+ }
84
+ export { AGENT_MANAGER_TOKEN };
85
+ //# sourceMappingURL=AgentManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentManager.js","sourceRoot":"","sources":["../../src/agents/AgentManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,53 @@
1
+ import type { ArtifactId } from '../artifact/types.js';
2
+ import type { Token } from '../core/container.js';
3
+ export interface AgentCapability {
4
+ name: string;
5
+ description: string;
6
+ inputs: string[];
7
+ outputs: string[];
8
+ }
9
+ export interface AgentTaskContext {
10
+ sessionId: string;
11
+ parentArtifactId?: ArtifactId;
12
+ userInput: string;
13
+ workingDirectory: string;
14
+ techStack?: string[];
15
+ constraints?: Record<string, unknown>;
16
+ }
17
+ export interface AgentResult {
18
+ success: boolean;
19
+ output?: string;
20
+ artifactsCreated?: ArtifactId[];
21
+ error?: string;
22
+ durationMs: number;
23
+ modelUsed: string;
24
+ tokensUsed?: number;
25
+ }
26
+ export interface AgentDefinition {
27
+ id: string;
28
+ name: string;
29
+ description: string;
30
+ triggers: string[];
31
+ capabilities: AgentCapability[];
32
+ toolAllowlist: string[];
33
+ toolDenylist?: string[];
34
+ modelPreference: 'haiku' | 'sonnet' | 'opus';
35
+ maxConcurrency: number;
36
+ timeoutMs?: number;
37
+ priority: number;
38
+ }
39
+ export interface IAgent {
40
+ readonly definition: AgentDefinition;
41
+ execute(context: AgentTaskContext): Promise<AgentResult>;
42
+ canHandle(userInput: string): boolean;
43
+ getConfidence(userInput: string): number;
44
+ }
45
+ export interface IAgentManager {
46
+ register(definition: AgentDefinition, implementation?: IAgent): void;
47
+ dispatch(context: AgentTaskContext): Promise<AgentResult>;
48
+ findBestAgent(userInput: string): AgentDefinition | null;
49
+ listAll(): AgentDefinition[];
50
+ getById(id: string): IAgent | undefined;
51
+ hasHandler(userInput: string): boolean;
52
+ }
53
+ export declare const AGENT_MANAGER_TOKEN: Token<IAgentManager>;
@@ -0,0 +1,4 @@
1
+ // SCALE Engine — Agent System Interface
2
+ // Purpose: Define contracts for subagent delegation
3
+ export const AGENT_MANAGER_TOKEN = Symbol('AgentManager');
4
+ //# sourceMappingURL=IAgent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IAgent.js","sourceRoot":"","sources":["../../src/agents/IAgent.ts"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,oDAAoD;AA6DpD,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAC,cAAc,CAAyB,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const DEBUGGER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const DEBUGGER_AGENT = {
2
+ id: 'debugger', name: 'Debugger', description: 'Debugging agent',
3
+ triggers: ['debug', 'fix'], capabilities: [{ name: 'debug', description: 'Debug', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Grep', 'Bash'], modelPreference: 'sonnet', maxConcurrency: 2, priority: 12,
5
+ };
6
+ //# sourceMappingURL=debugger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debugger.js","sourceRoot":"","sources":["../../../src/agents/definitions/debugger.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,cAAc,GAAoB;IAC7C,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,iBAAiB;IAChE,QAAQ,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC5G,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE;CACpG,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const DOC_WRITER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const DOC_WRITER_AGENT = {
2
+ id: 'doc-writer', name: 'Doc Writer', description: 'Documentation agent',
3
+ triggers: ['document', 'readme'], capabilities: [{ name: 'doc', description: 'Documentation', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Write'], modelPreference: 'haiku', maxConcurrency: 3, priority: 3,
5
+ };
6
+ //# sourceMappingURL=doc-writer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"doc-writer.js","sourceRoot":"","sources":["../../../src/agents/definitions/doc-writer.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,gBAAgB,GAAoB;IAC/C,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,WAAW,EAAE,qBAAqB;IACxE,QAAQ,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACxH,aAAa,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;CAC3F,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const IMPLEMENTER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const IMPLEMENTER_AGENT = {
2
+ id: 'implementer', name: 'Implementer', description: 'Implementation agent',
3
+ triggers: ['implement', 'code'], capabilities: [{ name: 'implement', description: 'Implement', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Edit', 'Write'], modelPreference: 'sonnet', maxConcurrency: 2, priority: 8,
5
+ };
6
+ //# sourceMappingURL=implementer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"implementer.js","sourceRoot":"","sources":["../../../src/agents/definitions/implementer.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,iBAAiB,GAAoB;IAChD,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,aAAa,EAAE,WAAW,EAAE,sBAAsB;IAC3E,QAAQ,EAAE,CAAC,WAAW,EAAE,MAAM,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACzH,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;CACpG,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const PLANNER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const PLANNER_AGENT = {
2
+ id: 'planner', name: 'Planner', description: 'Planning agent',
3
+ triggers: ['plan', 'design'], capabilities: [{ name: 'plan', description: 'Plan', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Grep'], modelPreference: 'opus', maxConcurrency: 1, priority: 10,
5
+ };
6
+ //# sourceMappingURL=planner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"planner.js","sourceRoot":"","sources":["../../../src/agents/definitions/planner.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,aAAa,GAAoB;IAC5C,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,gBAAgB;IAC7D,QAAQ,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC5G,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE;CAC1F,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const RESEARCHER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const RESEARCHER_AGENT = {
2
+ id: 'researcher', name: 'Researcher', description: 'Research agent',
3
+ triggers: ['search', 'find'], capabilities: [{ name: 'research', description: 'Research', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Glob', 'Grep'], modelPreference: 'haiku', maxConcurrency: 3, priority: 5,
5
+ };
6
+ //# sourceMappingURL=researcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"researcher.js","sourceRoot":"","sources":["../../../src/agents/definitions/researcher.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,gBAAgB,GAAoB;IAC/C,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,WAAW,EAAE,gBAAgB;IACnE,QAAQ,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACpH,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;CAC1F,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const REVIEWER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const REVIEWER_AGENT = {
2
+ id: 'reviewer', name: 'Reviewer', description: 'Review agent',
3
+ triggers: ['review', 'check'], capabilities: [{ name: 'review', description: 'Review', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Grep'], modelPreference: 'sonnet', maxConcurrency: 2, priority: 7,
5
+ };
6
+ //# sourceMappingURL=reviewer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reviewer.js","sourceRoot":"","sources":["../../../src/agents/definitions/reviewer.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,cAAc,GAAoB;IAC7C,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc;IAC7D,QAAQ,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACjH,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;CAC3F,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const SECURITY_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const SECURITY_AGENT = {
2
+ id: 'security', name: 'Security', description: 'Security agent',
3
+ triggers: ['security', 'audit'], capabilities: [{ name: 'security', description: 'Security', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Grep'], modelPreference: 'opus', maxConcurrency: 1, priority: 15,
5
+ };
6
+ //# sourceMappingURL=security.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"security.js","sourceRoot":"","sources":["../../../src/agents/definitions/security.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,cAAc,GAAoB;IAC7C,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB;IAC/D,QAAQ,EAAE,CAAC,UAAU,EAAE,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACvH,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE;CAC1F,CAAA"}
@@ -0,0 +1,2 @@
1
+ import type { AgentDefinition } from '../IAgent.js';
2
+ export declare const TESTER_AGENT: AgentDefinition;
@@ -0,0 +1,6 @@
1
+ export const TESTER_AGENT = {
2
+ id: 'tester', name: 'Tester', description: 'Testing agent',
3
+ triggers: ['test', 'tdd'], capabilities: [{ name: 'test', description: 'Test', inputs: [], outputs: [] }],
4
+ toolAllowlist: ['Read', 'Edit', 'Write', 'Bash'], modelPreference: 'sonnet', maxConcurrency: 2, priority: 9,
5
+ };
6
+ //# sourceMappingURL=tester.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tester.js","sourceRoot":"","sources":["../../../src/agents/definitions/tester.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,YAAY,GAAoB;IAC3C,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,eAAe;IAC1D,QAAQ,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACzG,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC;CAC5G,CAAA"}
@@ -0,0 +1 @@
1
+ export declare const $: any, file: any;
@@ -0,0 +1,14 @@
1
+ export const $, { file };
2
+ ^ ^ ;
3
+ _AGENT: AgentDefinition = {
4
+ id: '${file}',
5
+ name: '${file}',
6
+ description: 'Agent for ${file} tasks',
7
+ triggers: ['${file}'],
8
+ capabilities: [{ name: '${file}', description: '${file} capability', inputs: [], outputs: [] }],
9
+ toolAllowlist: ['Read', 'Grep'],
10
+ modelPreference: 'sonnet',
11
+ maxConcurrency: 1,
12
+ priority: 5,
13
+ };
14
+ //# sourceMappingURL=definitions$%7Bfile%7D.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"definitions${file}.js","sourceRoot":"","sources":["../../src/agents/definitions${file}.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,CAAC,EAAA,EAAC,IAAI,EAAA,CAAA;AAAA,GAAC,GAAC,CAAA;AAAC,MAAM,EAAE,eAAe,GAAG;IAC9C,EAAE,EAAE,SAAS;IACb,IAAI,EAAE,SAAS;IACf,WAAW,EAAE,yBAAyB;IACtC,QAAQ,EAAE,CAAC,SAAS,CAAC;IACrB,YAAY,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC/F,aAAa,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IAC/B,eAAe,EAAE,QAAQ;IACzB,cAAc,EAAE,CAAC;IACjB,QAAQ,EAAE,CAAC;CACZ,CAAA"}
@@ -0,0 +1,15 @@
1
+ export type { IAgentManager, IAgent, AgentDefinition, AgentTaskContext, AgentResult, AgentCapability, } from './IAgent.js';
2
+ export { AGENT_MANAGER_TOKEN } from './IAgent.js';
3
+ export { AgentManager, initializeAgentManager } from './AgentManager.js';
4
+ export { PLANNER_AGENT } from './definitions/planner.js';
5
+ export { RESEARCHER_AGENT } from './definitions/researcher.js';
6
+ export { IMPLEMENTER_AGENT } from './definitions/implementer.js';
7
+ export { REVIEWER_AGENT } from './definitions/reviewer.js';
8
+ export { TESTER_AGENT } from './definitions/tester.js';
9
+ export { SECURITY_AGENT } from './definitions/security.js';
10
+ export { DEBUGGER_AGENT } from './definitions/debugger.js';
11
+ export { DOC_WRITER_AGENT } from './definitions/doc-writer.js';
12
+ import type { AgentDefinition } from './IAgent.js';
13
+ export declare const ALL_AGENTS: AgentDefinition[];
14
+ import type { AgentManager } from './AgentManager.js';
15
+ export declare function registerAllAgents(manager: AgentManager): void;
@@ -0,0 +1,34 @@
1
+ // SCALE Engine — Agent System Entry Point
2
+ export { AGENT_MANAGER_TOKEN } from './IAgent.js';
3
+ export { AgentManager, initializeAgentManager } from './AgentManager.js';
4
+ export { PLANNER_AGENT } from './definitions/planner.js';
5
+ export { RESEARCHER_AGENT } from './definitions/researcher.js';
6
+ export { IMPLEMENTER_AGENT } from './definitions/implementer.js';
7
+ export { REVIEWER_AGENT } from './definitions/reviewer.js';
8
+ export { TESTER_AGENT } from './definitions/tester.js';
9
+ export { SECURITY_AGENT } from './definitions/security.js';
10
+ export { DEBUGGER_AGENT } from './definitions/debugger.js';
11
+ export { DOC_WRITER_AGENT } from './definitions/doc-writer.js';
12
+ import { PLANNER_AGENT } from './definitions/planner.js';
13
+ import { RESEARCHER_AGENT } from './definitions/researcher.js';
14
+ import { IMPLEMENTER_AGENT } from './definitions/implementer.js';
15
+ import { REVIEWER_AGENT } from './definitions/reviewer.js';
16
+ import { TESTER_AGENT } from './definitions/tester.js';
17
+ import { SECURITY_AGENT } from './definitions/security.js';
18
+ import { DEBUGGER_AGENT } from './definitions/debugger.js';
19
+ import { DOC_WRITER_AGENT } from './definitions/doc-writer.js';
20
+ export const ALL_AGENTS = [
21
+ PLANNER_AGENT,
22
+ RESEARCHER_AGENT,
23
+ IMPLEMENTER_AGENT,
24
+ REVIEWER_AGENT,
25
+ TESTER_AGENT,
26
+ SECURITY_AGENT,
27
+ DEBUGGER_AGENT,
28
+ DOC_WRITER_AGENT,
29
+ ];
30
+ export function registerAllAgents(manager) {
31
+ for (const def of ALL_AGENTS)
32
+ manager.register(def);
33
+ }
34
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/agents/index.ts"],"names":[],"mappings":"AAAA,0CAA0C;AAW1C,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAA;AAExE,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAA;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAA;AAE9D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAA;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAA;AAI9D,MAAM,CAAC,MAAM,UAAU,GAAsB;IAC3C,aAAa;IACb,gBAAgB;IAChB,iBAAiB;IACjB,cAAc;IACd,YAAY;IACZ,cAAc;IACd,cAAc;IACd,gBAAgB;CACjB,CAAA;AAID,MAAM,UAAU,iBAAiB,CAAC,OAAqB;IACrD,KAAK,MAAM,GAAG,IAAI,UAAU;QAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;AACrD,CAAC"}