@noorm/marie-cli 0.1.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 (193) hide show
  1. package/JOY_ZONING.md +200 -0
  2. package/LICENSE.md +190 -0
  3. package/README.md +94 -0
  4. package/dist/cli-new/components/App.js +138 -0
  5. package/dist/cli-new/components/App.js.map +1 -0
  6. package/dist/cli-new/components/ApprovalDialog.js +31 -0
  7. package/dist/cli-new/components/ApprovalDialog.js.map +1 -0
  8. package/dist/cli-new/components/Banner.js +23 -0
  9. package/dist/cli-new/components/Banner.js.map +1 -0
  10. package/dist/cli-new/components/ChatArea.js +49 -0
  11. package/dist/cli-new/components/ChatArea.js.map +1 -0
  12. package/dist/cli-new/components/Header.js +20 -0
  13. package/dist/cli-new/components/Header.js.map +1 -0
  14. package/dist/cli-new/components/InputArea.js +97 -0
  15. package/dist/cli-new/components/InputArea.js.map +1 -0
  16. package/dist/cli-new/components/MessageBubble.js +114 -0
  17. package/dist/cli-new/components/MessageBubble.js.map +1 -0
  18. package/dist/cli-new/components/SessionSwitcher.js +46 -0
  19. package/dist/cli-new/components/SessionSwitcher.js.map +1 -0
  20. package/dist/cli-new/components/SetupWizard.js +283 -0
  21. package/dist/cli-new/components/SetupWizard.js.map +1 -0
  22. package/dist/cli-new/components/ToolCallDisplay.js +45 -0
  23. package/dist/cli-new/components/ToolCallDisplay.js.map +1 -0
  24. package/dist/cli-new/hooks/useGit.js +99 -0
  25. package/dist/cli-new/hooks/useGit.js.map +1 -0
  26. package/dist/cli-new/hooks/useMarie.js +249 -0
  27. package/dist/cli-new/hooks/useMarie.js.map +1 -0
  28. package/dist/cli-new/hooks/useSessions.js +75 -0
  29. package/dist/cli-new/hooks/useSessions.js.map +1 -0
  30. package/dist/cli-new/index.js +52 -0
  31. package/dist/cli-new/index.js.map +1 -0
  32. package/dist/cli-new/styles/theme.js +68 -0
  33. package/dist/cli-new/styles/theme.js.map +1 -0
  34. package/dist/cli-new/types/cli.js +2 -0
  35. package/dist/cli-new/types/cli.js.map +1 -0
  36. package/dist/extension.cjs +655 -0
  37. package/dist/monolith/adapters/CliMarieAdapter.js +72 -0
  38. package/dist/monolith/adapters/CliMarieAdapter.js.map +1 -0
  39. package/dist/monolith/adapters/VscodeMarieAdapter.js +81 -0
  40. package/dist/monolith/adapters/VscodeMarieAdapter.js.map +1 -0
  41. package/dist/monolith/cli/CliFileSystemPort.js +83 -0
  42. package/dist/monolith/cli/CliFileSystemPort.js.map +1 -0
  43. package/dist/monolith/cli/MarieToolDefinitionsCLI.js +438 -0
  44. package/dist/monolith/cli/MarieToolDefinitionsCLI.js.map +1 -0
  45. package/dist/monolith/cli/index.js +272 -0
  46. package/dist/monolith/cli/index.js.map +1 -0
  47. package/dist/monolith/cli/services/JoyAutomationServiceCLI.js +80 -0
  48. package/dist/monolith/cli/services/JoyAutomationServiceCLI.js.map +1 -0
  49. package/dist/monolith/cli/services/JoyServiceCLI.js +63 -0
  50. package/dist/monolith/cli/services/JoyServiceCLI.js.map +1 -0
  51. package/dist/monolith/cli/storage.js +119 -0
  52. package/dist/monolith/cli/storage.js.map +1 -0
  53. package/dist/monolith/domain/joy/JoyTools.js +513 -0
  54. package/dist/monolith/domain/joy/JoyTools.js.map +1 -0
  55. package/dist/monolith/domain/joy/RitualService.js +51 -0
  56. package/dist/monolith/domain/joy/RitualService.js.map +1 -0
  57. package/dist/monolith/domain/marie/MarieTypes.js +2 -0
  58. package/dist/monolith/domain/marie/MarieTypes.js.map +1 -0
  59. package/dist/monolith/infrastructure/ai/agents/MarieAscendant.js +230 -0
  60. package/dist/monolith/infrastructure/ai/agents/MarieAscendant.js.map +1 -0
  61. package/dist/monolith/infrastructure/ai/agents/MarieYOLO.js +207 -0
  62. package/dist/monolith/infrastructure/ai/agents/MarieYOLO.js.map +1 -0
  63. package/dist/monolith/infrastructure/ai/context/ContextArchiveService.js +129 -0
  64. package/dist/monolith/infrastructure/ai/context/ContextArchiveService.js.map +1 -0
  65. package/dist/monolith/infrastructure/ai/context/ContextManager.js +118 -0
  66. package/dist/monolith/infrastructure/ai/context/ContextManager.js.map +1 -0
  67. package/dist/monolith/infrastructure/ai/core/FileSystemPort.js +2 -0
  68. package/dist/monolith/infrastructure/ai/core/FileSystemPort.js.map +1 -0
  69. package/dist/monolith/infrastructure/ai/core/GhostPort.js +2 -0
  70. package/dist/monolith/infrastructure/ai/core/GhostPort.js.map +1 -0
  71. package/dist/monolith/infrastructure/ai/core/MarieAscensionTypes.js +2 -0
  72. package/dist/monolith/infrastructure/ai/core/MarieAscensionTypes.js.map +1 -0
  73. package/dist/monolith/infrastructure/ai/core/MarieEngine.js +590 -0
  74. package/dist/monolith/infrastructure/ai/core/MarieEngine.js.map +1 -0
  75. package/dist/monolith/infrastructure/ai/core/MarieEventDispatcher.js +161 -0
  76. package/dist/monolith/infrastructure/ai/core/MarieEventDispatcher.js.map +1 -0
  77. package/dist/monolith/infrastructure/ai/core/MarieLockManager.js +121 -0
  78. package/dist/monolith/infrastructure/ai/core/MarieLockManager.js.map +1 -0
  79. package/dist/monolith/infrastructure/ai/core/MarieProgressTracker.js +256 -0
  80. package/dist/monolith/infrastructure/ai/core/MarieProgressTracker.js.map +1 -0
  81. package/dist/monolith/infrastructure/ai/core/MariePulseService.js +67 -0
  82. package/dist/monolith/infrastructure/ai/core/MariePulseService.js.map +1 -0
  83. package/dist/monolith/infrastructure/ai/core/MarieResponse.js +101 -0
  84. package/dist/monolith/infrastructure/ai/core/MarieResponse.js.map +1 -0
  85. package/dist/monolith/infrastructure/ai/core/MarieSanitizer.js +86 -0
  86. package/dist/monolith/infrastructure/ai/core/MarieSanitizer.js.map +1 -0
  87. package/dist/monolith/infrastructure/ai/core/MarieSession.js +202 -0
  88. package/dist/monolith/infrastructure/ai/core/MarieSession.js.map +1 -0
  89. package/dist/monolith/infrastructure/ai/core/MarieStabilityMonitor.js +58 -0
  90. package/dist/monolith/infrastructure/ai/core/MarieStabilityMonitor.js.map +1 -0
  91. package/dist/monolith/infrastructure/ai/core/MarieToolMender.js +127 -0
  92. package/dist/monolith/infrastructure/ai/core/MarieToolMender.js.map +1 -0
  93. package/dist/monolith/infrastructure/ai/core/MarieToolProcessor.js +548 -0
  94. package/dist/monolith/infrastructure/ai/core/MarieToolProcessor.js.map +1 -0
  95. package/dist/monolith/infrastructure/ai/core/MarieYOLOTypes.js +2 -0
  96. package/dist/monolith/infrastructure/ai/core/MarieYOLOTypes.js.map +1 -0
  97. package/dist/monolith/infrastructure/ai/core/ReasoningBudget.js +125 -0
  98. package/dist/monolith/infrastructure/ai/core/ReasoningBudget.js.map +1 -0
  99. package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js +30 -0
  100. package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js.map +1 -0
  101. package/dist/monolith/infrastructure/ai/providers/AIProvider.js +2 -0
  102. package/dist/monolith/infrastructure/ai/providers/AIProvider.js.map +1 -0
  103. package/dist/monolith/infrastructure/ai/providers/AnthropicProvider.js +148 -0
  104. package/dist/monolith/infrastructure/ai/providers/AnthropicProvider.js.map +1 -0
  105. package/dist/monolith/infrastructure/ai/providers/CerebrasProvider.js +208 -0
  106. package/dist/monolith/infrastructure/ai/providers/CerebrasProvider.js.map +1 -0
  107. package/dist/monolith/infrastructure/ai/providers/OpenRouterProvider.js +404 -0
  108. package/dist/monolith/infrastructure/ai/providers/OpenRouterProvider.js.map +1 -0
  109. package/dist/monolith/infrastructure/ai/providers/OpenRouterStreamParser.js +283 -0
  110. package/dist/monolith/infrastructure/ai/providers/OpenRouterStreamParser.js.map +1 -0
  111. package/dist/monolith/infrastructure/config/ConfigService.js +398 -0
  112. package/dist/monolith/infrastructure/config/ConfigService.js.map +1 -0
  113. package/dist/monolith/infrastructure/services/MarieMemoryStore.js +140 -0
  114. package/dist/monolith/infrastructure/services/MarieMemoryStore.js.map +1 -0
  115. package/dist/monolith/infrastructure/tools/MarieToolDefinitions.js +1568 -0
  116. package/dist/monolith/infrastructure/tools/MarieToolDefinitions.js.map +1 -0
  117. package/dist/monolith/infrastructure/tools/PureStreamParser.js +147 -0
  118. package/dist/monolith/infrastructure/tools/PureStreamParser.js.map +1 -0
  119. package/dist/monolith/infrastructure/tools/SharedToolDefinitions.js +223 -0
  120. package/dist/monolith/infrastructure/tools/SharedToolDefinitions.js.map +1 -0
  121. package/dist/monolith/infrastructure/tools/ToolRegistry.js +29 -0
  122. package/dist/monolith/infrastructure/tools/ToolRegistry.js.map +1 -0
  123. package/dist/monolith/infrastructure/tools/ToolUtils.js +59 -0
  124. package/dist/monolith/infrastructure/tools/ToolUtils.js.map +1 -0
  125. package/dist/monolith/plumbing/analysis/CodeHealthService.js +146 -0
  126. package/dist/monolith/plumbing/analysis/CodeHealthService.js.map +1 -0
  127. package/dist/monolith/plumbing/analysis/ComplexityService.js +43 -0
  128. package/dist/monolith/plumbing/analysis/ComplexityService.js.map +1 -0
  129. package/dist/monolith/plumbing/analysis/DependencyService.js +51 -0
  130. package/dist/monolith/plumbing/analysis/DependencyService.js.map +1 -0
  131. package/dist/monolith/plumbing/analysis/DiscoveryService.js +49 -0
  132. package/dist/monolith/plumbing/analysis/DiscoveryService.js.map +1 -0
  133. package/dist/monolith/plumbing/analysis/JoyMapService.js +66 -0
  134. package/dist/monolith/plumbing/analysis/JoyMapService.js.map +1 -0
  135. package/dist/monolith/plumbing/analysis/LintService.js +132 -0
  136. package/dist/monolith/plumbing/analysis/LintService.js.map +1 -0
  137. package/dist/monolith/plumbing/analysis/MarieSentinelService.js +276 -0
  138. package/dist/monolith/plumbing/analysis/MarieSentinelService.js.map +1 -0
  139. package/dist/monolith/plumbing/analysis/QualityGuardrailService.js +119 -0
  140. package/dist/monolith/plumbing/analysis/QualityGuardrailService.js.map +1 -0
  141. package/dist/monolith/plumbing/analysis/SurgicalMender.js +70 -0
  142. package/dist/monolith/plumbing/analysis/SurgicalMender.js.map +1 -0
  143. package/dist/monolith/plumbing/analysis/TestService.js +104 -0
  144. package/dist/monolith/plumbing/analysis/TestService.js.map +1 -0
  145. package/dist/monolith/plumbing/filesystem/FileService.js +406 -0
  146. package/dist/monolith/plumbing/filesystem/FileService.js.map +1 -0
  147. package/dist/monolith/plumbing/filesystem/PathResolver.js +26 -0
  148. package/dist/monolith/plumbing/filesystem/PathResolver.js.map +1 -0
  149. package/dist/monolith/plumbing/git/GitService.js +71 -0
  150. package/dist/monolith/plumbing/git/GitService.js.map +1 -0
  151. package/dist/monolith/plumbing/lsp/SymbolService.js +36 -0
  152. package/dist/monolith/plumbing/lsp/SymbolService.js.map +1 -0
  153. package/dist/monolith/plumbing/terminal/ProcessRegistry.js +31 -0
  154. package/dist/monolith/plumbing/terminal/ProcessRegistry.js.map +1 -0
  155. package/dist/monolith/plumbing/terminal/TerminalService.js +180 -0
  156. package/dist/monolith/plumbing/terminal/TerminalService.js.map +1 -0
  157. package/dist/monolith/plumbing/ui/DecorationService.js +54 -0
  158. package/dist/monolith/plumbing/ui/DecorationService.js.map +1 -0
  159. package/dist/monolith/plumbing/utils/ErrorUtils.js +11 -0
  160. package/dist/monolith/plumbing/utils/ErrorUtils.js.map +1 -0
  161. package/dist/monolith/plumbing/utils/JsonUtils.js +360 -0
  162. package/dist/monolith/plumbing/utils/JsonUtils.js.map +1 -0
  163. package/dist/monolith/plumbing/utils/PrefixTree.js +153 -0
  164. package/dist/monolith/plumbing/utils/PrefixTree.js.map +1 -0
  165. package/dist/monolith/plumbing/utils/RetryUtils.js +141 -0
  166. package/dist/monolith/plumbing/utils/RetryUtils.js.map +1 -0
  167. package/dist/monolith/plumbing/utils/StreamTagDetector.js +128 -0
  168. package/dist/monolith/plumbing/utils/StreamTagDetector.js.map +1 -0
  169. package/dist/monolith/plumbing/utils/StringUtils.js +97 -0
  170. package/dist/monolith/plumbing/utils/StringUtils.js.map +1 -0
  171. package/dist/monolith/plumbing/utils/TimeoutUtils.js +21 -0
  172. package/dist/monolith/plumbing/utils/TimeoutUtils.js.map +1 -0
  173. package/dist/monolith/runtime/MarieRuntime.js +354 -0
  174. package/dist/monolith/runtime/MarieRuntime.js.map +1 -0
  175. package/dist/monolith/runtime/RuntimeAdapterBase.js +59 -0
  176. package/dist/monolith/runtime/RuntimeAdapterBase.js.map +1 -0
  177. package/dist/monolith/runtime/providerFactory.js +11 -0
  178. package/dist/monolith/runtime/providerFactory.js.map +1 -0
  179. package/dist/monolith/runtime/types.js +2 -0
  180. package/dist/monolith/runtime/types.js.map +1 -0
  181. package/dist/monolith/services/HealthService.js +38 -0
  182. package/dist/monolith/services/HealthService.js.map +1 -0
  183. package/dist/monolith/services/JoyAutomationService.js +131 -0
  184. package/dist/monolith/services/JoyAutomationService.js.map +1 -0
  185. package/dist/monolith/services/JoyLogService.js +48 -0
  186. package/dist/monolith/services/JoyLogService.js.map +1 -0
  187. package/dist/monolith/services/JoyService.js +190 -0
  188. package/dist/monolith/services/JoyService.js.map +1 -0
  189. package/dist/monolith/services/MarieGhostService.js +168 -0
  190. package/dist/monolith/services/MarieGhostService.js.map +1 -0
  191. package/dist/monolith/services/MarieSCMProvider.js +41 -0
  192. package/dist/monolith/services/MarieSCMProvider.js.map +1 -0
  193. package/package.json +168 -0
