@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.
- package/JOY_ZONING.md +200 -0
- package/LICENSE.md +190 -0
- package/README.md +94 -0
- package/dist/cli-new/components/App.js +138 -0
- package/dist/cli-new/components/App.js.map +1 -0
- package/dist/cli-new/components/ApprovalDialog.js +31 -0
- package/dist/cli-new/components/ApprovalDialog.js.map +1 -0
- package/dist/cli-new/components/Banner.js +23 -0
- package/dist/cli-new/components/Banner.js.map +1 -0
- package/dist/cli-new/components/ChatArea.js +49 -0
- package/dist/cli-new/components/ChatArea.js.map +1 -0
- package/dist/cli-new/components/Header.js +20 -0
- package/dist/cli-new/components/Header.js.map +1 -0
- package/dist/cli-new/components/InputArea.js +97 -0
- package/dist/cli-new/components/InputArea.js.map +1 -0
- package/dist/cli-new/components/MessageBubble.js +114 -0
- package/dist/cli-new/components/MessageBubble.js.map +1 -0
- package/dist/cli-new/components/SessionSwitcher.js +46 -0
- package/dist/cli-new/components/SessionSwitcher.js.map +1 -0
- package/dist/cli-new/components/SetupWizard.js +283 -0
- package/dist/cli-new/components/SetupWizard.js.map +1 -0
- package/dist/cli-new/components/ToolCallDisplay.js +45 -0
- package/dist/cli-new/components/ToolCallDisplay.js.map +1 -0
- package/dist/cli-new/hooks/useGit.js +99 -0
- package/dist/cli-new/hooks/useGit.js.map +1 -0
- package/dist/cli-new/hooks/useMarie.js +249 -0
- package/dist/cli-new/hooks/useMarie.js.map +1 -0
- package/dist/cli-new/hooks/useSessions.js +75 -0
- package/dist/cli-new/hooks/useSessions.js.map +1 -0
- package/dist/cli-new/index.js +52 -0
- package/dist/cli-new/index.js.map +1 -0
- package/dist/cli-new/styles/theme.js +68 -0
- package/dist/cli-new/styles/theme.js.map +1 -0
- package/dist/cli-new/types/cli.js +2 -0
- package/dist/cli-new/types/cli.js.map +1 -0
- package/dist/extension.cjs +655 -0
- package/dist/monolith/adapters/CliMarieAdapter.js +72 -0
- package/dist/monolith/adapters/CliMarieAdapter.js.map +1 -0
- package/dist/monolith/adapters/VscodeMarieAdapter.js +81 -0
- package/dist/monolith/adapters/VscodeMarieAdapter.js.map +1 -0
- package/dist/monolith/cli/CliFileSystemPort.js +83 -0
- package/dist/monolith/cli/CliFileSystemPort.js.map +1 -0
- package/dist/monolith/cli/MarieToolDefinitionsCLI.js +438 -0
- package/dist/monolith/cli/MarieToolDefinitionsCLI.js.map +1 -0
- package/dist/monolith/cli/index.js +272 -0
- package/dist/monolith/cli/index.js.map +1 -0
- package/dist/monolith/cli/services/JoyAutomationServiceCLI.js +80 -0
- package/dist/monolith/cli/services/JoyAutomationServiceCLI.js.map +1 -0
- package/dist/monolith/cli/services/JoyServiceCLI.js +63 -0
- package/dist/monolith/cli/services/JoyServiceCLI.js.map +1 -0
- package/dist/monolith/cli/storage.js +119 -0
- package/dist/monolith/cli/storage.js.map +1 -0
- package/dist/monolith/domain/joy/JoyTools.js +513 -0
- package/dist/monolith/domain/joy/JoyTools.js.map +1 -0
- package/dist/monolith/domain/joy/RitualService.js +51 -0
- package/dist/monolith/domain/joy/RitualService.js.map +1 -0
- package/dist/monolith/domain/marie/MarieTypes.js +2 -0
- package/dist/monolith/domain/marie/MarieTypes.js.map +1 -0
- package/dist/monolith/infrastructure/ai/agents/MarieAscendant.js +230 -0
- package/dist/monolith/infrastructure/ai/agents/MarieAscendant.js.map +1 -0
- package/dist/monolith/infrastructure/ai/agents/MarieYOLO.js +207 -0
- package/dist/monolith/infrastructure/ai/agents/MarieYOLO.js.map +1 -0
- package/dist/monolith/infrastructure/ai/context/ContextArchiveService.js +129 -0
- package/dist/monolith/infrastructure/ai/context/ContextArchiveService.js.map +1 -0
- package/dist/monolith/infrastructure/ai/context/ContextManager.js +118 -0
- package/dist/monolith/infrastructure/ai/context/ContextManager.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/FileSystemPort.js +2 -0
- package/dist/monolith/infrastructure/ai/core/FileSystemPort.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/GhostPort.js +2 -0
- package/dist/monolith/infrastructure/ai/core/GhostPort.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieAscensionTypes.js +2 -0
- package/dist/monolith/infrastructure/ai/core/MarieAscensionTypes.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieEngine.js +590 -0
- package/dist/monolith/infrastructure/ai/core/MarieEngine.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieEventDispatcher.js +161 -0
- package/dist/monolith/infrastructure/ai/core/MarieEventDispatcher.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieLockManager.js +121 -0
- package/dist/monolith/infrastructure/ai/core/MarieLockManager.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieProgressTracker.js +256 -0
- package/dist/monolith/infrastructure/ai/core/MarieProgressTracker.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MariePulseService.js +67 -0
- package/dist/monolith/infrastructure/ai/core/MariePulseService.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieResponse.js +101 -0
- package/dist/monolith/infrastructure/ai/core/MarieResponse.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieSanitizer.js +86 -0
- package/dist/monolith/infrastructure/ai/core/MarieSanitizer.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieSession.js +202 -0
- package/dist/monolith/infrastructure/ai/core/MarieSession.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieStabilityMonitor.js +58 -0
- package/dist/monolith/infrastructure/ai/core/MarieStabilityMonitor.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieToolMender.js +127 -0
- package/dist/monolith/infrastructure/ai/core/MarieToolMender.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieToolProcessor.js +548 -0
- package/dist/monolith/infrastructure/ai/core/MarieToolProcessor.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/MarieYOLOTypes.js +2 -0
- package/dist/monolith/infrastructure/ai/core/MarieYOLOTypes.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/ReasoningBudget.js +125 -0
- package/dist/monolith/infrastructure/ai/core/ReasoningBudget.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js +30 -0
- package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js.map +1 -0
- package/dist/monolith/infrastructure/ai/providers/AIProvider.js +2 -0
- package/dist/monolith/infrastructure/ai/providers/AIProvider.js.map +1 -0
- package/dist/monolith/infrastructure/ai/providers/AnthropicProvider.js +148 -0
- package/dist/monolith/infrastructure/ai/providers/AnthropicProvider.js.map +1 -0
- package/dist/monolith/infrastructure/ai/providers/CerebrasProvider.js +208 -0
- package/dist/monolith/infrastructure/ai/providers/CerebrasProvider.js.map +1 -0
- package/dist/monolith/infrastructure/ai/providers/OpenRouterProvider.js +404 -0
- package/dist/monolith/infrastructure/ai/providers/OpenRouterProvider.js.map +1 -0
- package/dist/monolith/infrastructure/ai/providers/OpenRouterStreamParser.js +283 -0
- package/dist/monolith/infrastructure/ai/providers/OpenRouterStreamParser.js.map +1 -0
- package/dist/monolith/infrastructure/config/ConfigService.js +398 -0
- package/dist/monolith/infrastructure/config/ConfigService.js.map +1 -0
- package/dist/monolith/infrastructure/services/MarieMemoryStore.js +140 -0
- package/dist/monolith/infrastructure/services/MarieMemoryStore.js.map +1 -0
- package/dist/monolith/infrastructure/tools/MarieToolDefinitions.js +1568 -0
- package/dist/monolith/infrastructure/tools/MarieToolDefinitions.js.map +1 -0
- package/dist/monolith/infrastructure/tools/PureStreamParser.js +147 -0
- package/dist/monolith/infrastructure/tools/PureStreamParser.js.map +1 -0
- package/dist/monolith/infrastructure/tools/SharedToolDefinitions.js +223 -0
- package/dist/monolith/infrastructure/tools/SharedToolDefinitions.js.map +1 -0
- package/dist/monolith/infrastructure/tools/ToolRegistry.js +29 -0
- package/dist/monolith/infrastructure/tools/ToolRegistry.js.map +1 -0
- package/dist/monolith/infrastructure/tools/ToolUtils.js +59 -0
- package/dist/monolith/infrastructure/tools/ToolUtils.js.map +1 -0
- package/dist/monolith/plumbing/analysis/CodeHealthService.js +146 -0
- package/dist/monolith/plumbing/analysis/CodeHealthService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/ComplexityService.js +43 -0
- package/dist/monolith/plumbing/analysis/ComplexityService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/DependencyService.js +51 -0
- package/dist/monolith/plumbing/analysis/DependencyService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/DiscoveryService.js +49 -0
- package/dist/monolith/plumbing/analysis/DiscoveryService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/JoyMapService.js +66 -0
- package/dist/monolith/plumbing/analysis/JoyMapService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/LintService.js +132 -0
- package/dist/monolith/plumbing/analysis/LintService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/MarieSentinelService.js +276 -0
- package/dist/monolith/plumbing/analysis/MarieSentinelService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/QualityGuardrailService.js +119 -0
- package/dist/monolith/plumbing/analysis/QualityGuardrailService.js.map +1 -0
- package/dist/monolith/plumbing/analysis/SurgicalMender.js +70 -0
- package/dist/monolith/plumbing/analysis/SurgicalMender.js.map +1 -0
- package/dist/monolith/plumbing/analysis/TestService.js +104 -0
- package/dist/monolith/plumbing/analysis/TestService.js.map +1 -0
- package/dist/monolith/plumbing/filesystem/FileService.js +406 -0
- package/dist/monolith/plumbing/filesystem/FileService.js.map +1 -0
- package/dist/monolith/plumbing/filesystem/PathResolver.js +26 -0
- package/dist/monolith/plumbing/filesystem/PathResolver.js.map +1 -0
- package/dist/monolith/plumbing/git/GitService.js +71 -0
- package/dist/monolith/plumbing/git/GitService.js.map +1 -0
- package/dist/monolith/plumbing/lsp/SymbolService.js +36 -0
- package/dist/monolith/plumbing/lsp/SymbolService.js.map +1 -0
- package/dist/monolith/plumbing/terminal/ProcessRegistry.js +31 -0
- package/dist/monolith/plumbing/terminal/ProcessRegistry.js.map +1 -0
- package/dist/monolith/plumbing/terminal/TerminalService.js +180 -0
- package/dist/monolith/plumbing/terminal/TerminalService.js.map +1 -0
- package/dist/monolith/plumbing/ui/DecorationService.js +54 -0
- package/dist/monolith/plumbing/ui/DecorationService.js.map +1 -0
- package/dist/monolith/plumbing/utils/ErrorUtils.js +11 -0
- package/dist/monolith/plumbing/utils/ErrorUtils.js.map +1 -0
- package/dist/monolith/plumbing/utils/JsonUtils.js +360 -0
- package/dist/monolith/plumbing/utils/JsonUtils.js.map +1 -0
- package/dist/monolith/plumbing/utils/PrefixTree.js +153 -0
- package/dist/monolith/plumbing/utils/PrefixTree.js.map +1 -0
- package/dist/monolith/plumbing/utils/RetryUtils.js +141 -0
- package/dist/monolith/plumbing/utils/RetryUtils.js.map +1 -0
- package/dist/monolith/plumbing/utils/StreamTagDetector.js +128 -0
- package/dist/monolith/plumbing/utils/StreamTagDetector.js.map +1 -0
- package/dist/monolith/plumbing/utils/StringUtils.js +97 -0
- package/dist/monolith/plumbing/utils/StringUtils.js.map +1 -0
- package/dist/monolith/plumbing/utils/TimeoutUtils.js +21 -0
- package/dist/monolith/plumbing/utils/TimeoutUtils.js.map +1 -0
- package/dist/monolith/runtime/MarieRuntime.js +354 -0
- package/dist/monolith/runtime/MarieRuntime.js.map +1 -0
- package/dist/monolith/runtime/RuntimeAdapterBase.js +59 -0
- package/dist/monolith/runtime/RuntimeAdapterBase.js.map +1 -0
- package/dist/monolith/runtime/providerFactory.js +11 -0
- package/dist/monolith/runtime/providerFactory.js.map +1 -0
- package/dist/monolith/runtime/types.js +2 -0
- package/dist/monolith/runtime/types.js.map +1 -0
- package/dist/monolith/services/HealthService.js +38 -0
- package/dist/monolith/services/HealthService.js.map +1 -0
- package/dist/monolith/services/JoyAutomationService.js +131 -0
- package/dist/monolith/services/JoyAutomationService.js.map +1 -0
- package/dist/monolith/services/JoyLogService.js +48 -0
- package/dist/monolith/services/JoyLogService.js.map +1 -0
- package/dist/monolith/services/JoyService.js +190 -0
- package/dist/monolith/services/JoyService.js.map +1 -0
- package/dist/monolith/services/MarieGhostService.js +168 -0
- package/dist/monolith/services/MarieGhostService.js.map +1 -0
- package/dist/monolith/services/MarieSCMProvider.js +41 -0
- package/dist/monolith/services/MarieSCMProvider.js.map +1 -0
- 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"}
|