@they-juanreina/compost-cli 0.1.0-rc.1
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/LICENSE +21 -0
- package/README.md +5 -0
- package/bin/compost.js +7 -0
- package/dist/commands/_stub.d.ts +9 -0
- package/dist/commands/_stub.d.ts.map +1 -0
- package/dist/commands/_stub.js +27 -0
- package/dist/commands/_stub.js.map +1 -0
- package/dist/commands/blame.d.ts +3 -0
- package/dist/commands/blame.d.ts.map +1 -0
- package/dist/commands/blame.js +31 -0
- package/dist/commands/blame.js.map +1 -0
- package/dist/commands/chat.d.ts +8 -0
- package/dist/commands/chat.d.ts.map +1 -0
- package/dist/commands/chat.js +99 -0
- package/dist/commands/chat.js.map +1 -0
- package/dist/commands/code.d.ts +3 -0
- package/dist/commands/code.d.ts.map +1 -0
- package/dist/commands/code.js +70 -0
- package/dist/commands/code.js.map +1 -0
- package/dist/commands/config.d.ts +3 -0
- package/dist/commands/config.d.ts.map +1 -0
- package/dist/commands/config.js +76 -0
- package/dist/commands/config.js.map +1 -0
- package/dist/commands/create.d.ts +20 -0
- package/dist/commands/create.d.ts.map +1 -0
- package/dist/commands/create.js +148 -0
- package/dist/commands/create.js.map +1 -0
- package/dist/commands/endorse.d.ts +3 -0
- package/dist/commands/endorse.d.ts.map +1 -0
- package/dist/commands/endorse.js +31 -0
- package/dist/commands/endorse.js.map +1 -0
- package/dist/commands/evals.d.ts +3 -0
- package/dist/commands/evals.d.ts.map +1 -0
- package/dist/commands/evals.js +54 -0
- package/dist/commands/evals.js.map +1 -0
- package/dist/commands/export.d.ts +3 -0
- package/dist/commands/export.d.ts.map +1 -0
- package/dist/commands/export.js +54 -0
- package/dist/commands/export.js.map +1 -0
- package/dist/commands/ingest.d.ts +3 -0
- package/dist/commands/ingest.d.ts.map +1 -0
- package/dist/commands/ingest.js +26 -0
- package/dist/commands/ingest.js.map +1 -0
- package/dist/commands/init.d.ts +3 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +51 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/migrate.d.ts +3 -0
- package/dist/commands/migrate.d.ts.map +1 -0
- package/dist/commands/migrate.js +28 -0
- package/dist/commands/migrate.js.map +1 -0
- package/dist/commands/models.d.ts +3 -0
- package/dist/commands/models.d.ts.map +1 -0
- package/dist/commands/models.js +32 -0
- package/dist/commands/models.js.map +1 -0
- package/dist/commands/query.d.ts +3 -0
- package/dist/commands/query.d.ts.map +1 -0
- package/dist/commands/query.js +13 -0
- package/dist/commands/query.js.map +1 -0
- package/dist/commands/reindex.d.ts +3 -0
- package/dist/commands/reindex.d.ts.map +1 -0
- package/dist/commands/reindex.js +53 -0
- package/dist/commands/reindex.js.map +1 -0
- package/dist/commands/rescan.d.ts +3 -0
- package/dist/commands/rescan.d.ts.map +1 -0
- package/dist/commands/rescan.js +60 -0
- package/dist/commands/rescan.js.map +1 -0
- package/dist/commands/saturate.d.ts +3 -0
- package/dist/commands/saturate.d.ts.map +1 -0
- package/dist/commands/saturate.js +35 -0
- package/dist/commands/saturate.js.map +1 -0
- package/dist/commands/search.d.ts +3 -0
- package/dist/commands/search.d.ts.map +1 -0
- package/dist/commands/search.js +52 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/serve.d.ts +3 -0
- package/dist/commands/serve.d.ts.map +1 -0
- package/dist/commands/serve.js +9 -0
- package/dist/commands/serve.js.map +1 -0
- package/dist/commands/session.d.ts +3 -0
- package/dist/commands/session.d.ts.map +1 -0
- package/dist/commands/session.js +25 -0
- package/dist/commands/session.js.map +1 -0
- package/dist/commands/setup.d.ts +3 -0
- package/dist/commands/setup.d.ts.map +1 -0
- package/dist/commands/setup.js +38 -0
- package/dist/commands/setup.js.map +1 -0
- package/dist/commands/snap.d.ts +3 -0
- package/dist/commands/snap.d.ts.map +1 -0
- package/dist/commands/snap.js +27 -0
- package/dist/commands/snap.js.map +1 -0
- package/dist/commands/status.d.ts +3 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +26 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/synthesize.d.ts +3 -0
- package/dist/commands/synthesize.d.ts.map +1 -0
- package/dist/commands/synthesize.js +13 -0
- package/dist/commands/synthesize.js.map +1 -0
- package/dist/commands/tag.d.ts +3 -0
- package/dist/commands/tag.d.ts.map +1 -0
- package/dist/commands/tag.js +46 -0
- package/dist/commands/tag.js.map +1 -0
- package/dist/commands/transcribe.d.ts +3 -0
- package/dist/commands/transcribe.d.ts.map +1 -0
- package/dist/commands/transcribe.js +110 -0
- package/dist/commands/transcribe.js.map +1 -0
- package/dist/commands/validate.d.ts +3 -0
- package/dist/commands/validate.d.ts.map +1 -0
- package/dist/commands/validate.js +81 -0
- package/dist/commands/validate.js.map +1 -0
- package/dist/commands/watch.d.ts +3 -0
- package/dist/commands/watch.d.ts.map +1 -0
- package/dist/commands/watch.js +50 -0
- package/dist/commands/watch.js.map +1 -0
- package/dist/errors.d.ts +9 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +12 -0
- package/dist/errors.js.map +1 -0
- package/dist/exporters/csv.d.ts +8 -0
- package/dist/exporters/csv.d.ts.map +1 -0
- package/dist/exporters/csv.js +44 -0
- package/dist/exporters/csv.js.map +1 -0
- package/dist/exporters/eaf.d.ts +3 -0
- package/dist/exporters/eaf.d.ts.map +1 -0
- package/dist/exporters/eaf.js +91 -0
- package/dist/exporters/eaf.js.map +1 -0
- package/dist/exporters/html.d.ts +8 -0
- package/dist/exporters/html.d.ts.map +1 -0
- package/dist/exporters/html.js +47 -0
- package/dist/exporters/html.js.map +1 -0
- package/dist/exporters/md.d.ts +3 -0
- package/dist/exporters/md.d.ts.map +1 -0
- package/dist/exporters/md.js +43 -0
- package/dist/exporters/md.js.map +1 -0
- package/dist/exporters/pdf.d.ts +9 -0
- package/dist/exporters/pdf.d.ts.map +1 -0
- package/dist/exporters/pdf.js +40 -0
- package/dist/exporters/pdf.js.map +1 -0
- package/dist/exporters/report.d.ts +43 -0
- package/dist/exporters/report.d.ts.map +1 -0
- package/dist/exporters/report.js +49 -0
- package/dist/exporters/report.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/legacy_client.d.ts +38 -0
- package/dist/legacy_client.d.ts.map +1 -0
- package/dist/legacy_client.js +44 -0
- package/dist/legacy_client.js.map +1 -0
- package/dist/lib/answerSchema.d.ts +2 -0
- package/dist/lib/answerSchema.d.ts.map +1 -0
- package/dist/lib/answerSchema.js +27 -0
- package/dist/lib/answerSchema.js.map +1 -0
- package/dist/lib/artifacts.d.ts +64 -0
- package/dist/lib/artifacts.d.ts.map +1 -0
- package/dist/lib/artifacts.js +254 -0
- package/dist/lib/artifacts.js.map +1 -0
- package/dist/lib/blame.d.ts +30 -0
- package/dist/lib/blame.d.ts.map +1 -0
- package/dist/lib/blame.js +164 -0
- package/dist/lib/blame.js.map +1 -0
- package/dist/lib/canonicalSessions.d.ts +24 -0
- package/dist/lib/canonicalSessions.d.ts.map +1 -0
- package/dist/lib/canonicalSessions.js +48 -0
- package/dist/lib/canonicalSessions.js.map +1 -0
- package/dist/lib/chat.d.ts +24 -0
- package/dist/lib/chat.d.ts.map +1 -0
- package/dist/lib/chat.js +50 -0
- package/dist/lib/chat.js.map +1 -0
- package/dist/lib/config.d.ts +45 -0
- package/dist/lib/config.d.ts.map +1 -0
- package/dist/lib/config.js +143 -0
- package/dist/lib/config.js.map +1 -0
- package/dist/lib/dispatch.d.ts +10 -0
- package/dist/lib/dispatch.d.ts.map +1 -0
- package/dist/lib/dispatch.js +31 -0
- package/dist/lib/dispatch.js.map +1 -0
- package/dist/lib/doctor.d.ts +19 -0
- package/dist/lib/doctor.d.ts.map +1 -0
- package/dist/lib/doctor.js +43 -0
- package/dist/lib/doctor.js.map +1 -0
- package/dist/lib/events.d.ts +42 -0
- package/dist/lib/events.d.ts.map +1 -0
- package/dist/lib/events.js +57 -0
- package/dist/lib/events.js.map +1 -0
- package/dist/lib/export.d.ts +14 -0
- package/dist/lib/export.d.ts.map +1 -0
- package/dist/lib/export.js +36 -0
- package/dist/lib/export.js.map +1 -0
- package/dist/lib/ingest.d.ts +21 -0
- package/dist/lib/ingest.d.ts.map +1 -0
- package/dist/lib/ingest.js +68 -0
- package/dist/lib/ingest.js.map +1 -0
- package/dist/lib/journal.d.ts +23 -0
- package/dist/lib/journal.d.ts.map +1 -0
- package/dist/lib/journal.js +95 -0
- package/dist/lib/journal.js.map +1 -0
- package/dist/lib/migrate.d.ts +29 -0
- package/dist/lib/migrate.d.ts.map +1 -0
- package/dist/lib/migrate.js +117 -0
- package/dist/lib/migrate.js.map +1 -0
- package/dist/lib/nativeRuntime.d.ts +46 -0
- package/dist/lib/nativeRuntime.d.ts.map +1 -0
- package/dist/lib/nativeRuntime.js +61 -0
- package/dist/lib/nativeRuntime.js.map +1 -0
- package/dist/lib/provisionNative.d.ts +46 -0
- package/dist/lib/provisionNative.d.ts.map +1 -0
- package/dist/lib/provisionNative.js +105 -0
- package/dist/lib/provisionNative.js.map +1 -0
- package/dist/lib/queue.d.ts +36 -0
- package/dist/lib/queue.d.ts.map +1 -0
- package/dist/lib/queue.js +102 -0
- package/dist/lib/queue.js.map +1 -0
- package/dist/lib/retrieve.d.ts +51 -0
- package/dist/lib/retrieve.d.ts.map +1 -0
- package/dist/lib/retrieve.js +92 -0
- package/dist/lib/retrieve.js.map +1 -0
- package/dist/lib/saturate.d.ts +21 -0
- package/dist/lib/saturate.d.ts.map +1 -0
- package/dist/lib/saturate.js +132 -0
- package/dist/lib/saturate.js.map +1 -0
- package/dist/lib/schemas.generated.d.ts +15 -0
- package/dist/lib/schemas.generated.d.ts.map +1 -0
- package/dist/lib/schemas.generated.js +975 -0
- package/dist/lib/schemas.generated.js.map +1 -0
- package/dist/lib/seed.d.ts +16 -0
- package/dist/lib/seed.d.ts.map +1 -0
- package/dist/lib/seed.js +64 -0
- package/dist/lib/seed.js.map +1 -0
- package/dist/lib/seedResolve.d.ts +6 -0
- package/dist/lib/seedResolve.d.ts.map +1 -0
- package/dist/lib/seedResolve.js +27 -0
- package/dist/lib/seedResolve.js.map +1 -0
- package/dist/lib/session.d.ts +19 -0
- package/dist/lib/session.d.ts.map +1 -0
- package/dist/lib/session.js +61 -0
- package/dist/lib/session.js.map +1 -0
- package/dist/lib/setup.d.ts +44 -0
- package/dist/lib/setup.d.ts.map +1 -0
- package/dist/lib/setup.js +249 -0
- package/dist/lib/setup.js.map +1 -0
- package/dist/lib/snap.d.ts +15 -0
- package/dist/lib/snap.d.ts.map +1 -0
- package/dist/lib/snap.js +115 -0
- package/dist/lib/snap.js.map +1 -0
- package/dist/lib/status.d.ts +39 -0
- package/dist/lib/status.d.ts.map +1 -0
- package/dist/lib/status.js +174 -0
- package/dist/lib/status.js.map +1 -0
- package/dist/lib/tagcode.d.ts +26 -0
- package/dist/lib/tagcode.d.ts.map +1 -0
- package/dist/lib/tagcode.js +231 -0
- package/dist/lib/tagcode.js.map +1 -0
- package/dist/lib/templates.d.ts +3 -0
- package/dist/lib/templates.d.ts.map +1 -0
- package/dist/lib/templates.js +21 -0
- package/dist/lib/templates.js.map +1 -0
- package/dist/lib/transcribeNative.d.ts +44 -0
- package/dist/lib/transcribeNative.d.ts.map +1 -0
- package/dist/lib/transcribeNative.js +53 -0
- package/dist/lib/transcribeNative.js.map +1 -0
- package/dist/lib/transcript.d.ts +68 -0
- package/dist/lib/transcript.d.ts.map +1 -0
- package/dist/lib/transcript.js +10 -0
- package/dist/lib/transcript.js.map +1 -0
- package/dist/lib/validate.d.ts +16 -0
- package/dist/lib/validate.d.ts.map +1 -0
- package/dist/lib/validate.js +155 -0
- package/dist/lib/validate.js.map +1 -0
- package/dist/llm/adapter.d.ts +33 -0
- package/dist/llm/adapter.d.ts.map +1 -0
- package/dist/llm/adapter.js +106 -0
- package/dist/llm/adapter.js.map +1 -0
- package/dist/llm/http.d.ts +9 -0
- package/dist/llm/http.d.ts.map +1 -0
- package/dist/llm/http.js +56 -0
- package/dist/llm/http.js.map +1 -0
- package/dist/llm/providers/anthropic.d.ts +14 -0
- package/dist/llm/providers/anthropic.d.ts.map +1 -0
- package/dist/llm/providers/anthropic.js +66 -0
- package/dist/llm/providers/anthropic.js.map +1 -0
- package/dist/llm/providers/lmstudio.d.ts +7 -0
- package/dist/llm/providers/lmstudio.d.ts.map +1 -0
- package/dist/llm/providers/lmstudio.js +8 -0
- package/dist/llm/providers/lmstudio.js.map +1 -0
- package/dist/llm/providers/ollama.d.ts +12 -0
- package/dist/llm/providers/ollama.d.ts.map +1 -0
- package/dist/llm/providers/ollama.js +87 -0
- package/dist/llm/providers/ollama.js.map +1 -0
- package/dist/llm/providers/openai.d.ts +7 -0
- package/dist/llm/providers/openai.d.ts.map +1 -0
- package/dist/llm/providers/openai.js +8 -0
- package/dist/llm/providers/openai.js.map +1 -0
- package/dist/llm/providers/openai_compatible.d.ts +18 -0
- package/dist/llm/providers/openai_compatible.d.ts.map +1 -0
- package/dist/llm/providers/openai_compatible.js +70 -0
- package/dist/llm/providers/openai_compatible.js.map +1 -0
- package/dist/llm/types.d.ts +60 -0
- package/dist/llm/types.d.ts.map +1 -0
- package/dist/llm/types.js +2 -0
- package/dist/llm/types.js.map +1 -0
- package/dist/logging.d.ts +22 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +58 -0
- package/dist/logging.js.map +1 -0
- package/dist/loops/embed_worker.d.ts +44 -0
- package/dist/loops/embed_worker.d.ts.map +1 -0
- package/dist/loops/embed_worker.js +144 -0
- package/dist/loops/embed_worker.js.map +1 -0
- package/dist/loops/eval_grader.d.ts +19 -0
- package/dist/loops/eval_grader.d.ts.map +1 -0
- package/dist/loops/eval_grader.js +22 -0
- package/dist/loops/eval_grader.js.map +1 -0
- package/dist/loops/ingest_watcher.d.ts +17 -0
- package/dist/loops/ingest_watcher.d.ts.map +1 -0
- package/dist/loops/ingest_watcher.js +66 -0
- package/dist/loops/ingest_watcher.js.map +1 -0
- package/dist/loops/legacy_worker.d.ts +26 -0
- package/dist/loops/legacy_worker.d.ts.map +1 -0
- package/dist/loops/legacy_worker.js +102 -0
- package/dist/loops/legacy_worker.js.map +1 -0
- package/dist/loops/supervisor.d.ts +71 -0
- package/dist/loops/supervisor.d.ts.map +1 -0
- package/dist/loops/supervisor.js +122 -0
- package/dist/loops/supervisor.js.map +1 -0
- package/dist/loops/synthesis.d.ts +31 -0
- package/dist/loops/synthesis.d.ts.map +1 -0
- package/dist/loops/synthesis.js +71 -0
- package/dist/loops/synthesis.js.map +1 -0
- package/dist/loops/transcribe_worker.d.ts +22 -0
- package/dist/loops/transcribe_worker.d.ts.map +1 -0
- package/dist/loops/transcribe_worker.js +77 -0
- package/dist/loops/transcribe_worker.js.map +1 -0
- package/dist/output.d.ts +8 -0
- package/dist/output.d.ts.map +1 -0
- package/dist/output.js +26 -0
- package/dist/output.js.map +1 -0
- package/dist/render/transcript_md.d.ts +5 -0
- package/dist/render/transcript_md.d.ts.map +1 -0
- package/dist/render/transcript_md.js +14 -0
- package/dist/render/transcript_md.js.map +1 -0
- package/dist/router.d.ts +3 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.js +68 -0
- package/dist/router.js.map +1 -0
- package/dist/transcriber_client.d.ts +42 -0
- package/dist/transcriber_client.d.ts.map +1 -0
- package/dist/transcriber_client.js +72 -0
- package/dist/transcriber_client.js.map +1 -0
- package/package.json +45 -0
- package/templates/AGENTS.md +25 -0
- package/templates/config.toml +56 -0
- package/templates/sample-seed/codebook/desire-for-manual-override.md +8 -0
- package/templates/sample-seed/codebook/distrust-of-automation.md +8 -0
- package/templates/sample-seed/highlights/H-001.md +9 -0
- package/templates/sample-seed/highlights/H-002.md +9 -0
- package/templates/sample-seed/seed.md +17 -0
- package/templates/sample-seed/sessions/S001/transcript.json +74 -0
- package/templates/sample-seed/synthesis/themes/control-earns-trust.md +13 -0
- package/templates/seed.md +21 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { isCompostError } from '../errors.js';
|
|
2
|
+
import { defaultResearcherId, endorseArtifact } from '../lib/artifacts.js';
|
|
3
|
+
import { resolveSeedPath } from '../lib/seedResolve.js';
|
|
4
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
5
|
+
export function registerEndorse(program) {
|
|
6
|
+
program
|
|
7
|
+
.command('endorse')
|
|
8
|
+
.description('Endorse an AI-suggested artifact — promotes it from [draft] to researcher-approved')
|
|
9
|
+
.argument('<artifact-ref>', 'Id from `compost create` (C-slug / H-NNN / T-slug), SHA256 prefix, or latest:<kind>=<seed>')
|
|
10
|
+
.option('--seed <name>', 'Seed (default: the only seed under ./Seeds)')
|
|
11
|
+
.option('--researcher <id>', 'Researcher identity (default: $COMPOST_USER)')
|
|
12
|
+
.action((artifactRef, flags, cmd) => {
|
|
13
|
+
const out = getOutputOpts(cmd);
|
|
14
|
+
try {
|
|
15
|
+
const seedPath = resolveSeedPath(process.cwd(), flags.seed);
|
|
16
|
+
const researcher = flags.researcher ?? defaultResearcherId();
|
|
17
|
+
const result = endorseArtifact(seedPath, artifactRef, researcher);
|
|
18
|
+
// A second endorse by the same researcher is a no-op (#169) — surface
|
|
19
|
+
// that distinctly so callers/scripts can tell "ok, just did it" from
|
|
20
|
+
// "ok, was already endorsed" without parsing event ids.
|
|
21
|
+
const status = result.already_endorsed === true ? 'already_endorsed' : 'ok';
|
|
22
|
+
emit({ status, command: 'endorse', researcher, ...result }, out);
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
if (isCompostError(err))
|
|
26
|
+
emitError(err, out);
|
|
27
|
+
throw err;
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=endorse.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"endorse.js","sourceRoot":"","sources":["../../src/commands/endorse.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAO7D,MAAM,UAAU,eAAe,CAAC,OAAgB;IAC9C,OAAO;SACJ,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CACV,oFAAoF,CACrF;SACA,QAAQ,CACP,gBAAgB,EAChB,4FAA4F,CAC7F;SACA,MAAM,CAAC,eAAe,EAAE,6CAA6C,CAAC;SACtE,MAAM,CAAC,mBAAmB,EAAE,8CAA8C,CAAC;SAC3E,MAAM,CAAC,CAAC,WAAmB,EAAE,KAAmB,EAAE,GAAY,EAAE,EAAE;QACjE,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,mBAAmB,EAAE,CAAA;YAC5D,MAAM,MAAM,GAAG,eAAe,CAAC,QAAQ,EAAE,WAAW,EAAE,UAAU,CAAC,CAAA;YACjE,sEAAsE;YACtE,qEAAqE;YACrE,wDAAwD;YACxD,MAAM,MAAM,GAAG,MAAM,CAAC,gBAAgB,KAAK,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAA;YAC3E,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,MAAM,EAAE,EAAE,GAAG,CAAC,CAAA;QAClE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evals.d.ts","sourceRoot":"","sources":["../../src/commands/evals.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAWxC,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAmDpD"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { runGolden, runHarness } from 'compost-evals';
|
|
2
|
+
import { isCompostError } from '../errors.js';
|
|
3
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
4
|
+
export function registerEvals(program) {
|
|
5
|
+
const evals = program.command('evals').description('Skill / suggestion / harness eval runners');
|
|
6
|
+
evals
|
|
7
|
+
.command('run')
|
|
8
|
+
.description('Run a golden-set eval for a skill (coverage / faithfulness / schema)')
|
|
9
|
+
.requiredOption('--skill <name>', 'querying-research-knowledge | thematic-coding | saturation-analysis')
|
|
10
|
+
.action(async (flags, cmd) => {
|
|
11
|
+
const out = getOutputOpts(cmd);
|
|
12
|
+
try {
|
|
13
|
+
// Identity runner: scores the golden expected outputs against themselves,
|
|
14
|
+
// establishing the harness + fixtures. A real skill runner is injected
|
|
15
|
+
// once the refactored skills (#51-53) are wired.
|
|
16
|
+
const result = await runGolden(flags.skill, (input) => input);
|
|
17
|
+
emit({ command: 'evals run', ...result }, out);
|
|
18
|
+
if (!result.passed)
|
|
19
|
+
process.exitCode = 1;
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
if (isCompostError(err))
|
|
23
|
+
emitError(err, out);
|
|
24
|
+
throw err;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
evals
|
|
28
|
+
.command('harness')
|
|
29
|
+
.description('Run the end-to-end harness eval suite (gates major releases)')
|
|
30
|
+
.action(async (_flags, cmd) => {
|
|
31
|
+
const out = getOutputOpts(cmd);
|
|
32
|
+
try {
|
|
33
|
+
// The real seed pipeline (ingest→transcribe→code→synthesize) is injected
|
|
34
|
+
// here once it can run headless in CI; until then the harness reports the
|
|
35
|
+
// diff against expected and exits non-zero, so it gates releases honestly.
|
|
36
|
+
const result = await runHarness(async () => ({}));
|
|
37
|
+
emit({
|
|
38
|
+
command: 'evals harness',
|
|
39
|
+
...result,
|
|
40
|
+
note: result.passed
|
|
41
|
+
? undefined
|
|
42
|
+
: 'seed pipeline not yet wired into the harness; fixtures + diff machinery are in place',
|
|
43
|
+
}, out);
|
|
44
|
+
if (!result.passed)
|
|
45
|
+
process.exitCode = 1;
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
if (isCompostError(err))
|
|
49
|
+
emitError(err, out);
|
|
50
|
+
throw err;
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=evals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evals.js","sourceRoot":"","sources":["../../src/commands/evals.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAErD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAM7D,MAAM,UAAU,aAAa,CAAC,OAAgB;IAC5C,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,2CAA2C,CAAC,CAAA;IAE/F,KAAK;SACF,OAAO,CAAC,KAAK,CAAC;SACd,WAAW,CAAC,sEAAsE,CAAC;SACnF,cAAc,CACb,gBAAgB,EAChB,qEAAqE,CACtE;SACA,MAAM,CAAC,KAAK,EAAE,KAAe,EAAE,GAAY,EAAE,EAAE;QAC9C,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,0EAA0E;YAC1E,uEAAuE;YACvE,iDAAiD;YACjD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,KAAc,EAAE,EAAE,CAAC,KAAK,CAAC,CAAA;YACtE,IAAI,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,MAAM,EAAE,EAAE,GAAG,CAAC,CAAA;YAC9C,IAAI,CAAC,MAAM,CAAC,MAAM;gBAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;QAC1C,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;IAEJ,KAAK;SACF,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,8DAA8D,CAAC;SAC3E,MAAM,CAAC,KAAK,EAAE,MAAe,EAAE,GAAY,EAAE,EAAE;QAC9C,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,yEAAyE;YACzE,0EAA0E;YAC1E,2EAA2E;YAC3E,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;YACjD,IAAI,CACF;gBACE,OAAO,EAAE,eAAe;gBACxB,GAAG,MAAM;gBACT,IAAI,EAAE,MAAM,CAAC,MAAM;oBACjB,CAAC,CAAC,SAAS;oBACX,CAAC,CAAC,sFAAsF;aAC3F,EACD,GAAG,CACJ,CAAA;YACD,IAAI,CAAC,MAAM,CAAC,MAAM;gBAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;QAC1C,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../src/commands/export.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAYxC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA0DrD"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { writeFileSync } from 'node:fs';
|
|
2
|
+
import { CompostError, isCompostError } from '../errors.js';
|
|
3
|
+
import { exportTranscript, loadTranscript } from '../lib/export.js';
|
|
4
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
5
|
+
export function registerExport(program) {
|
|
6
|
+
program
|
|
7
|
+
.command('export')
|
|
8
|
+
.description('Export a transcript.json to CSV (legacy fact_utterances) or Markdown')
|
|
9
|
+
.argument('<transcript-path>', 'Path to a transcript.json')
|
|
10
|
+
.requiredOption('--format <fmt>', 'csv | md | eaf')
|
|
11
|
+
.option('--out <path>', 'Write to a file instead of stdout')
|
|
12
|
+
.option('--created-date <date>', 'Value for the legacy CSV created_date column')
|
|
13
|
+
.action((transcriptPath, flags, cmd) => {
|
|
14
|
+
const out = getOutputOpts(cmd);
|
|
15
|
+
try {
|
|
16
|
+
const format = flags.format;
|
|
17
|
+
if (format !== 'csv' && format !== 'md' && format !== 'eaf') {
|
|
18
|
+
throw new CompostError('INVALID_INPUT', `--format must be csv, md, or eaf (got "${flags.format}")`);
|
|
19
|
+
}
|
|
20
|
+
const transcript = loadTranscript(transcriptPath);
|
|
21
|
+
const result = exportTranscript(transcript, flags.createdDate !== undefined ? { format, createdDate: flags.createdDate } : { format });
|
|
22
|
+
if (flags.out !== undefined) {
|
|
23
|
+
writeFileSync(flags.out, result.content, 'utf8');
|
|
24
|
+
emit({
|
|
25
|
+
status: 'ok',
|
|
26
|
+
command: 'export',
|
|
27
|
+
format,
|
|
28
|
+
session_id: result.session_id,
|
|
29
|
+
out: flags.out,
|
|
30
|
+
}, out);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
if (out.human) {
|
|
34
|
+
process.stdout.write(result.content);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
emit({
|
|
38
|
+
status: 'ok',
|
|
39
|
+
command: 'export',
|
|
40
|
+
format,
|
|
41
|
+
session_id: result.session_id,
|
|
42
|
+
content: result.content,
|
|
43
|
+
}, out);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch (err) {
|
|
47
|
+
if (isCompostError(err)) {
|
|
48
|
+
emitError(err, out);
|
|
49
|
+
}
|
|
50
|
+
throw err;
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=export.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../src/commands/export.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAIvC,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAqB,gBAAgB,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACtF,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAQ7D,MAAM,UAAU,cAAc,CAAC,OAAgB;IAC7C,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,sEAAsE,CAAC;SACnF,QAAQ,CAAC,mBAAmB,EAAE,2BAA2B,CAAC;SAC1D,cAAc,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;SAClD,MAAM,CAAC,cAAc,EAAE,mCAAmC,CAAC;SAC3D,MAAM,CAAC,uBAAuB,EAAE,8CAA8C,CAAC;SAC/E,MAAM,CAAC,CAAC,cAAsB,EAAE,KAAkB,EAAE,GAAY,EAAE,EAAE;QACnE,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,KAAK,CAAC,MAAsB,CAAA;YAC3C,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;gBAC5D,MAAM,IAAI,YAAY,CACpB,eAAe,EACf,0CAA0C,KAAK,CAAC,MAAM,IAAI,CAC3D,CAAA;YACH,CAAC;YACD,MAAM,UAAU,GAAG,cAAc,CAAC,cAAc,CAAC,CAAA;YACjD,MAAM,MAAM,GAAG,gBAAgB,CAC7B,UAAU,EACV,KAAK,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAC1F,CAAA;YACD,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;gBAC5B,aAAa,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;gBAChD,IAAI,CACF;oBACE,MAAM,EAAE,IAAI;oBACZ,OAAO,EAAE,QAAQ;oBACjB,MAAM;oBACN,UAAU,EAAE,MAAM,CAAC,UAAU;oBAC7B,GAAG,EAAE,KAAK,CAAC,GAAG;iBACf,EACD,GAAG,CACJ,CAAA;gBACD,OAAM;YACR,CAAC;YACD,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;gBACd,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;YACtC,CAAC;iBAAM,CAAC;gBACN,IAAI,CACF;oBACE,MAAM,EAAE,IAAI;oBACZ,OAAO,EAAE,QAAQ;oBACjB,MAAM;oBACN,UAAU,EAAE,MAAM,CAAC,UAAU;oBAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;iBACxB,EACD,GAAG,CACJ,CAAA;YACH,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YACrB,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ingest.d.ts","sourceRoot":"","sources":["../../src/commands/ingest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAWxC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAqBrD"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { isCompostError } from '../errors.js';
|
|
2
|
+
import { ingestPath } from '../lib/ingest.js';
|
|
3
|
+
import { resolveSeedPath } from '../lib/seedResolve.js';
|
|
4
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
5
|
+
export function registerIngest(program) {
|
|
6
|
+
program
|
|
7
|
+
.command('ingest')
|
|
8
|
+
.description('Route audio/video to the transcriber and legacy artifacts to the legacy-ingest worker')
|
|
9
|
+
.argument('<path>', 'File or folder to ingest')
|
|
10
|
+
.option('--seed <name>', 'Target seed (defaults to the only seed under ./Seeds)')
|
|
11
|
+
.action((target, flags, cmd) => {
|
|
12
|
+
const out = getOutputOpts(cmd);
|
|
13
|
+
try {
|
|
14
|
+
const seedPath = resolveSeedPath(process.cwd(), flags.seed);
|
|
15
|
+
const result = ingestPath(seedPath, target);
|
|
16
|
+
emit({ status: 'ok', command: 'ingest', ...result }, out);
|
|
17
|
+
}
|
|
18
|
+
catch (err) {
|
|
19
|
+
if (isCompostError(err)) {
|
|
20
|
+
emitError(err, out);
|
|
21
|
+
}
|
|
22
|
+
throw err;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=ingest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ingest.js","sourceRoot":"","sources":["../../src/commands/ingest.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAM7D,MAAM,UAAU,cAAc,CAAC,OAAgB;IAC7C,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CACV,uFAAuF,CACxF;SACA,QAAQ,CAAC,QAAQ,EAAE,0BAA0B,CAAC;SAC9C,MAAM,CAAC,eAAe,EAAE,uDAAuD,CAAC;SAChF,MAAM,CAAC,CAAC,MAAc,EAAE,KAAkB,EAAE,GAAY,EAAE,EAAE;QAC3D,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,MAAM,GAAG,UAAU,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAA;YAC3C,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,MAAM,EAAE,EAAE,GAAG,CAAC,CAAA;QAC3D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YACrB,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAYxC,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAsDnD"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { isCompostError } from '../errors.js';
|
|
2
|
+
import { initSeed } from '../lib/seed.js';
|
|
3
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
4
|
+
export function registerInit(program) {
|
|
5
|
+
program
|
|
6
|
+
.command('init')
|
|
7
|
+
.description('Scaffold a new Seeds/<name>/ tree plus .compost/ and config.toml')
|
|
8
|
+
.argument('<seed-name>', 'Seed identifier (alphanumeric, plus - or _)')
|
|
9
|
+
.option('--force', 'Overwrite an existing seed directory')
|
|
10
|
+
.option('--from-legacy <path>', 'Migrate a legacy folder into the new seed (delegates to compost migrate)')
|
|
11
|
+
.option('--from-sample', 'Unpack the bundled sample seed (a redacted single-session corpus)')
|
|
12
|
+
.action((seedName, flags, cmd) => {
|
|
13
|
+
const out = getOutputOpts(cmd);
|
|
14
|
+
try {
|
|
15
|
+
const result = initSeed(seedName, {
|
|
16
|
+
force: flags.force === true,
|
|
17
|
+
fromSample: flags.fromSample === true,
|
|
18
|
+
});
|
|
19
|
+
if (flags.fromLegacy !== undefined) {
|
|
20
|
+
emit({
|
|
21
|
+
status: 'partial',
|
|
22
|
+
command: 'init',
|
|
23
|
+
seed: result.seed_name,
|
|
24
|
+
path: result.path,
|
|
25
|
+
created_at: result.created_at,
|
|
26
|
+
files: result.files,
|
|
27
|
+
directories: result.directories,
|
|
28
|
+
from_legacy: flags.fromLegacy,
|
|
29
|
+
note: '--from-legacy migration is not yet wired (defers to #23 compost migrate)',
|
|
30
|
+
}, out);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
emit({
|
|
34
|
+
status: 'ok',
|
|
35
|
+
command: 'init',
|
|
36
|
+
seed: result.seed_name,
|
|
37
|
+
path: result.path,
|
|
38
|
+
created_at: result.created_at,
|
|
39
|
+
files: result.files,
|
|
40
|
+
directories: result.directories,
|
|
41
|
+
}, out);
|
|
42
|
+
}
|
|
43
|
+
catch (err) {
|
|
44
|
+
if (isCompostError(err)) {
|
|
45
|
+
emitError(err, out);
|
|
46
|
+
}
|
|
47
|
+
throw err;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACzC,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAQ7D,MAAM,UAAU,YAAY,CAAC,OAAgB;IAC3C,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,kEAAkE,CAAC;SAC/E,QAAQ,CAAC,aAAa,EAAE,6CAA6C,CAAC;SACtE,MAAM,CAAC,SAAS,EAAE,sCAAsC,CAAC;SACzD,MAAM,CACL,sBAAsB,EACtB,0EAA0E,CAC3E;SACA,MAAM,CAAC,eAAe,EAAE,mEAAmE,CAAC;SAC5F,MAAM,CAAC,CAAC,QAAgB,EAAE,KAAgB,EAAE,GAAY,EAAE,EAAE;QAC3D,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE;gBAChC,KAAK,EAAE,KAAK,CAAC,KAAK,KAAK,IAAI;gBAC3B,UAAU,EAAE,KAAK,CAAC,UAAU,KAAK,IAAI;aACtC,CAAC,CAAA;YACF,IAAI,KAAK,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;gBACnC,IAAI,CACF;oBACE,MAAM,EAAE,SAAS;oBACjB,OAAO,EAAE,MAAM;oBACf,IAAI,EAAE,MAAM,CAAC,SAAS;oBACtB,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,UAAU,EAAE,MAAM,CAAC,UAAU;oBAC7B,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,WAAW,EAAE,MAAM,CAAC,WAAW;oBAC/B,WAAW,EAAE,KAAK,CAAC,UAAU;oBAC7B,IAAI,EAAE,0EAA0E;iBACjF,EACD,GAAG,CACJ,CAAA;gBACD,OAAM;YACR,CAAC;YACD,IAAI,CACF;gBACE,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,MAAM;gBACf,IAAI,EAAE,MAAM,CAAC,SAAS;gBACtB,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,UAAU,EAAE,MAAM,CAAC,UAAU;gBAC7B,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,WAAW,EAAE,MAAM,CAAC,WAAW;aAChC,EACD,GAAG,CACJ,CAAA;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YACrB,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../../src/commands/migrate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAUxC,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAyBtD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { isCompostError } from '../errors.js';
|
|
2
|
+
import { migrate } from '../lib/migrate.js';
|
|
3
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
4
|
+
export function registerMigrate(program) {
|
|
5
|
+
program
|
|
6
|
+
.command('migrate')
|
|
7
|
+
.description('Rename a legacy 01_*/02_*/03_*/04_* seed in place and scaffold .compost/')
|
|
8
|
+
.argument('<path>', 'Path to the legacy seed directory')
|
|
9
|
+
.option('--apply', 'Perform the migration (default is a read-only dry-run)')
|
|
10
|
+
.action((seedPath, flags, cmd) => {
|
|
11
|
+
const out = getOutputOpts(cmd);
|
|
12
|
+
try {
|
|
13
|
+
const result = migrate(seedPath, { apply: flags.apply === true });
|
|
14
|
+
emit({
|
|
15
|
+
status: result.applied ? 'ok' : 'dry_run',
|
|
16
|
+
command: 'migrate',
|
|
17
|
+
...result,
|
|
18
|
+
}, out);
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
if (isCompostError(err)) {
|
|
22
|
+
emitError(err, out);
|
|
23
|
+
}
|
|
24
|
+
throw err;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=migrate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../src/commands/migrate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAA;AAC3C,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAM7D,MAAM,UAAU,eAAe,CAAC,OAAgB;IAC9C,OAAO;SACJ,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,0EAA0E,CAAC;SACvF,QAAQ,CAAC,QAAQ,EAAE,mCAAmC,CAAC;SACvD,MAAM,CAAC,SAAS,EAAE,wDAAwD,CAAC;SAC3E,MAAM,CAAC,CAAC,QAAgB,EAAE,KAAmB,EAAE,GAAY,EAAE,EAAE;QAC9D,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,OAAO,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,KAAK,IAAI,EAAE,CAAC,CAAA;YACjE,IAAI,CACF;gBACE,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS;gBACzC,OAAO,EAAE,SAAS;gBAClB,GAAG,MAAM;aACV,EACD,GAAG,CACJ,CAAA;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YACrB,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.d.ts","sourceRoot":"","sources":["../../src/commands/models.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAaxC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA0BrD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { isCompostError } from '../errors.js';
|
|
2
|
+
import { loadConfig } from '../lib/config.js';
|
|
3
|
+
import { runDoctor } from '../lib/doctor.js';
|
|
4
|
+
import { resolveSeedPath } from '../lib/seedResolve.js';
|
|
5
|
+
import { LLMAdapter } from '../llm/adapter.js';
|
|
6
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
7
|
+
export function registerModels(program) {
|
|
8
|
+
const models = program.command('models').description('LLM provider helpers');
|
|
9
|
+
models
|
|
10
|
+
.command('doctor')
|
|
11
|
+
.description('Probe configured providers and report health + per-task coverage')
|
|
12
|
+
.option('--seed <name>', 'Seed whose config.toml to read (default: the only seed under ./Seeds)')
|
|
13
|
+
.action(async (flags, cmd) => {
|
|
14
|
+
const out = getOutputOpts(cmd);
|
|
15
|
+
try {
|
|
16
|
+
const seedPath = resolveSeedPath(process.cwd(), flags.seed);
|
|
17
|
+
const config = loadConfig(seedPath);
|
|
18
|
+
const adapter = new LLMAdapter(config);
|
|
19
|
+
const report = await runDoctor(adapter, config);
|
|
20
|
+
emit({ command: 'models doctor', ...report }, out);
|
|
21
|
+
if (!report.ok)
|
|
22
|
+
process.exitCode = 1;
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
if (isCompostError(err)) {
|
|
26
|
+
emitError(err, out);
|
|
27
|
+
}
|
|
28
|
+
throw err;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=models.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/commands/models.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAM7D,MAAM,UAAU,cAAc,CAAC,OAAgB;IAC7C,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,sBAAsB,CAAC,CAAA;IAE5E,MAAM;SACH,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,kEAAkE,CAAC;SAC/E,MAAM,CACL,eAAe,EACf,uEAAuE,CACxE;SACA,MAAM,CAAC,KAAK,EAAE,KAAkB,EAAE,GAAY,EAAE,EAAE;QACjD,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,MAAM,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAA;YACnC,MAAM,OAAO,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAA;YACtC,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;YAC/C,IAAI,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,MAAM,EAAE,EAAE,GAAG,CAAC,CAAA;YAClD,IAAI,CAAC,MAAM,CAAC,EAAE;gBAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;QACtC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YACrB,CAAC;YACD,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../src/commands/query.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAIxC,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAUpD"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { stubAction, stubDescription } from './_stub.js';
|
|
2
|
+
export function registerQuery(program) {
|
|
3
|
+
program
|
|
4
|
+
.command('query')
|
|
5
|
+
.description(stubDescription('Run a one-shot RAG query against the seed (no chat loop)', 51))
|
|
6
|
+
.argument('<question>')
|
|
7
|
+
// --seed is in the contract today even though the action is still stubbed
|
|
8
|
+
// (#167): every seed-scoped command must accept it so a multi-seed workspace
|
|
9
|
+
// is targetable from the moment `query` ships.
|
|
10
|
+
.option('--seed <name>', 'Seed (default: the only seed under ./Seeds)')
|
|
11
|
+
.action(stubAction({ command: 'query', issue: 51 }));
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/commands/query.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAExD,MAAM,UAAU,aAAa,CAAC,OAAgB;IAC5C,OAAO;SACJ,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,eAAe,CAAC,0DAA0D,EAAE,EAAE,CAAC,CAAC;SAC5F,QAAQ,CAAC,YAAY,CAAC;QACvB,0EAA0E;QAC1E,6EAA6E;QAC7E,+CAA+C;SAC9C,MAAM,CAAC,eAAe,EAAE,6CAA6C,CAAC;SACtE,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,CAAA;AACxD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reindex.d.ts","sourceRoot":"","sources":["../../src/commands/reindex.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAYxC,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAyDtD"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { existsSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import Database from 'better-sqlite3';
|
|
4
|
+
import { SnapshotStore } from 'compost-provenance';
|
|
5
|
+
import { CompostError, isCompostError } from '../errors.js';
|
|
6
|
+
import { resolveSeedPath } from '../lib/seedResolve.js';
|
|
7
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
8
|
+
export function registerReindex(program) {
|
|
9
|
+
program
|
|
10
|
+
.command('reindex')
|
|
11
|
+
.description('Rebuild derived state in .compost/ — caches, event snapshots, and optionally vectors')
|
|
12
|
+
.option('--seed <name>', 'Target seed (defaults to the only seed under ./Seeds)')
|
|
13
|
+
.option('--vectors', 'Also rebuild the LanceDB embeddings index')
|
|
14
|
+
.action((flags, cmd) => {
|
|
15
|
+
const out = getOutputOpts(cmd);
|
|
16
|
+
try {
|
|
17
|
+
const seedPath = resolveSeedPath(process.cwd(), flags.seed);
|
|
18
|
+
const eventsDb = join(seedPath, '.compost', 'events.sqlite');
|
|
19
|
+
if (!existsSync(eventsDb)) {
|
|
20
|
+
throw new CompostError('FILE_NOT_FOUND', `No events.sqlite at ${eventsDb}. Has any artifact been created in this seed?`);
|
|
21
|
+
}
|
|
22
|
+
// Rebuild snapshots from the event log.
|
|
23
|
+
const db = new Database(eventsDb);
|
|
24
|
+
try {
|
|
25
|
+
const store = new SnapshotStore(db);
|
|
26
|
+
const rebuilt = store.rebuildAll();
|
|
27
|
+
const result = {
|
|
28
|
+
status: 'ok',
|
|
29
|
+
command: 'reindex',
|
|
30
|
+
seed: seedPath,
|
|
31
|
+
snapshots_rebuilt: rebuilt,
|
|
32
|
+
vectors_rebuilt: null,
|
|
33
|
+
};
|
|
34
|
+
if (flags.vectors === true) {
|
|
35
|
+
// The embed-worker (v0.1-04) owns the LanceDB write path. Until it
|
|
36
|
+
// ships, --vectors is a recognized flag that emits a clear "wait" status
|
|
37
|
+
// instead of pretending to succeed.
|
|
38
|
+
result.note = '--vectors requires the embed-worker (v0.1-04, issue #137); not yet wired';
|
|
39
|
+
}
|
|
40
|
+
emit(result, out);
|
|
41
|
+
}
|
|
42
|
+
finally {
|
|
43
|
+
db.close();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch (err) {
|
|
47
|
+
if (isCompostError(err))
|
|
48
|
+
emitError(err, out);
|
|
49
|
+
throw err;
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=reindex.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reindex.js","sourceRoot":"","sources":["../../src/commands/reindex.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAChC,OAAO,QAAQ,MAAM,gBAAgB,CAAA;AAErC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAO7D,MAAM,UAAU,eAAe,CAAC,OAAgB;IAC9C,OAAO;SACJ,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CACV,sFAAsF,CACvF;SACA,MAAM,CAAC,eAAe,EAAE,uDAAuD,CAAC;SAChF,MAAM,CAAC,WAAW,EAAE,2CAA2C,CAAC;SAChE,MAAM,CAAC,CAAC,KAAmB,EAAE,GAAY,EAAE,EAAE;QAC5C,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,eAAe,CAAC,CAAA;YAC5D,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC1B,MAAM,IAAI,YAAY,CACpB,gBAAgB,EAChB,uBAAuB,QAAQ,+CAA+C,CAC/E,CAAA;YACH,CAAC;YAED,wCAAwC;YACxC,MAAM,EAAE,GAAG,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAA;YACjC,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,IAAI,aAAa,CAAC,EAAE,CAAC,CAAA;gBACnC,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,EAAE,CAAA;gBAElC,MAAM,MAAM,GAOR;oBACF,MAAM,EAAE,IAAI;oBACZ,OAAO,EAAE,SAAS;oBAClB,IAAI,EAAE,QAAQ;oBACd,iBAAiB,EAAE,OAAO;oBAC1B,eAAe,EAAE,IAAI;iBACtB,CAAA;gBAED,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI,EAAE,CAAC;oBAC3B,mEAAmE;oBACnE,yEAAyE;oBACzE,oCAAoC;oBACpC,MAAM,CAAC,IAAI,GAAG,0EAA0E,CAAA;gBAC1F,CAAC;gBAED,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;YACnB,CAAC;oBAAS,CAAC;gBACT,EAAE,CAAC,KAAK,EAAE,CAAA;YACZ,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rescan.d.ts","sourceRoot":"","sources":["../../src/commands/rescan.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAkCxC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA+BrD"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync, statSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { isCompostError } from '../errors.js';
|
|
4
|
+
import { resolveSeedPath } from '../lib/seedResolve.js';
|
|
5
|
+
import { suggestThemesOnce } from '../loops/synthesis.js';
|
|
6
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
7
|
+
/** Load embedded highlights from highlights/*.json ({ id, vector } sidecars
|
|
8
|
+
* written by the embed-worker). Empty when none are embedded yet. */
|
|
9
|
+
function loadEmbeddedHighlights(seedPath) {
|
|
10
|
+
const dir = join(seedPath, 'highlights');
|
|
11
|
+
if (!existsSync(dir))
|
|
12
|
+
return [];
|
|
13
|
+
const out = [];
|
|
14
|
+
for (const f of readdirSync(dir)) {
|
|
15
|
+
if (!f.endsWith('.json'))
|
|
16
|
+
continue;
|
|
17
|
+
const p = join(dir, f);
|
|
18
|
+
if (!statSync(p).isFile())
|
|
19
|
+
continue;
|
|
20
|
+
try {
|
|
21
|
+
const j = JSON.parse(readFileSync(p, 'utf8'));
|
|
22
|
+
if (typeof j.id === 'string' && Array.isArray(j.vector))
|
|
23
|
+
out.push({ id: j.id, vector: j.vector });
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
// skip malformed sidecars
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return out;
|
|
30
|
+
}
|
|
31
|
+
export function registerRescan(program) {
|
|
32
|
+
program
|
|
33
|
+
.command('rescan')
|
|
34
|
+
.description('Run the cross-session-similarity scanner: cluster un-coded highlights → AI code suggestions')
|
|
35
|
+
.option('--seed <name>', 'Seed (default: the only seed under ./Seeds)')
|
|
36
|
+
.option('--threshold <n>', 'Cosine similarity threshold for clustering', '0.75')
|
|
37
|
+
.action((flags, cmd) => {
|
|
38
|
+
const out = getOutputOpts(cmd);
|
|
39
|
+
try {
|
|
40
|
+
const seedPath = resolveSeedPath(process.cwd(), flags.seed);
|
|
41
|
+
const highlights = loadEmbeddedHighlights(seedPath);
|
|
42
|
+
const suggestions = suggestThemesOnce(seedPath, highlights, {
|
|
43
|
+
threshold: Number(flags.threshold ?? 0.75),
|
|
44
|
+
});
|
|
45
|
+
emit({
|
|
46
|
+
status: 'ok',
|
|
47
|
+
command: 'rescan',
|
|
48
|
+
embedded_highlights: highlights.length,
|
|
49
|
+
suggested: suggestions.length,
|
|
50
|
+
suggestions,
|
|
51
|
+
}, out);
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
if (isCompostError(err))
|
|
55
|
+
emitError(err, out);
|
|
56
|
+
throw err;
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=rescan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rescan.js","sourceRoot":"","sources":["../../src/commands/rescan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AACzE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAKhC,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAO7D;qEACqE;AACrE,SAAS,sBAAsB,CAAC,QAAgB;IAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IACxC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;QAAE,OAAO,EAAE,CAAA;IAC/B,MAAM,GAAG,GAAmB,EAAE,CAAA;IAC9B,KAAK,MAAM,CAAC,IAAI,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;QACjC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,SAAQ;QAClC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAA;QACtB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE;YAAE,SAAQ;QACnC,IAAI,CAAC;YACH,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,CAAuC,CAAA;YACnF,IAAI,OAAO,CAAC,CAAC,EAAE,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;gBACrD,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAA;QAC5C,CAAC;QAAC,MAAM,CAAC;YACP,0BAA0B;QAC5B,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAA;AACZ,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,OAAgB;IAC7C,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CACV,6FAA6F,CAC9F;SACA,MAAM,CAAC,eAAe,EAAE,6CAA6C,CAAC;SACtE,MAAM,CAAC,iBAAiB,EAAE,4CAA4C,EAAE,MAAM,CAAC;SAC/E,MAAM,CAAC,CAAC,KAAkB,EAAE,GAAY,EAAE,EAAE;QAC3C,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,UAAU,GAAG,sBAAsB,CAAC,QAAQ,CAAC,CAAA;YACnD,MAAM,WAAW,GAAG,iBAAiB,CAAC,QAAQ,EAAE,UAAU,EAAE;gBAC1D,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC;aAC3C,CAAC,CAAA;YACF,IAAI,CACF;gBACE,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,QAAQ;gBACjB,mBAAmB,EAAE,UAAU,CAAC,MAAM;gBACtC,SAAS,EAAE,WAAW,CAAC,MAAM;gBAC7B,WAAW;aACZ,EACD,GAAG,CACJ,CAAA;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"saturate.d.ts","sourceRoot":"","sources":["../../src/commands/saturate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAYxC,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAmCvD"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { saturationPulse } from 'compost-retrieval';
|
|
2
|
+
import { isCompostError } from '../errors.js';
|
|
3
|
+
import { gatherSessionsWithThemes } from '../lib/saturate.js';
|
|
4
|
+
import { emit, emitError, getOutputOpts } from '../output.js';
|
|
5
|
+
export function registerSaturate(program) {
|
|
6
|
+
program
|
|
7
|
+
.command('saturate')
|
|
8
|
+
.description('Assess thematic saturation: per-session theme novelty + a continue/pause/conclude recommendation')
|
|
9
|
+
.option('--seed <name>', 'Seed (default: the only seed under ./Seeds)')
|
|
10
|
+
.option('--dry-streak <n>', 'Consecutive dry sessions that trigger a conclude recommendation', '2')
|
|
11
|
+
.action((flags, cmd) => {
|
|
12
|
+
const out = getOutputOpts(cmd);
|
|
13
|
+
try {
|
|
14
|
+
const opts = {};
|
|
15
|
+
if (flags.seed !== undefined)
|
|
16
|
+
opts.seed = flags.seed;
|
|
17
|
+
const sessions = gatherSessionsWithThemes(opts);
|
|
18
|
+
const pulse = saturationPulse(sessions, {
|
|
19
|
+
dryStreakToConclude: Number(flags.dryStreak ?? 2),
|
|
20
|
+
});
|
|
21
|
+
emit({
|
|
22
|
+
status: 'ok',
|
|
23
|
+
command: 'saturate',
|
|
24
|
+
sessions: sessions.length,
|
|
25
|
+
...pulse,
|
|
26
|
+
}, out);
|
|
27
|
+
}
|
|
28
|
+
catch (err) {
|
|
29
|
+
if (isCompostError(err))
|
|
30
|
+
emitError(err, out);
|
|
31
|
+
throw err;
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=saturate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"saturate.js","sourceRoot":"","sources":["../../src/commands/saturate.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAEnD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAA;AAC7D,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAO7D,MAAM,UAAU,gBAAgB,CAAC,OAAgB;IAC/C,OAAO;SACJ,OAAO,CAAC,UAAU,CAAC;SACnB,WAAW,CACV,kGAAkG,CACnG;SACA,MAAM,CAAC,eAAe,EAAE,6CAA6C,CAAC;SACtE,MAAM,CACL,kBAAkB,EAClB,iEAAiE,EACjE,GAAG,CACJ;SACA,MAAM,CAAC,CAAC,KAAoB,EAAE,GAAY,EAAE,EAAE;QAC7C,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,CAAA;QAC9B,IAAI,CAAC;YACH,MAAM,IAAI,GAAsB,EAAE,CAAA;YAClC,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS;gBAAE,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAA;YACpD,MAAM,QAAQ,GAAG,wBAAwB,CAAC,IAAI,CAAC,CAAA;YAC/C,MAAM,KAAK,GAAG,eAAe,CAAC,QAAQ,EAAE;gBACtC,mBAAmB,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,IAAI,CAAC,CAAC;aAClD,CAAC,CAAA;YACF,IAAI,CACF;gBACE,MAAM,EAAE,IAAI;gBACZ,OAAO,EAAE,UAAU;gBACnB,QAAQ,EAAE,QAAQ,CAAC,MAAM;gBACzB,GAAG,KAAK;aACT,EACD,GAAG,CACJ,CAAA;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,cAAc,CAAC,GAAG,CAAC;gBAAE,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC5C,MAAM,GAAG,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/commands/search.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAYxC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAmDrD"}
|