ralph-research 0.1.0 → 0.1.2
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/README.md +69 -0
- package/dist/adapters/extractor/command-extractor.js +46 -4
- package/dist/adapters/extractor/command-extractor.js.map +1 -1
- package/dist/adapters/fs/json-file-frontier-store.js +4 -2
- package/dist/adapters/fs/json-file-frontier-store.js.map +1 -1
- package/dist/adapters/fs/lockfile.d.ts +21 -1
- package/dist/adapters/fs/lockfile.js +65 -11
- package/dist/adapters/fs/lockfile.js.map +1 -1
- package/dist/adapters/fs/manifest-loader.d.ts +5 -1
- package/dist/adapters/fs/manifest-loader.js +15 -2
- package/dist/adapters/fs/manifest-loader.js.map +1 -1
- package/dist/adapters/git/git-client.d.ts +2 -0
- package/dist/adapters/git/git-client.js +19 -0
- package/dist/adapters/git/git-client.js.map +1 -1
- package/dist/app/services/manual-decision-service.js +76 -25
- package/dist/app/services/manual-decision-service.js.map +1 -1
- package/dist/app/services/project-state-service.d.ts +26 -1
- package/dist/app/services/project-state-service.js +172 -14
- package/dist/app/services/project-state-service.js.map +1 -1
- package/dist/app/services/run-admission-service.d.ts +20 -0
- package/dist/app/services/run-admission-service.js +30 -0
- package/dist/app/services/run-admission-service.js.map +1 -0
- package/dist/app/services/run-cycle-service.d.ts +5 -4
- package/dist/app/services/run-cycle-service.js +175 -14
- package/dist/app/services/run-cycle-service.js.map +1 -1
- package/dist/app/services/run-loop-service.d.ts +21 -0
- package/dist/app/services/run-loop-service.js +155 -0
- package/dist/app/services/run-loop-service.js.map +1 -0
- package/dist/cli/commands/demo.js +1 -0
- package/dist/cli/commands/demo.js.map +1 -1
- package/dist/cli/commands/doctor.d.ts +8 -0
- package/dist/cli/commands/doctor.js +59 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/init.js +1 -0
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/inspect.js +4 -0
- package/dist/cli/commands/inspect.js.map +1 -1
- package/dist/cli/commands/run.d.ts +3 -1
- package/dist/cli/commands/run.js +31 -28
- package/dist/cli/commands/run.js.map +1 -1
- package/dist/cli/commands/status.js +35 -4
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/validate.js +21 -18
- package/dist/cli/commands/validate.js.map +1 -1
- package/dist/cli/main.js +3 -10
- package/dist/cli/main.js.map +1 -1
- package/dist/core/engine/cycle-runner.d.ts +2 -0
- package/dist/core/engine/cycle-runner.js +504 -34
- package/dist/core/engine/cycle-runner.js.map +1 -1
- package/dist/core/engine/promotion-artifact.d.ts +23 -0
- package/dist/core/engine/promotion-artifact.js +58 -0
- package/dist/core/engine/promotion-artifact.js.map +1 -0
- package/dist/core/engine/workspace-manager.d.ts +10 -1
- package/dist/core/engine/workspace-manager.js +70 -3
- package/dist/core/engine/workspace-manager.js.map +1 -1
- package/dist/core/manifest/admission.d.ts +16 -0
- package/dist/core/manifest/admission.js +64 -0
- package/dist/core/manifest/admission.js.map +1 -0
- package/dist/core/manifest/schema.d.ts +47 -0
- package/dist/core/manifest/schema.js +18 -1
- package/dist/core/manifest/schema.js.map +1 -1
- package/dist/core/model/decision-record.d.ts +4 -0
- package/dist/core/model/decision-record.js +6 -0
- package/dist/core/model/decision-record.js.map +1 -1
- package/dist/core/model/metric-diagnostics.d.ts +7 -0
- package/dist/core/model/metric-diagnostics.js +51 -0
- package/dist/core/model/metric-diagnostics.js.map +1 -0
- package/dist/core/model/run-record.d.ts +6 -0
- package/dist/core/model/run-record.js +4 -0
- package/dist/core/model/run-record.js.map +1 -1
- package/dist/core/state/frontier-materializer.d.ts +12 -0
- package/dist/core/state/frontier-materializer.js +74 -0
- package/dist/core/state/frontier-materializer.js.map +1 -0
- package/dist/core/state/frontier-semantics.d.ts +12 -0
- package/dist/core/state/frontier-semantics.js +26 -0
- package/dist/core/state/frontier-semantics.js.map +1 -0
- package/dist/core/state/ratchet-engine.js +29 -21
- package/dist/core/state/ratchet-engine.js.map +1 -1
- package/dist/core/state/recovery-classifier.d.ts +17 -0
- package/dist/core/state/recovery-classifier.js +150 -0
- package/dist/core/state/recovery-classifier.js.map +1 -0
- package/dist/core/state/run-state-machine.js +33 -23
- package/dist/core/state/run-state-machine.js.map +1 -1
- package/dist/core/state/stopping-target.d.ts +14 -0
- package/dist/core/state/stopping-target.js +67 -0
- package/dist/core/state/stopping-target.js.map +1 -0
- package/dist/mcp/server.js +17 -23
- package/dist/mcp/server.js.map +1 -1
- package/package.json +2 -2
- package/templates/writing/ralph.yaml +7 -0
package/dist/cli/commands/run.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RunLoopService } from "../../app/services/run-loop-service.js";
|
|
2
2
|
const defaultCommandIO = {
|
|
3
3
|
stdout: (message) => {
|
|
4
4
|
process.stdout.write(`${message}\n`);
|
|
@@ -9,38 +9,39 @@ const defaultCommandIO = {
|
|
|
9
9
|
};
|
|
10
10
|
export async function runRunCommand(options, io = defaultCommandIO) {
|
|
11
11
|
try {
|
|
12
|
-
const service = new
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
io.stdout(JSON.stringify({ ok: false, results }, null, 2));
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
io.stderr(`Cycle ${index + 1} ended with status ${result.status}`);
|
|
28
|
-
}
|
|
29
|
-
return 1;
|
|
12
|
+
const service = new RunLoopService();
|
|
13
|
+
const result = await service.run({
|
|
14
|
+
repoRoot: process.cwd(),
|
|
15
|
+
...(options.path ? { manifestPath: options.path } : {}),
|
|
16
|
+
...(options.fresh ? { fresh: options.fresh } : {}),
|
|
17
|
+
...(options.cycles === undefined ? {} : { cycles: options.cycles }),
|
|
18
|
+
...(options.untilTarget ? { untilTarget: options.untilTarget } : {}),
|
|
19
|
+
...(options.untilNoImprove === undefined ? {} : { untilNoImprove: options.untilNoImprove }),
|
|
20
|
+
});
|
|
21
|
+
if (!options.json) {
|
|
22
|
+
for (const warning of result.warnings) {
|
|
23
|
+
io.stderr(warning);
|
|
30
24
|
}
|
|
31
25
|
}
|
|
32
26
|
if (options.json) {
|
|
33
27
|
io.stdout(JSON.stringify({
|
|
34
|
-
ok:
|
|
35
|
-
cycles,
|
|
36
|
-
|
|
28
|
+
ok: result.ok,
|
|
29
|
+
cycles: result.cycles,
|
|
30
|
+
cyclesExecuted: result.cyclesExecuted,
|
|
31
|
+
stopReason: result.stopReason,
|
|
32
|
+
warnings: result.warnings,
|
|
33
|
+
...(result.target ? { target: result.target } : {}),
|
|
34
|
+
results: result.results,
|
|
37
35
|
}, null, 2));
|
|
38
36
|
}
|
|
39
37
|
else {
|
|
40
|
-
const latest = results.at(-1);
|
|
41
|
-
io.stdout(
|
|
38
|
+
const latest = result.results.at(-1);
|
|
39
|
+
io.stdout([
|
|
40
|
+
`Executed ${result.cyclesExecuted} cycle(s); latest status=${latest?.status ?? "not_run"}`,
|
|
41
|
+
`stop: ${result.stopReason}`,
|
|
42
|
+
].join("\n"));
|
|
42
43
|
}
|
|
43
|
-
return 0;
|
|
44
|
+
return result.ok ? 0 : 1;
|
|
44
45
|
}
|
|
45
46
|
catch (error) {
|
|
46
47
|
const message = error instanceof Error ? error.message : "Failed to run cycle";
|
|
@@ -56,10 +57,12 @@ export async function runRunCommand(options, io = defaultCommandIO) {
|
|
|
56
57
|
export function registerRunCommand(program) {
|
|
57
58
|
program
|
|
58
59
|
.command("run")
|
|
59
|
-
.description("Run one or more research cycles.")
|
|
60
|
+
.description("Run one or more research cycles or keep iterating until a stop condition is met.")
|
|
60
61
|
.option("-p, --path <path>", "Path to the manifest file")
|
|
61
|
-
.option("-c, --cycles <count>", "
|
|
62
|
-
.option("--
|
|
62
|
+
.option("-c, --cycles <count>", "Exact cycle count, or a max-cycle cap when used with progressive stop flags", (value) => Number.parseInt(value, 10))
|
|
63
|
+
.option("--until-target", "Keep running until manifest.stopping.target is met", false)
|
|
64
|
+
.option("--until-no-improve <count>", "Stop after N consecutive cycles without frontier improvement", (value) => Number.parseInt(value, 10))
|
|
65
|
+
.option("--fresh", "Start a fresh run instead of auto-resuming the latest recoverable run", false)
|
|
63
66
|
.option("--json", "Emit machine-readable output", false)
|
|
64
67
|
.action(async (options) => {
|
|
65
68
|
const exitCode = await runRunCommand(options);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../../src/cli/commands/run.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../../src/cli/commands/run.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,12 +17,30 @@ export async function runStatusCommand(options, io = defaultCommandIO) {
|
|
|
17
17
|
io.stdout(JSON.stringify(status, null, 2));
|
|
18
18
|
}
|
|
19
19
|
else {
|
|
20
|
-
|
|
20
|
+
const lines = [
|
|
21
21
|
`manifest: ${status.manifestPath}`,
|
|
22
22
|
`latest run: ${status.latestRun?.runId ?? "none"} (${status.latestRun?.status ?? "n/a"})`,
|
|
23
|
-
`
|
|
24
|
-
`
|
|
25
|
-
]
|
|
23
|
+
`runtime: ${formatRuntimeSummary(status)}`,
|
|
24
|
+
`recovery: ${status.recovery.classification} (${status.recovery.nextAction})`,
|
|
25
|
+
];
|
|
26
|
+
if (status.runtime.pid !== undefined) {
|
|
27
|
+
lines.push(`pid: ${status.runtime.pid}`);
|
|
28
|
+
}
|
|
29
|
+
if (status.runtime.lastHeartbeatAt) {
|
|
30
|
+
lines.push(`heartbeat: ${status.runtime.lastHeartbeatAt}`);
|
|
31
|
+
}
|
|
32
|
+
if (status.runtime.currentStep !== "none") {
|
|
33
|
+
lines.push(`current step: ${status.runtime.currentStep}`);
|
|
34
|
+
}
|
|
35
|
+
if (status.runtime.currentStepStartedAt) {
|
|
36
|
+
lines.push(`current step started: ${status.runtime.currentStepStartedAt}`);
|
|
37
|
+
}
|
|
38
|
+
if (status.runtime.lastProgressAt) {
|
|
39
|
+
lines.push(`last progress: ${status.runtime.lastProgressAt}`);
|
|
40
|
+
}
|
|
41
|
+
lines.push(`frontier entries: ${status.frontier.length}`);
|
|
42
|
+
lines.push(`pending human: ${status.pendingHumanRuns.length}`);
|
|
43
|
+
io.stdout(lines.join("\n"));
|
|
26
44
|
}
|
|
27
45
|
return 0;
|
|
28
46
|
}
|
|
@@ -50,4 +68,17 @@ export function registerStatusCommand(program) {
|
|
|
50
68
|
}
|
|
51
69
|
});
|
|
52
70
|
}
|
|
71
|
+
function formatRuntimeSummary(status) {
|
|
72
|
+
const runtime = status.runtime;
|
|
73
|
+
if (runtime.state === "running") {
|
|
74
|
+
return "running (alive)";
|
|
75
|
+
}
|
|
76
|
+
if (runtime.state === "stale" && runtime.resumable) {
|
|
77
|
+
return "stale (resumable)";
|
|
78
|
+
}
|
|
79
|
+
if (runtime.state === "stopped") {
|
|
80
|
+
return `stopped (${runtime.reason})`;
|
|
81
|
+
}
|
|
82
|
+
return runtime.state;
|
|
83
|
+
}
|
|
53
84
|
//# sourceMappingURL=status.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../src/cli/commands/status.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../../src/cli/commands/status.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getRunAdmission } from "../../app/services/run-admission-service.js";
|
|
2
2
|
import { DEFAULT_MANIFEST_FILENAME } from "../../core/manifest/schema.js";
|
|
3
3
|
const defaultValidateCommandIO = {
|
|
4
4
|
stdout: (message) => {
|
|
@@ -10,32 +10,35 @@ const defaultValidateCommandIO = {
|
|
|
10
10
|
};
|
|
11
11
|
export async function runValidateCommand(options, io = defaultValidateCommandIO) {
|
|
12
12
|
try {
|
|
13
|
-
const
|
|
13
|
+
const admission = await getRunAdmission({
|
|
14
|
+
repoRoot: process.cwd(),
|
|
15
|
+
manifestPath: options.path,
|
|
16
|
+
});
|
|
17
|
+
if (admission.ok) {
|
|
18
|
+
if (options.json) {
|
|
19
|
+
io.stdout(JSON.stringify(admission, null, 2));
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
io.stdout(`Manifest is executable: ${admission.path}`);
|
|
23
|
+
}
|
|
24
|
+
return 0;
|
|
25
|
+
}
|
|
14
26
|
if (options.json) {
|
|
15
|
-
io.
|
|
16
|
-
ok: true,
|
|
17
|
-
path: loaded.path,
|
|
18
|
-
project: loaded.manifest.project.name,
|
|
19
|
-
schemaVersion: loaded.manifest.schemaVersion,
|
|
20
|
-
}, null, 2));
|
|
27
|
+
io.stderr(JSON.stringify(admission, null, 2));
|
|
21
28
|
}
|
|
22
29
|
else {
|
|
23
|
-
|
|
30
|
+
const details = admission.details ? `\n${JSON.stringify(admission.details, null, 2)}` : "";
|
|
31
|
+
io.stderr(`${admission.error}${details}`);
|
|
24
32
|
}
|
|
25
|
-
return
|
|
33
|
+
return 1;
|
|
26
34
|
}
|
|
27
35
|
catch (error) {
|
|
28
|
-
const message = error instanceof
|
|
29
|
-
const details = error instanceof ManifestLoadError && error.causeValue ? `\n${JSON.stringify(error.causeValue, null, 2)}` : "";
|
|
36
|
+
const message = error instanceof Error ? error.message : "Unknown validation error";
|
|
30
37
|
if (options.json) {
|
|
31
|
-
io.stderr(JSON.stringify({
|
|
32
|
-
ok: false,
|
|
33
|
-
error: message,
|
|
34
|
-
details: error instanceof ManifestLoadError ? error.causeValue : undefined,
|
|
35
|
-
}, null, 2));
|
|
38
|
+
io.stderr(JSON.stringify({ ok: false, executable: false, error: message }, null, 2));
|
|
36
39
|
}
|
|
37
40
|
else {
|
|
38
|
-
io.stderr(
|
|
41
|
+
io.stderr(message);
|
|
39
42
|
}
|
|
40
43
|
return 1;
|
|
41
44
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../../src/cli/commands/validate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../../src/cli/commands/validate.ts"],"names":[],"mappings":"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"}
|
package/dist/cli/main.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { Command } from "commander";
|
|
3
|
-
import { createAppContext } from "../app/context.js";
|
|
4
3
|
import { registerAcceptCommand } from "./commands/accept.js";
|
|
5
4
|
import { registerDemoCommand } from "./commands/demo.js";
|
|
5
|
+
import { registerDoctorCommand } from "./commands/doctor.js";
|
|
6
6
|
import { registerFrontierCommand } from "./commands/frontier.js";
|
|
7
7
|
import { registerInitCommand } from "./commands/init.js";
|
|
8
8
|
import { registerInspectCommand } from "./commands/inspect.js";
|
|
@@ -11,19 +11,12 @@ import { registerRunCommand } from "./commands/run.js";
|
|
|
11
11
|
import { registerServeMcpCommand } from "./commands/serve-mcp.js";
|
|
12
12
|
import { registerStatusCommand } from "./commands/status.js";
|
|
13
13
|
import { registerValidateCommand } from "./commands/validate.js";
|
|
14
|
-
import { logger } from "../shared/logger.js";
|
|
15
14
|
const program = new Command();
|
|
16
15
|
program
|
|
17
16
|
.name("rrx")
|
|
18
17
|
.description("Local-first runtime for recursive research improvement.")
|
|
19
|
-
.version("0.1.
|
|
20
|
-
program
|
|
21
|
-
.command("doctor")
|
|
22
|
-
.description("Print scaffold status.")
|
|
23
|
-
.action(() => {
|
|
24
|
-
const context = createAppContext();
|
|
25
|
-
logger.info({ appName: context.appName, phase: context.phase }, "scaffold ready");
|
|
26
|
-
});
|
|
18
|
+
.version("0.1.2");
|
|
19
|
+
registerDoctorCommand(program);
|
|
27
20
|
registerValidateCommand(program);
|
|
28
21
|
registerInitCommand(program);
|
|
29
22
|
registerDemoCommand(program);
|
package/dist/cli/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/cli/main.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../src/cli/main.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,KAAK,CAAC;KACX,WAAW,CAAC,yDAAyD,CAAC;KACtE,OAAO,CAAC,OAAO,CAAC,CAAC;AAEpB,qBAAqB,CAAC,OAAO,CAAC,CAAC;AAC/B,uBAAuB,CAAC,OAAO,CAAC,CAAC;AACjC,mBAAmB,CAAC,OAAO,CAAC,CAAC;AAC7B,mBAAmB,CAAC,OAAO,CAAC,CAAC;AAC7B,kBAAkB,CAAC,OAAO,CAAC,CAAC;AAC5B,qBAAqB,CAAC,OAAO,CAAC,CAAC;AAC/B,uBAAuB,CAAC,OAAO,CAAC,CAAC;AACjC,sBAAsB,CAAC,OAAO,CAAC,CAAC;AAChC,qBAAqB,CAAC,OAAO,CAAC,CAAC;AAC/B,qBAAqB,CAAC,OAAO,CAAC,CAAC;AAC/B,uBAAuB,CAAC,OAAO,CAAC,CAAC;AAEjC,MAAM,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC"}
|
|
@@ -24,7 +24,9 @@ export interface RunCycleInput {
|
|
|
24
24
|
repoRoot: string;
|
|
25
25
|
manifestPath: string;
|
|
26
26
|
manifest: RalphManifest;
|
|
27
|
+
resolvedBaselineRef: string;
|
|
27
28
|
currentFrontier: FrontierEntry[];
|
|
29
|
+
resumeRun?: RunRecord;
|
|
28
30
|
}
|
|
29
31
|
export type CycleRunStatus = "accepted" | "rejected" | "needs_human" | "failed";
|
|
30
32
|
export interface CycleRunResult {
|