@@ -0,0 +1,161 @@
1
+ /**
2
+ * Routes raw AI events to the appropriate domain and UI handlers.
3
+ */
4
+ export class MarieEventDispatcher {
5
+ tracker;
6
+ ghostPort;
7
+ toolNames = new Map();
8
+ pendingContent = "";
9
+ pendingToolDeltas = new Map();
10
+ throttleTimer = null;
11
+ toolThrottleTimer = null;
12
+ THROTTLE_MS = 50;
13
+ TOOL_THROTTLE_MS = 100;
14
+ constructor(tracker, ghostPort) {
15
+ this.tracker = tracker;
16
+ this.ghostPort = ghostPort;
17
+ }
18
+ dispatch(event) {
19
+ const run = this.tracker.getRun();
20
+ switch (event.type) {
21
+ case "stage_change":
22
+ this.flushContent(); // Flush any pending content before stage change
23
+ this.updateStage(event);
24
+ break;
25
+ case "content_delta":
26
+ this.handleContentDelta(event, run);
27
+ break;
28
+ case "tool_call_delta":
29
+ this.handleToolDelta(event, run);
30
+ break;
31
+ case "usage":
32
+ this.flushContent();
33
+ run.usage = event.usage;
34
+ this.tracker.emitEvent({
35
+ type: "usage",
36
+ runId: run.runId,
37
+ usage: event.usage,
38
+ elapsedMs: this.tracker.elapsedMs(),
39
+ });
40
+ break;
41
+ }
42
+ }
43
+ handleContentDelta(event, run) {
44
+ this.pendingContent += event.text;
45
+ if (!this.throttleTimer) {
46
+ this.throttleTimer = setTimeout(() => {
47
+ this.flushContent();
48
+ }, this.THROTTLE_MS);
49
+ }
50
+ }
51
+ flushContent() {
52
+ if (!this.pendingContent)
53
+ return;
54
+ const text = this.pendingContent;
55
+ this.pendingContent = "";
56
+ this.throttleTimer = null;
57
+ const run = this.tracker.getRun(); // Re-fetch run to be safe
58
+ this.tracker.emitStream(text);
59
+ this.tracker.emitEvent({
60
+ type: "content_delta",
61
+ runId: run.runId,
62
+ text: text,
63
+ elapsedMs: this.tracker.elapsedMs(),
64
+ });
65
+ }
66
+ activeToolDelta(event, run) {
67
+ this.flushContent(); // Flush content before tool activity
68
+ if (event.argumentsDelta) {
69
+ const id = event.id || "default";
70
+ if (event.name) {
71
+ if (!this.toolNames.has(id)) {
72
+ this.toolNames.set(id, event.name);
73
+ }
74
+ }
75
+ const name = this.toolNames.get(id) || "";
76
+ this.tracker.emitEvent({
77
+ type: "tool_delta",
78
+ runId: run.runId,
79
+ name: name,
80
+ inputDelta: event.argumentsDelta,
81
+ elapsedMs: this.tracker.elapsedMs(),
82
+ });
83
+ if (this.ghostPort) {
84
+ this.ghostPort.handleDelta(id, name, event.argumentsDelta);
85
+ }
86
+ // Optimization: Only run regex if keywords are present
87
+ if (event.argumentsDelta.includes("path") ||
88
+ event.argumentsDelta.includes("file")) {
89
+ const pathMatch = event.argumentsDelta.match(/"path"\s*:\s*"([^"]*)"/);
90
+ if (pathMatch) {
91
+ run.activeFilePath = pathMatch[1];
92
+ this.tracker.emitProgressUpdate();
93
+ }
94
+ }
95
+ }
96
+ }
97
+ clear() {
98
+ this.toolNames.clear();
99
+ this.flushContent();
100
+ this.flushToolDeltas();
101
+ }
102
+ handleToolDelta(event, run) {
103
+ if (!event.argumentsDelta)
104
+ return;
105
+ const idx = event.index !== undefined ? String(event.index) : "default";
106
+ if (event.name && !this.toolNames.has(idx)) {
107
+ this.toolNames.set(idx, event.name);
108
+ }
109
+ const current = this.pendingToolDeltas.get(idx) || "";
110
+ this.pendingToolDeltas.set(idx, current + event.argumentsDelta);
111
+ if (!this.toolThrottleTimer) {
112
+ this.toolThrottleTimer = setTimeout(() => {
113
+ this.flushToolDeltas();
114
+ }, this.TOOL_THROTTLE_MS);
115
+ }
116
+ }
117
+ flushToolDeltas() {
118
+ const run = this.tracker.getRun();
119
+ for (const [idx, delta] of this.pendingToolDeltas.entries()) {
120
+ const name = this.toolNames.get(idx) || "";
121
+ this.tracker.emitEvent({
122
+ type: "tool_delta",
123
+ runId: run.runId,
124
+ name: name,
125
+ inputDelta: delta,
126
+ elapsedMs: this.tracker.elapsedMs(),
127
+ });
128
+ if (this.ghostPort) {
129
+ this.ghostPort.handleDelta(idx, name, delta);
130
+ }
131
+ if (delta.includes("path") || delta.includes("file")) {
132
+ const pathMatch = delta.match(/"path"\s*:\s*"([^"]*)"/);
133
+ if (pathMatch) {
134
+ run.activeFilePath = pathMatch[1];
135
+ this.tracker.emitProgressUpdate();
136
+ }
137
+ }
138
+ }
139
+ this.pendingToolDeltas.clear();
140
+ this.toolThrottleTimer = null;
141
+ }
142
+ updateStage(event) {
143
+ const run = this.tracker.getRun();
144
+ const stage = event.stage;
145
+ run.steps += 1;
146
+ if (["responding", "calling_tool", "editing"].includes(stage)) {
147
+ this.tracker.setObjectiveStatus("understand_request", "completed");
148
+ this.tracker.setObjectiveStatus("execute_plan", "in_progress", event.label || "Executing...");
149
+ run.activeObjectiveId = "execute_plan";
150
+ }
151
+ this.tracker.emitEvent({
152
+ type: "stage",
153
+ runId: run.runId,
154
+ stage,
155
+ label: event.label || stage,
156
+ elapsedMs: this.tracker.elapsedMs(),
157
+ });
158
+ this.tracker.emitProgressUpdate(event.label || `Stage: ${stage}`);
159
+ }
160
+ }
161
+ //# sourceMappingURL=MarieEventDispatcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarieEventDispatcher.js","sourceRoot":"","sources":["../../../../../src/monolith/infrastructure/ai/core/MarieEventDispatcher.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,121 @@
1
+ /**
2
+ * QUANTUM RESILIENCE: MarieLockManager
3
+ * Orchestrates multi-reader/single-writer locks for tool execution.
4
+ */
5
+ export class MarieLockManager {
6
+ tracker;
7
+ toolsInFlight = new Map();
8
+ constructor(tracker) {
9
+ this.tracker = tracker;
10
+ }
11
+ getLock(target) {
12
+ let lock = this.toolsInFlight.get(target);
13
+ if (!lock) {
14
+ lock = { write: null, reads: new Set() };
15
+ this.toolsInFlight.set(target, lock);
16
+ }
17
+ return lock;
18
+ }
19
+ async acquireLock(target, isWrite, signal, contextId) {
20
+ let lock = this.getLock(target);
21
+ // SELF-DEADLOCK PREVENTION (RE-ENTRANCY):
22
+ // If the current context already owns this lock for writing, we can proceed.
23
+ // Readers can always proceed if they are part of the same context.
24
+ if (contextId && lock.ownerContextId === contextId) {
25
+ return;
26
+ }
27
+ const startAcquire = Date.now();
28
+ const waitWithTimeout = async (promise) => {
29
+ if (!promise)
30
+ return;
31
+ const monitorId = setInterval(() => {
32
+ const elapsed = Date.now() - startAcquire;
33
+ if (elapsed > 5000) {
34
+ console.warn(`[MarieLockManager] SLOW LOCK: Acquisition on ${target} taking ${elapsed}ms...`);
35
+ if (this.tracker) {
36
+ this.tracker.emitEvent({
37
+ type: "reasoning",
38
+ runId: this.tracker.getRun().runId,
39
+ text: `⚠️ SLOW LOCK: Acquisition on ${target} is delayed...`,
40
+ elapsedMs: this.tracker.elapsedMs(),
41
+ });
42
+ }
43
+ }
44
+ }, 5000);
45
+ let timeoutId;
46
+ const timeout = new Promise((_, reject) => (timeoutId = setTimeout(() => reject(new Error(`Extreme Stability: Lock Acquisition Timeout on ${target}`)), 30000)));
47
+ try {
48
+ return await Promise.race([promise, timeout]);
49
+ }
50
+ finally {
51
+ clearInterval(monitorId);
52
+ clearTimeout(timeoutId);
53
+ }
54
+ };
55
+ if (isWrite) {
56
+ // Writer must wait for ALL reads AND any existing write
57
+ if (lock.write)
58
+ await waitWithTimeout(lock.write);
59
+ await waitWithTimeout(Promise.allSettled(Array.from(lock.reads)));
60
+ // Re-check after await to handle race conditions
61
+ lock = this.getLock(target);
62
+ while (lock.write || lock.reads.size > 0) {
63
+ if (signal?.aborted)
64
+ throw new Error("Aborted while waiting for lock");
65
+ if (lock.write)
66
+ await waitWithTimeout(lock.write);
67
+ if (lock.reads.size > 0)
68
+ await waitWithTimeout(Promise.allSettled(Array.from(lock.reads)));
69
+ lock = this.getLock(target);
70
+ }
71
+ }
72
+ else {
73
+ // Reader only waits for WRITE
74
+ if (lock.write)
75
+ await waitWithTimeout(lock.write);
76
+ }
77
+ }
78
+ registerExecution(target, isWrite, promise, contextId) {
79
+ const lock = this.getLock(target);
80
+ if (isWrite) {
81
+ lock.write = promise;
82
+ if (contextId)
83
+ lock.ownerContextId = contextId;
84
+ }
85
+ else {
86
+ lock.reads.add(promise);
87
+ }
88
+ promise.finally(() => {
89
+ this.releaseLock(target, isWrite, promise, contextId);
90
+ });
91
+ }
92
+ releaseLock(target, isWrite, promise, contextId) {
93
+ const lock = this.toolsInFlight.get(target);
94
+ if (!lock)
95
+ return;
96
+ if (isWrite) {
97
+ if (lock.write === promise) {
98
+ lock.write = null;
99
+ if (lock.ownerContextId === contextId)
100
+ lock.ownerContextId = undefined;
101
+ }
102
+ }
103
+ else {
104
+ lock.reads.delete(promise);
105
+ }
106
+ // Cleanup empty locks
107
+ if (!lock.write && lock.reads.size === 0) {
108
+ this.toolsInFlight.delete(target);
109
+ }
110
+ }
111
+ async waitForAll() {
112
+ const allPromises = [];
113
+ for (const lock of Array.from(this.toolsInFlight.values())) {
114
+ if (lock.write)
115
+ allPromises.push(lock.write);
116
+ lock.reads.forEach((p) => allPromises.push(p));
117
+ }
118
+ await Promise.allSettled(allPromises);
119
+ }
120
+ }
121
+ //# sourceMappingURL=MarieLockManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarieLockManager.js","sourceRoot":"","sources":["../../../../../src/monolith/infrastructure/ai/core/MarieLockManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,256 @@
1
+ import { MarieSanitizer } from "./MarieSanitizer.js";
2
+ export class MarieProgressTracker {
3
+ callbacks;
4
+ run;
5
+ // REASONING BUDGET: Prevent infinite reasoning growth
6
+ reasoningEventCount = 0;
7
+ reasoningCharCount = 0;
8
+ static MAX_REASONING_EVENTS_PER_TURN = 10;
9
+ static MAX_REASONING_CHARS_PER_TURN = 5000;
10
+ constructor(callbacks, run) {
11
+ this.callbacks = callbacks;
12
+ this.run = run;
13
+ }
14
+ /**
15
+ * Resets reasoning budget for new engine turn.
16
+ * Call this at the start of each chatLoop iteration.
17
+ */
18
+ resetReasoningBudget() {
19
+ this.reasoningEventCount = 0;
20
+ this.reasoningCharCount = 0;
21
+ }
22
+ /**
23
+ * Checks if reasoning budget is exhausted.
24
+ */
25
+ isReasoningBudgetExhausted() {
26
+ return (this.reasoningEventCount >=
27
+ MarieProgressTracker.MAX_REASONING_EVENTS_PER_TURN ||
28
+ this.reasoningCharCount >=
29
+ MarieProgressTracker.MAX_REASONING_CHARS_PER_TURN);
30
+ }
31
+ getRun() {
32
+ return this.run;
33
+ }
34
+ emitEvent(event) {
35
+ if (this.shouldDropEvent(event))
36
+ return;
37
+ // REASONING BUDGET ENFORCEMENT
38
+ if (event.type === "reasoning") {
39
+ // Check if budget is exhausted
40
+ if (this.isReasoningBudgetExhausted()) {
41
+ // Silently drop excess reasoning events
42
+ return;
43
+ }
44
+ // Track reasoning consumption
45
+ this.reasoningEventCount++;
46
+ const textLength = event.text?.length || 0;
47
+ this.reasoningCharCount += textLength;
48
+ // If this event would exceed char limit, truncate it
49
+ const remainingChars = MarieProgressTracker.MAX_REASONING_CHARS_PER_TURN -
50
+ this.reasoningCharCount;
51
+ if (remainingChars < 0 && event.text) {
52
+ event.text =
53
+ event.text.substring(0, Math.max(0, event.text.length + remainingChars)) + "... [truncated]";
54
+ this.reasoningCharCount =
55
+ MarieProgressTracker.MAX_REASONING_CHARS_PER_TURN;
56
+ }
57
+ }
58
+ const sanitizedEvent = MarieSanitizer.sanitize(event);
59
+ this.callbacks?.onEvent?.(sanitizedEvent);
60
+ }
61
+ eventCountInLastSecond = 0;
62
+ lastSecondTimestamp = Date.now();
63
+ shouldDropEvent(event) {
64
+ const now = Date.now();
65
+ if (now - this.lastSecondTimestamp > 1000) {
66
+ this.eventCountInLastSecond = 0;
67
+ this.lastSecondTimestamp = now;
68
+ }
69
+ this.eventCountInLastSecond++;
70
+ // Backpressure: If more than 100 events/sec, start dropping non-critical telemetry
71
+ // Content deltas should NEVER be dropped as they are the primary user output.
72
+ if (this.eventCountInLastSecond > 100) {
73
+ if (event.type === "reasoning" || event.type === "tool_delta") {
74
+ return true;
75
+ }
76
+ }
77
+ return false;
78
+ }
79
+ setObjectiveStatus(objectiveId, status, context) {
80
+ const objective = this.run.objectives.find((o) => o.id === objectiveId);
81
+ if (!objective)
82
+ return;
83
+ objective.status = status;
84
+ if (context)
85
+ objective.context = context;
86
+ }
87
+ setObjectiveEvidence(objectiveId, evidence) {
88
+ const objective = this.run.objectives.find((o) => o.id === objectiveId);
89
+ if (objective)
90
+ objective.verificationEvidence = evidence;
91
+ }
92
+ getPendingObjectives() {
93
+ return this.run.objectives.filter((o) => o.status !== "completed" && o.status !== "skipped");
94
+ }
95
+ recordAchievement(achievement) {
96
+ if (!this.run.achieved.includes(achievement)) {
97
+ this.run.achieved.push(achievement);
98
+ }
99
+ }
100
+ recordToolUsage(toolName) {
101
+ this.run.tools++;
102
+ if (!this.run.toolUsage) {
103
+ this.run.toolUsage = {};
104
+ }
105
+ this.run.toolUsage[toolName] = (this.run.toolUsage[toolName] || 0) + 1;
106
+ }
107
+ recordFileChange(file, added, removed) {
108
+ if (!this.run.codeStats) {
109
+ this.run.codeStats = { modifiedFiles: {} };
110
+ }
111
+ if (!this.run.codeStats.modifiedFiles[file]) {
112
+ this.run.codeStats.modifiedFiles[file] = { added: 0, removed: 0 };
113
+ }
114
+ this.run.codeStats.modifiedFiles[file].added += added;
115
+ this.run.codeStats.modifiedFiles[file].removed += removed;
116
+ }
117
+ recordHeuristicFix(toolName) {
118
+ if (!this.run.heuristicFixes)
119
+ this.run.heuristicFixes = [];
120
+ const msg = `Heuristic repair for ${toolName} ✨`;
121
+ if (!this.run.heuristicFixes.includes(msg)) {
122
+ this.run.heuristicFixes.push(msg);
123
+ this.emitProgressUpdate(msg);
124
+ }
125
+ }
126
+ updateDebounceTimer = null;
127
+ pendingUpdate = false;
128
+ emitStream(chunk) {
129
+ this.callbacks?.onStream?.(chunk, this.run.runId);
130
+ }
131
+ emitProgressUpdate(context) {
132
+ if (context) {
133
+ this.run.currentContext = context;
134
+ }
135
+ if (this.updateDebounceTimer) {
136
+ this.pendingUpdate = true;
137
+ return;
138
+ }
139
+ this.internalEmitProgress();
140
+ this.updateDebounceTimer = setTimeout(() => {
141
+ this.updateDebounceTimer = null;
142
+ if (this.pendingUpdate) {
143
+ this.pendingUpdate = false;
144
+ this.internalEmitProgress();
145
+ }
146
+ }, 150); // 150ms debounce for UI stability
147
+ }
148
+ lastObjectivesJson = "";
149
+ lastAchievedJson = "";
150
+ internalEmitProgress() {
151
+ const completed = this.run.objectives.filter((o) => o.status === "completed").length;
152
+ const completionPercent = this.run.objectives.length > 0
153
+ ? Math.round((completed / this.run.objectives.length) * 100)
154
+ : 0;
155
+ // PLANETARY STABILITY: Context Pressure Monitor
156
+ const totalLogs = this.run.logs?.length || 0;
157
+ const totalEvents = this.run.events?.length || 0;
158
+ const pressure = totalLogs + totalEvents;
159
+ if (pressure > 1000) {
160
+ this.emitEvent({
161
+ type: "reasoning",
162
+ runId: this.run.runId,
163
+ text: `⚠️ CONTEXT PRESSURE: ${pressure} items in memory. Trimming background telemetry...`,
164
+ elapsedMs: this.elapsedMs(),
165
+ });
166
+ // Prune events to keep RAM low (keep first 50 and last 100)
167
+ if (this.run.events && this.run.events.length > 500) {
168
+ this.run.events = [
169
+ ...this.run.events.slice(0, 50),
170
+ {
171
+ type: "reasoning",
172
+ text: "... [Planetary Pruning: Events recovered] ...",
173
+ },
174
+ ...this.run.events.slice(-100),
175
+ ];
176
+ }
177
+ // Prune logs to keep RAM low
178
+ if (this.run.logs && this.run.logs.length > 500) {
179
+ this.run.logs = [
180
+ ...this.run.logs.slice(0, 50),
181
+ {
182
+ type: "reasoning",
183
+ text: "... [Planetary Pruning: Logs recovered] ...",
184
+ },
185
+ ...this.run.logs.slice(-100),
186
+ ];
187
+ }
188
+ }
189
+ // SPECTRAL INTEGRITY: UI Delta Compression
190
+ const objectivesSnapshot = this.run.objectives.map((o) => ({ ...o }));
191
+ const currentObjectivesJson = JSON.stringify(objectivesSnapshot);
192
+ const achievedSnapshot = [...this.run.achieved];
193
+ const currentAchievedJson = JSON.stringify(achievedSnapshot);
194
+ const objectivesChanged = currentObjectivesJson !== this.lastObjectivesJson;
195
+ const achievedChanged = currentAchievedJson !== this.lastAchievedJson;
196
+ this.lastObjectivesJson = currentObjectivesJson;
197
+ this.lastAchievedJson = currentAchievedJson;
198
+ this.emitEvent({
199
+ type: "progress_update",
200
+ runId: this.run.runId,
201
+ completionPercent,
202
+ activeObjectiveId: this.run.activeObjectiveId,
203
+ activeToolName: this.run.activeToolName,
204
+ lastToolName: this.run.lastToolName,
205
+ objectives: objectivesChanged ? objectivesSnapshot : undefined, // Compact if unchanged
206
+ achieved: achievedChanged ? achievedSnapshot : undefined, // Compact if unchanged
207
+ context: this.run.currentContext,
208
+ lifecycleStage: this.run.lifecycleStage,
209
+ ritualComplete: this.run.ritualComplete,
210
+ activeFilePath: this.run.activeFilePath,
211
+ currentPass: this.run.currentPass,
212
+ totalPasses: this.run.totalPasses,
213
+ passFocus: this.run.passFocus,
214
+ isResuming: this.run.isResuming,
215
+ passHistory: this.run.passHistory ? [...this.run.passHistory] : undefined,
216
+ metrics: this.run.metrics ? { ...this.run.metrics } : undefined,
217
+ heuristicFixes: this.run.heuristicFixes
218
+ ? [...this.run.heuristicFixes]
219
+ : undefined,
220
+ ascensionState: this.run.ascensionState,
221
+ elapsedMs: Date.now() - this.run.startedAt,
222
+ });
223
+ }
224
+ flush() {
225
+ if (this.updateDebounceTimer) {
226
+ clearTimeout(this.updateDebounceTimer);
227
+ this.updateDebounceTimer = null;
228
+ }
229
+ this.pendingUpdate = false;
230
+ this.internalEmitProgress();
231
+ }
232
+ dispose() {
233
+ if (this.updateDebounceTimer) {
234
+ clearTimeout(this.updateDebounceTimer);
235
+ this.updateDebounceTimer = null;
236
+ }
237
+ }
238
+ emitPassTransition(currentPass, totalPasses, passFocus) {
239
+ this.run.currentPass = currentPass;
240
+ this.run.totalPasses = totalPasses;
241
+ this.run.passFocus = passFocus;
242
+ this.emitEvent({
243
+ type: "pass_transition",
244
+ runId: this.run.runId,
245
+ currentPass,
246
+ totalPasses,
247
+ passFocus,
248
+ elapsedMs: this.elapsedMs(),
249
+ });
250
+ this.emitProgressUpdate();
251
+ }
252
+ elapsedMs() {
253
+ return Date.now() - this.run.startedAt;
254
+ }
255
+ }
256
+ //# sourceMappingURL=MarieProgressTracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarieProgressTracker.js","sourceRoot":"","sources":["../../../../../src/monolith/infrastructure/ai/core/MarieProgressTracker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,67 @@
1
+ import { MarieGhostService } from "../../../services/MarieGhostService.js";
2
+ /**
3
+ * ATMOSPHERIC SEPARATION: MariePulseService
4
+ * Handles the engine's "vital signs": reasoning heartbeats, turn collision watchdogs,
5
+ * and global ghost resource cleanup.
6
+ */
7
+ export class MariePulseService {
8
+ tracker;
9
+ heartbeatTimer = null;
10
+ watchdogTimer = null;
11
+ constructor(tracker) {
12
+ this.tracker = tracker;
13
+ }
14
+ /**
15
+ * SUB-ATOMIC INTEGRITY: Reactive Lock Recovery
16
+ * If the engine lock is held for >120s, it's likely a zombie turn. Force-release.
17
+ */
18
+ startTurnWatchdog(onRecover) {
19
+ this.stopTurnWatchdog();
20
+ this.watchdogTimer = setTimeout(() => {
21
+ console.error("[MariePulseService] LOCK RECOVERY: AI Engine lock held for >120s. Force-releasing...");
22
+ this.tracker.emitEvent({
23
+ type: "reasoning",
24
+ runId: this.tracker.getRun().runId,
25
+ text: "🚨 LOCK RECOVERY: Stale reasoning process detected (>120s). Force-releasing engine lock.",
26
+ elapsedMs: this.tracker.elapsedMs(),
27
+ });
28
+ onRecover();
29
+ }, 120000);
30
+ return this.watchdogTimer;
31
+ }
32
+ stopTurnWatchdog() {
33
+ if (this.watchdogTimer) {
34
+ clearTimeout(this.watchdogTimer);
35
+ this.watchdogTimer = null;
36
+ }
37
+ }
38
+ /**
39
+ * REASONING HEARTBEAT: Detect AI hangs during streaming.
40
+ */
41
+ startHeartbeat() {
42
+ this.stopHeartbeat();
43
+ this.heartbeatTimer = setTimeout(() => {
44
+ this.tracker.emitEvent({
45
+ type: "reasoning",
46
+ runId: this.tracker.getRun().runId,
47
+ text: "🚨 PLANETARY STABILITY HAZARD: AI reasoning hang detected (>60s).",
48
+ elapsedMs: this.tracker.elapsedMs(),
49
+ });
50
+ }, 60000);
51
+ }
52
+ stopHeartbeat() {
53
+ if (this.heartbeatTimer) {
54
+ clearTimeout(this.heartbeatTimer);
55
+ this.heartbeatTimer = null;
56
+ }
57
+ }
58
+ /**
59
+ * GHOST GUARD: Absolute Resource Sanctity
60
+ */
61
+ cleanup() {
62
+ this.stopHeartbeat();
63
+ this.stopTurnWatchdog();
64
+ MarieGhostService.clearAll();
65
+ }
66
+ }
67
+ //# sourceMappingURL=MariePulseService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MariePulseService.js","sourceRoot":"","sources":["../../../../../src/monolith/infrastructure/ai/core/MariePulseService.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAE3E;;;;GAIG;AACH,MAAM,OAAO,iBAAiB;IAIR;IAHZ,cAAc,GAA0B,IAAI,CAAC;IAC7C,aAAa,GAA0B,IAAI,CAAC;IAEpD,YAAoB,OAA6B;QAA7B,YAAO,GAAP,OAAO,CAAsB;IAAG,CAAC;IAErD;;;OAGG;IACI,iBAAiB,CAAC,SAAqB;QAC5C,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,GAAG,EAAE;YACnC,OAAO,CAAC,KAAK,CACX,sFAAsF,CACvF,CAAC;YAEF,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;gBACrB,IAAI,EAAE,WAAW;gBACjB,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,KAAK;gBAClC,IAAI,EAAE,0FAA0F;gBAChG,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;aACpC,CAAC,CAAC;YAEH,SAAS,EAAE,CAAC;QACd,CAAC,EAAE,MAAM,CAAC,CAAC;QACX,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAEM,gBAAgB;QACrB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;IAED;;OAEG;IACI,cAAc;QACnB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YACpC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;gBACrB,IAAI,EAAE,WAAW;gBACjB,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,KAAK;gBAClC,IAAI,EAAE,mEAAmE;gBACzE,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;aACpC,CAAC,CAAC;QACL,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAEM,aAAa;QAClB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;IACH,CAAC;IAED;;OAEG;IACI,OAAO;QACZ,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,iBAAiB,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;CACF"}