@noorm/marie-cli 0.1.9 → 0.1.10
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/dist/extension.cjs +124 -123
- package/dist/monolith/adapters/VscodeMarieAdapter.js +1 -1
- package/dist/monolith/adapters/VscodeMarieAdapter.js.map +1 -1
- package/dist/monolith/cli/CliFileSystemPort.js +10 -0
- package/dist/monolith/cli/CliFileSystemPort.js.map +1 -1
- package/dist/monolith/cli/index.js +27 -2
- package/dist/monolith/cli/index.js.map +1 -1
- package/dist/monolith/cli/services/JoyServiceCLI.js.map +1 -1
- package/dist/monolith/infrastructure/ai/core/MarieEngine.js +20 -0
- package/dist/monolith/infrastructure/ai/core/MarieEngine.js.map +1 -1
- package/dist/monolith/infrastructure/ai/core/SessionLogService.js +58 -0
- package/dist/monolith/infrastructure/ai/core/SessionLogService.js.map +1 -0
- package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js +4 -1
- package/dist/monolith/infrastructure/ai/core/VscodeFileSystemPort.js.map +1 -1
- package/dist/monolith/plumbing/filesystem/FileService.js +37 -0
- package/dist/monolith/plumbing/filesystem/FileService.js.map +1 -1
- package/dist/monolith/runtime/MarieRuntime.js +3 -1
- package/dist/monolith/runtime/MarieRuntime.js.map +1 -1
- package/dist/monolith/services/JoyService.js +18 -0
- package/dist/monolith/services/JoyService.js.map +1 -1
- package/dist/monolith/tests/FileAppendVerifyTest.js +28 -0
- package/dist/monolith/tests/FileAppendVerifyTest.js.map +1 -0
- package/dist/monolith/tests/StreamingVerifyTest.js +39 -0
- package/dist/monolith/tests/StreamingVerifyTest.js.map +1 -0
- package/package.json +1 -1
|
@@ -5,6 +5,7 @@ export class JoyService {
|
|
|
5
5
|
context;
|
|
6
6
|
joyLog;
|
|
7
7
|
statusBarItem;
|
|
8
|
+
persistenceStatusBarItem;
|
|
8
9
|
_onJoyScoreChange = new vscode.EventEmitter();
|
|
9
10
|
onJoyScoreChange = this._onJoyScoreChange.event;
|
|
10
11
|
_onRunProgress = new vscode.EventEmitter();
|
|
@@ -15,7 +16,21 @@ export class JoyService {
|
|
|
15
16
|
this.context = context;
|
|
16
17
|
this.joyLog = joyLog;
|
|
17
18
|
this.statusBarItem = vscode.window.createStatusBarItem(vscode.StatusBarAlignment.Right, 100);
|
|
19
|
+
this.persistenceStatusBarItem = vscode.window.createStatusBarItem(vscode.StatusBarAlignment.Right, 101);
|
|
18
20
|
context.subscriptions.push(this.statusBarItem);
|
|
21
|
+
context.subscriptions.push(this.persistenceStatusBarItem);
|
|
22
|
+
// Listen to run progress for persistence updates
|
|
23
|
+
context.subscriptions.push(this.onRunProgress((e) => {
|
|
24
|
+
if (e.type === "session_persistence_update" && e.totalBytes !== undefined) {
|
|
25
|
+
const kb = (e.totalBytes / 1024).toFixed(1);
|
|
26
|
+
this.persistenceStatusBarItem.text = `$(sync~spin) ${kb} KB`;
|
|
27
|
+
this.persistenceStatusBarItem.tooltip = `Marie Session Persistence: ${kb} KB written to log.`;
|
|
28
|
+
this.persistenceStatusBarItem.show();
|
|
29
|
+
}
|
|
30
|
+
else if (e.type === "run_completed" || e.type === "run_error") {
|
|
31
|
+
this.persistenceStatusBarItem.hide();
|
|
32
|
+
}
|
|
33
|
+
}));
|
|
19
34
|
this.intention =
|
|
20
35
|
context.workspaceState.get("marie.intention") || null;
|
|
21
36
|
if (!process.env.MARIE_EXTENSION_TESTS) {
|
|
@@ -180,6 +195,9 @@ export class JoyService {
|
|
|
180
195
|
fileName.endsWith(".tsx") ||
|
|
181
196
|
fileName.endsWith(".jsx"));
|
|
182
197
|
}
|
|
198
|
+
fireRunProgress(progress) {
|
|
199
|
+
this._onRunProgress.fire(progress);
|
|
200
|
+
}
|
|
183
201
|
dispose() {
|
|
184
202
|
this.statusBarItem.dispose();
|
|
185
203
|
this._onJoyScoreChange.dispose();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JoyService.js","sourceRoot":"","sources":["../../../src/monolith/services/JoyService.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EACL,eAAe,GAEhB,MAAM,2CAA2C,CAAC;AAGnD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAE/E,MAAM,OAAO,UAAU;
|
|
1
|
+
{"version":3,"file":"JoyService.js","sourceRoot":"","sources":["../../../src/monolith/services/JoyService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import * as fs from "fs";
|
|
2
|
+
import * as path from "path";
|
|
3
|
+
import { appendToFile } from "../plumbing/filesystem/FileService.js";
|
|
4
|
+
async function verifyFileAppend() {
|
|
5
|
+
const testFile = path.join(process.cwd(), "test_append.txt");
|
|
6
|
+
if (fs.existsSync(testFile))
|
|
7
|
+
fs.unlinkSync(testFile);
|
|
8
|
+
console.log(`Verifying appendToFile for: ${testFile}`);
|
|
9
|
+
let totalBytesAppended = 0;
|
|
10
|
+
const onProgress = (b) => {
|
|
11
|
+
totalBytesAppended += b;
|
|
12
|
+
console.log(`Progress: +${b} bytes (Total: ${totalBytesAppended})`);
|
|
13
|
+
};
|
|
14
|
+
await appendToFile(testFile, "Line 1\n", undefined, onProgress);
|
|
15
|
+
await appendToFile(testFile, "Line 2\n", undefined, onProgress);
|
|
16
|
+
const content = fs.readFileSync(testFile, "utf-8");
|
|
17
|
+
console.log(`Content:\n${content}`);
|
|
18
|
+
if (content !== "Line 1\nLine 2\n") {
|
|
19
|
+
throw new Error("File append verification failed!");
|
|
20
|
+
}
|
|
21
|
+
console.log("✅ File append verification successful!");
|
|
22
|
+
fs.unlinkSync(testFile);
|
|
23
|
+
}
|
|
24
|
+
verifyFileAppend().catch(err => {
|
|
25
|
+
console.error("❌ Verification failed:", err);
|
|
26
|
+
process.exit(1);
|
|
27
|
+
});
|
|
28
|
+
//# sourceMappingURL=FileAppendVerifyTest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileAppendVerifyTest.js","sourceRoot":"","sources":["../../../src/monolith/tests/FileAppendVerifyTest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;AAErE,KAAK,UAAU,gBAAgB;IAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,iBAAiB,CAAC,CAAC;IAE7D,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;QAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAErD,OAAO,CAAC,GAAG,CAAC,+BAA+B,QAAQ,EAAE,CAAC,CAAC;IAEvD,IAAI,kBAAkB,GAAG,CAAC,CAAC;IAC3B,MAAM,UAAU,GAAG,CAAC,CAAS,EAAE,EAAE;QAC7B,kBAAkB,IAAI,CAAC,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,kBAAkB,kBAAkB,GAAG,CAAC,CAAC;IACxE,CAAC,CAAC;IAEF,MAAM,YAAY,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;IAChE,MAAM,YAAY,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;IAEhE,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACnD,OAAO,CAAC,GAAG,CAAC,aAAa,OAAO,EAAE,CAAC,CAAC;IAEpC,IAAI,OAAO,KAAK,kBAAkB,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;IACxD,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;IACtD,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AAC5B,CAAC;AAED,gBAAgB,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;IAC3B,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,GAAG,CAAC,CAAC;IAC7C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACpB,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import * as fs from "fs";
|
|
2
|
+
import * as path from "path";
|
|
3
|
+
import * as os from "os";
|
|
4
|
+
import { SessionLogService } from "../infrastructure/ai/core/SessionLogService.js";
|
|
5
|
+
async function verifyStreaming() {
|
|
6
|
+
const logService = SessionLogService.getInstance();
|
|
7
|
+
const sessionId = `test_persistence_${Date.now()}`;
|
|
8
|
+
logService.initializeSession(sessionId);
|
|
9
|
+
console.log(`Starting persistence verification for session: ${sessionId}`);
|
|
10
|
+
const events = [
|
|
11
|
+
{ type: "stage_update", stage: "thinking", stage_status: "active" },
|
|
12
|
+
{ type: "content_delta", text: "Hello" },
|
|
13
|
+
{ type: "content_delta", text: " world" },
|
|
14
|
+
{ type: "tool_call", tool: "read_file", input: { path: "foo.txt" } },
|
|
15
|
+
{ type: "run_completed" }
|
|
16
|
+
];
|
|
17
|
+
for (const event of events) {
|
|
18
|
+
await logService.appendEvent(event);
|
|
19
|
+
console.log(`Logged event: ${event.type}`);
|
|
20
|
+
}
|
|
21
|
+
const logPath = path.join(os.homedir(), ".marie", "logs", "sessions", `${sessionId}.jsonl`);
|
|
22
|
+
const content = fs.readFileSync(logPath, "utf-8");
|
|
23
|
+
const lines = content.trim().split("\n");
|
|
24
|
+
console.log(`Log Content Check: ${lines.length} lines persisted.`);
|
|
25
|
+
if (lines.length !== events.length) {
|
|
26
|
+
throw new Error(`Persistence mismatch! Expected ${events.length} lines, got ${lines.length}`);
|
|
27
|
+
}
|
|
28
|
+
// Verify recovery
|
|
29
|
+
const recoveredEvents = lines.map(l => JSON.parse(l));
|
|
30
|
+
if (recoveredEvents[1].text !== "Hello") {
|
|
31
|
+
throw new Error("Data integrity check failed!");
|
|
32
|
+
}
|
|
33
|
+
console.log("✅ High-integrity persistence verification successful!");
|
|
34
|
+
}
|
|
35
|
+
verifyStreaming().catch(err => {
|
|
36
|
+
console.error("❌ Verification failed:", err);
|
|
37
|
+
process.exit(1);
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=StreamingVerifyTest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StreamingVerifyTest.js","sourceRoot":"","sources":["../../../src/monolith/tests/StreamingVerifyTest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAEnF,KAAK,UAAU,eAAe;IAC1B,MAAM,UAAU,GAAG,iBAAiB,CAAC,WAAW,EAAE,CAAC;IACnD,MAAM,SAAS,GAAG,oBAAoB,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;IACnD,UAAU,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;IAExC,OAAO,CAAC,GAAG,CAAC,kDAAkD,SAAS,EAAE,CAAC,CAAC;IAE3E,MAAM,MAAM,GAAU;QAClB,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE;QACnE,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,OAAO,EAAE;QACxC,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,QAAQ,EAAE;QACzC,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE;QACpE,EAAE,IAAI,EAAE,eAAe,EAAE;KAC5B,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QACzB,MAAM,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QACpC,OAAO,CAAC,GAAG,CAAC,iBAAiB,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,SAAS,QAAQ,CAAC,CAAC;IAC5F,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAClD,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAEzC,OAAO,CAAC,GAAG,CAAC,sBAAsB,KAAK,CAAC,MAAM,mBAAmB,CAAC,CAAC;IAEnE,IAAI,KAAK,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CAAC,kCAAkC,MAAM,CAAC,MAAM,eAAe,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;IAClG,CAAC;IAED,kBAAkB;IAClB,MAAM,eAAe,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACtD,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IACpD,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,uDAAuD,CAAC,CAAC;AACzE,CAAC;AAED,eAAe,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;IAC1B,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,GAAG,CAAC,CAAC;IAC7C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACpB,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED