clawvault 3.0.0 → 3.2.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/README.md +352 -20
- package/bin/clawvault.js +8 -2
- package/bin/command-registration.test.js +3 -1
- package/bin/command-runtime.js +9 -1
- package/bin/register-core-commands.js +23 -10
- package/bin/register-maintenance-commands.js +39 -3
- package/bin/register-query-commands.js +58 -29
- package/bin/register-task-commands.js +18 -1
- package/bin/register-task-commands.test.js +16 -0
- package/bin/register-vault-operations-commands.js +29 -1
- package/bin/register-workgraph-commands.js +1368 -0
- package/dashboard/lib/graph-diff.js +104 -0
- package/dashboard/lib/graph-diff.test.js +75 -0
- package/dashboard/lib/vault-parser.js +556 -0
- package/dashboard/lib/vault-parser.test.js +254 -0
- package/dashboard/public/app.js +796 -0
- package/dashboard/public/index.html +52 -0
- package/dashboard/public/styles.css +221 -0
- package/dashboard/server.js +374 -0
- package/dist/{chunk-F2JEUD4J.js → chunk-23YDQ3QU.js} +6 -8
- package/dist/{chunk-C7OK5WKP.js → chunk-2JQ3O2YL.js} +4 -4
- package/dist/{chunk-VR5NE7PZ.js → chunk-2RAZ4ZFE.js} +1 -1
- package/dist/chunk-2ZDO52B4.js +52 -0
- package/dist/{chunk-ZZA73MFY.js → chunk-33DOSHTA.js} +176 -36
- package/dist/chunk-33VSQP4J.js +37 -0
- package/dist/chunk-4BQTQMJP.js +93 -0
- package/dist/{chunk-GUKMRGM7.js → chunk-4OXMU5S2.js} +1 -1
- package/dist/{chunk-62YTUT6J.js → chunk-4PY655YM.js} +15 -3
- package/dist/chunk-6FH3IULF.js +352 -0
- package/dist/{chunk-3NSBOUT3.js → chunk-77Q5CSPJ.js} +404 -80
- package/dist/{chunk-4VQTUVH7.js → chunk-7YZWHM36.js} +52 -26
- package/dist/chunk-BSJ6RIT7.js +447 -0
- package/dist/chunk-BUEW6IIK.js +364 -0
- package/dist/{chunk-WGRQ6HDV.js → chunk-CLJTREDS.js} +74 -14
- package/dist/chunk-EK6S23ZB.js +469 -0
- package/dist/{chunk-LNJA2UGL.js → chunk-ESFLMDRB.js} +9 -86
- package/dist/{chunk-H34S76MB.js → chunk-ESVS6K2B.js} +6 -6
- package/dist/{chunk-WAZ3NLWL.js → chunk-F55HGNU4.js} +0 -47
- package/dist/{chunk-QK3UCXWL.js → chunk-FHFUXL6G.js} +2 -2
- package/dist/{chunk-YKTA5JOJ.js → chunk-GAOWA7GR.js} +212 -46
- package/dist/chunk-GGA32J2R.js +784 -0
- package/dist/chunk-GNJL4YGR.js +79 -0
- package/dist/chunk-MDIH26GC.js +183 -0
- package/dist/{chunk-LYHGEHXG.js → chunk-MFAWT5O5.js} +0 -1
- package/dist/chunk-MM6QGW3P.js +207 -0
- package/dist/{chunk-P5EPF6MB.js → chunk-MW5C6ZQA.js} +110 -13
- package/dist/chunk-NCKFNBHJ.js +257 -0
- package/dist/{chunk-QBLMXKF2.js → chunk-OIWVQYQF.js} +1 -1
- package/dist/{chunk-42MXU7A6.js → chunk-P62WHA27.js} +58 -47
- package/dist/chunk-PBACDKKP.js +66 -0
- package/dist/{chunk-VGLOTGAS.js → chunk-QSHD36LH.js} +2 -2
- package/dist/{chunk-OZ7RIXTO.js → chunk-QSRRMEYM.js} +2 -2
- package/dist/chunk-QVEERJSP.js +152 -0
- package/dist/{chunk-N2AXRYLC.js → chunk-QWQ3TIKS.js} +1 -1
- package/dist/{chunk-3DHXQHYG.js → chunk-R2MIW5G7.js} +1 -1
- package/dist/{chunk-SJSFRIYS.js → chunk-SLXOR3CC.js} +2 -2
- package/dist/chunk-SS4B7P7V.js +99 -0
- package/dist/{chunk-JY6FYXIT.js → chunk-STCQGCEQ.js} +6 -11
- package/dist/chunk-U4O6C46S.js +154 -0
- package/dist/{chunk-ITPEXLHA.js → chunk-URXDAUVH.js} +24 -5
- package/dist/chunk-VSL7KY3M.js +189 -0
- package/dist/{chunk-U55BGUAU.js → chunk-W4SPAEE7.js} +6 -6
- package/dist/chunk-WMGIIABP.js +15 -0
- package/dist/{chunk-3D6BCTP6.js → chunk-X3SPPUFG.js} +51 -39
- package/dist/{chunk-THRJVD4L.js → chunk-Y6VJKXGL.js} +1 -1
- package/dist/{chunk-ZVVFWOLW.js → chunk-ZN54U2OZ.js} +123 -10
- package/dist/cli/index.js +32 -25
- package/dist/commands/archive.js +3 -3
- package/dist/commands/backlog.js +3 -3
- package/dist/commands/blocked.js +3 -3
- package/dist/commands/canvas.d.ts +15 -0
- package/dist/commands/canvas.js +200 -0
- package/dist/commands/checkpoint.js +2 -2
- package/dist/commands/compat.js +2 -2
- package/dist/commands/context.js +8 -6
- package/dist/commands/doctor.d.ts +11 -7
- package/dist/commands/doctor.js +18 -16
- package/dist/commands/embed.js +5 -6
- package/dist/commands/entities.js +2 -2
- package/dist/commands/graph.js +4 -4
- package/dist/commands/inject.d.ts +1 -1
- package/dist/commands/inject.js +5 -6
- package/dist/commands/kanban.js +4 -4
- package/dist/commands/link.js +5 -5
- package/dist/commands/migrate-observations.js +4 -4
- package/dist/commands/observe.d.ts +0 -1
- package/dist/commands/observe.js +14 -13
- package/dist/commands/project.js +5 -5
- package/dist/commands/rebuild-embeddings.d.ts +21 -0
- package/dist/commands/rebuild-embeddings.js +91 -0
- package/dist/commands/rebuild.js +12 -11
- package/dist/commands/recover.js +3 -3
- package/dist/commands/reflect.js +6 -7
- package/dist/commands/repair-session.js +1 -1
- package/dist/commands/replay.js +14 -14
- package/dist/commands/session-recap.js +1 -1
- package/dist/commands/setup.d.ts +2 -90
- package/dist/commands/setup.js +3 -21
- package/dist/commands/shell-init.js +1 -1
- package/dist/commands/sleep.d.ts +1 -1
- package/dist/commands/sleep.js +20 -19
- package/dist/commands/status.d.ts +2 -0
- package/dist/commands/status.js +57 -35
- package/dist/commands/sync-bd.d.ts +10 -0
- package/dist/commands/sync-bd.js +10 -0
- package/dist/commands/tailscale.js +3 -3
- package/dist/commands/task.js +4 -4
- package/dist/commands/template.js +2 -2
- package/dist/commands/wake.d.ts +1 -1
- package/dist/commands/wake.js +11 -10
- package/dist/commands/workgraph.d.ts +124 -0
- package/dist/commands/workgraph.js +38 -0
- package/dist/index.d.ts +337 -191
- package/dist/index.js +387 -118
- package/dist/{inject-Bzi5E-By.d.cts → inject-DYUrDqQO.d.ts} +3 -3
- package/dist/ledger-B7g7jhqG.d.ts +44 -0
- package/dist/lib/auto-linker.js +2 -2
- package/dist/lib/canvas-layout.d.ts +100 -16
- package/dist/lib/canvas-layout.js +21 -78
- package/dist/lib/config.d.ts +27 -3
- package/dist/lib/config.js +4 -2
- package/dist/lib/entity-index.js +1 -1
- package/dist/lib/project-utils.js +4 -4
- package/dist/lib/session-repair.js +1 -1
- package/dist/lib/session-utils.js +1 -1
- package/dist/lib/tailscale.js +1 -1
- package/dist/lib/task-utils.js +3 -3
- package/dist/lib/template-engine.js +1 -1
- package/dist/lib/webdav.js +1 -1
- package/dist/onnxruntime_binding-5QEF3SUC.node +0 -0
- package/dist/onnxruntime_binding-BKPKNEGC.node +0 -0
- package/dist/onnxruntime_binding-FMOXGIUT.node +0 -0
- package/dist/onnxruntime_binding-OI2KMXC5.node +0 -0
- package/dist/onnxruntime_binding-UX44MLAZ.node +0 -0
- package/dist/onnxruntime_binding-Y2W7N7WY.node +0 -0
- package/dist/openclaw-plugin.d.ts +8 -0
- package/dist/openclaw-plugin.js +14 -0
- package/dist/registry-BR4326o0.d.ts +30 -0
- package/dist/store-CA-6sKCJ.d.ts +34 -0
- package/dist/thread-B9LhXNU0.d.ts +41 -0
- package/dist/transformers.node-A2ZRORSQ.js +46775 -0
- package/dist/{types-Y2_Um2Ls.d.cts → types-BbWJoC1c.d.ts} +1 -44
- package/dist/workgraph/index.d.ts +5 -0
- package/dist/workgraph/index.js +23 -0
- package/dist/workgraph/ledger.d.ts +2 -0
- package/dist/workgraph/ledger.js +25 -0
- package/dist/workgraph/registry.d.ts +2 -0
- package/dist/workgraph/registry.js +19 -0
- package/dist/workgraph/store.d.ts +2 -0
- package/dist/workgraph/store.js +25 -0
- package/dist/workgraph/thread.d.ts +2 -0
- package/dist/workgraph/thread.js +25 -0
- package/dist/workgraph/types.d.ts +54 -0
- package/dist/workgraph/types.js +7 -0
- package/hooks/clawvault/HOOK.md +34 -4
- package/hooks/clawvault/handler.js +760 -78
- package/hooks/clawvault/handler.test.js +235 -79
- package/hooks/clawvault/openclaw.plugin.json +72 -0
- package/openclaw.plugin.json +65 -38
- package/package.json +15 -18
- package/dist/chunk-3RG5ZIWI.js +0 -10
- package/dist/chunk-6U6MK36V.js +0 -205
- package/dist/chunk-7R7O6STJ.js +0 -88
- package/dist/chunk-CMB7UL7C.js +0 -327
- package/dist/chunk-DEFFDRVP.js +0 -938
- package/dist/chunk-E7MFQB6D.js +0 -163
- package/dist/chunk-GAJV4IGR.js +0 -82
- package/dist/chunk-GQSLDZTS.js +0 -560
- package/dist/chunk-K234IDRJ.js +0 -1073
- package/dist/chunk-MFM6K7PU.js +0 -374
- package/dist/chunk-MXSSG3QU.js +0 -42
- package/dist/chunk-PAH27GSN.js +0 -108
- package/dist/cli/index.cjs +0 -10033
- package/dist/cli/index.d.cts +0 -5
- package/dist/commands/archive.cjs +0 -287
- package/dist/commands/archive.d.cts +0 -11
- package/dist/commands/backlog.cjs +0 -721
- package/dist/commands/backlog.d.cts +0 -53
- package/dist/commands/blocked.cjs +0 -204
- package/dist/commands/blocked.d.cts +0 -26
- package/dist/commands/checkpoint.cjs +0 -244
- package/dist/commands/checkpoint.d.cts +0 -41
- package/dist/commands/compat.cjs +0 -369
- package/dist/commands/compat.d.cts +0 -28
- package/dist/commands/context.cjs +0 -2989
- package/dist/commands/context.d.cts +0 -2
- package/dist/commands/doctor.cjs +0 -3062
- package/dist/commands/doctor.d.cts +0 -21
- package/dist/commands/embed.cjs +0 -232
- package/dist/commands/embed.d.cts +0 -17
- package/dist/commands/entities.cjs +0 -141
- package/dist/commands/entities.d.cts +0 -7
- package/dist/commands/graph.cjs +0 -501
- package/dist/commands/graph.d.cts +0 -21
- package/dist/commands/inject.cjs +0 -1636
- package/dist/commands/inject.d.cts +0 -2
- package/dist/commands/kanban.cjs +0 -884
- package/dist/commands/kanban.d.cts +0 -63
- package/dist/commands/link.cjs +0 -965
- package/dist/commands/link.d.cts +0 -11
- package/dist/commands/migrate-observations.cjs +0 -362
- package/dist/commands/migrate-observations.d.cts +0 -19
- package/dist/commands/observe.cjs +0 -4099
- package/dist/commands/observe.d.cts +0 -23
- package/dist/commands/project.cjs +0 -1341
- package/dist/commands/project.d.cts +0 -85
- package/dist/commands/rebuild.cjs +0 -3136
- package/dist/commands/rebuild.d.cts +0 -11
- package/dist/commands/recover.cjs +0 -361
- package/dist/commands/recover.d.cts +0 -38
- package/dist/commands/reflect.cjs +0 -1008
- package/dist/commands/reflect.d.cts +0 -11
- package/dist/commands/repair-session.cjs +0 -457
- package/dist/commands/repair-session.d.cts +0 -38
- package/dist/commands/replay.cjs +0 -4103
- package/dist/commands/replay.d.cts +0 -16
- package/dist/commands/session-recap.cjs +0 -353
- package/dist/commands/session-recap.d.cts +0 -27
- package/dist/commands/setup.cjs +0 -1345
- package/dist/commands/setup.d.cts +0 -100
- package/dist/commands/shell-init.cjs +0 -75
- package/dist/commands/shell-init.d.cts +0 -7
- package/dist/commands/sleep.cjs +0 -6028
- package/dist/commands/sleep.d.cts +0 -36
- package/dist/commands/status.cjs +0 -2736
- package/dist/commands/status.d.cts +0 -52
- package/dist/commands/tailscale.cjs +0 -1532
- package/dist/commands/tailscale.d.cts +0 -52
- package/dist/commands/task.cjs +0 -1236
- package/dist/commands/task.d.cts +0 -97
- package/dist/commands/template.cjs +0 -457
- package/dist/commands/template.d.cts +0 -36
- package/dist/commands/wake.cjs +0 -2626
- package/dist/commands/wake.d.cts +0 -22
- package/dist/context-BUGaWpyL.d.cts +0 -46
- package/dist/index.cjs +0 -14526
- package/dist/index.d.cts +0 -858
- package/dist/inject-Bzi5E-By.d.ts +0 -137
- package/dist/lib/auto-linker.cjs +0 -176
- package/dist/lib/auto-linker.d.cts +0 -26
- package/dist/lib/canvas-layout.cjs +0 -136
- package/dist/lib/canvas-layout.d.cts +0 -31
- package/dist/lib/config.cjs +0 -78
- package/dist/lib/config.d.cts +0 -11
- package/dist/lib/entity-index.cjs +0 -84
- package/dist/lib/entity-index.d.cts +0 -26
- package/dist/lib/project-utils.cjs +0 -864
- package/dist/lib/project-utils.d.cts +0 -97
- package/dist/lib/session-repair.cjs +0 -239
- package/dist/lib/session-repair.d.cts +0 -110
- package/dist/lib/session-utils.cjs +0 -209
- package/dist/lib/session-utils.d.cts +0 -63
- package/dist/lib/tailscale.cjs +0 -1183
- package/dist/lib/tailscale.d.cts +0 -225
- package/dist/lib/task-utils.cjs +0 -1137
- package/dist/lib/task-utils.d.cts +0 -208
- package/dist/lib/template-engine.cjs +0 -47
- package/dist/lib/template-engine.d.cts +0 -11
- package/dist/lib/webdav.cjs +0 -568
- package/dist/lib/webdav.d.cts +0 -109
- package/dist/plugin/index.cjs +0 -1907
- package/dist/plugin/index.d.cts +0 -36
- package/dist/plugin/index.d.ts +0 -36
- package/dist/plugin/index.js +0 -572
- package/dist/plugin/inject.cjs +0 -356
- package/dist/plugin/inject.d.cts +0 -54
- package/dist/plugin/inject.d.ts +0 -54
- package/dist/plugin/inject.js +0 -17
- package/dist/plugin/observe.cjs +0 -631
- package/dist/plugin/observe.d.cts +0 -39
- package/dist/plugin/observe.d.ts +0 -39
- package/dist/plugin/observe.js +0 -18
- package/dist/plugin/templates.cjs +0 -593
- package/dist/plugin/templates.d.cts +0 -52
- package/dist/plugin/templates.d.ts +0 -52
- package/dist/plugin/templates.js +0 -25
- package/dist/plugin/types.cjs +0 -18
- package/dist/plugin/types.d.cts +0 -209
- package/dist/plugin/types.d.ts +0 -209
- package/dist/plugin/types.js +0 -0
- package/dist/plugin/vault.cjs +0 -927
- package/dist/plugin/vault.d.cts +0 -68
- package/dist/plugin/vault.d.ts +0 -68
- package/dist/plugin/vault.js +0 -22
- package/dist/types-Y2_Um2Ls.d.ts +0 -205
- package/templates/memory-event.md +0 -67
- package/templates/party.md +0 -63
- package/templates/primitive-registry.yaml +0 -551
- package/templates/run.md +0 -68
- package/templates/trigger.md +0 -68
- package/templates/workspace.md +0 -50
package/dist/commands/link.d.cts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
interface LinkOptions {
|
|
2
|
-
all?: boolean;
|
|
3
|
-
dryRun?: boolean;
|
|
4
|
-
backlinks?: string;
|
|
5
|
-
orphans?: boolean;
|
|
6
|
-
rebuild?: boolean;
|
|
7
|
-
vaultPath?: string;
|
|
8
|
-
}
|
|
9
|
-
declare function linkCommand(file: string | undefined, options: LinkOptions): Promise<void>;
|
|
10
|
-
|
|
11
|
-
export { linkCommand };
|
|
@@ -1,362 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/commands/migrate-observations.ts
|
|
31
|
-
var migrate_observations_exports = {};
|
|
32
|
-
__export(migrate_observations_exports, {
|
|
33
|
-
migrateObservations: () => migrateObservations,
|
|
34
|
-
migrateObservationsCommand: () => migrateObservationsCommand,
|
|
35
|
-
registerMigrateObservationsCommand: () => registerMigrateObservationsCommand
|
|
36
|
-
});
|
|
37
|
-
module.exports = __toCommonJS(migrate_observations_exports);
|
|
38
|
-
var fs3 = __toESM(require("fs"), 1);
|
|
39
|
-
|
|
40
|
-
// src/lib/config.ts
|
|
41
|
-
var fs = __toESM(require("fs"), 1);
|
|
42
|
-
var path = __toESM(require("path"), 1);
|
|
43
|
-
function findNearestVaultPath(startPath = process.cwd()) {
|
|
44
|
-
let current = path.resolve(startPath);
|
|
45
|
-
while (true) {
|
|
46
|
-
if (fs.existsSync(path.join(current, ".clawvault.json"))) {
|
|
47
|
-
return current;
|
|
48
|
-
}
|
|
49
|
-
const parent = path.dirname(current);
|
|
50
|
-
if (parent === current) {
|
|
51
|
-
return null;
|
|
52
|
-
}
|
|
53
|
-
current = parent;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
function resolveVaultPath(options = {}) {
|
|
57
|
-
if (options.explicitPath) {
|
|
58
|
-
return path.resolve(options.explicitPath);
|
|
59
|
-
}
|
|
60
|
-
if (process.env.CLAWVAULT_PATH) {
|
|
61
|
-
return path.resolve(process.env.CLAWVAULT_PATH);
|
|
62
|
-
}
|
|
63
|
-
const discovered = findNearestVaultPath(options.cwd ?? process.cwd());
|
|
64
|
-
if (discovered) {
|
|
65
|
-
return discovered;
|
|
66
|
-
}
|
|
67
|
-
throw new Error("No vault path found. Set CLAWVAULT_PATH, use --vault, or run inside a vault.");
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// src/lib/ledger.ts
|
|
71
|
-
var fs2 = __toESM(require("fs"), 1);
|
|
72
|
-
var path2 = __toESM(require("path"), 1);
|
|
73
|
-
var DATE_RE = /^\d{4}-\d{2}-\d{2}$/;
|
|
74
|
-
var YEAR_RE = /^\d{4}$/;
|
|
75
|
-
var MONTH_RE = /^(0[1-9]|1[0-2])$/;
|
|
76
|
-
var DAY_FILE_RE = /^(0[1-9]|[12]\d|3[01])\.md$/;
|
|
77
|
-
var RAW_DAY_FILE_RE = /^(0[1-9]|[12]\d|3[01])\.jsonl$/;
|
|
78
|
-
function walkThreeLevelDateTree(rootPath, extension) {
|
|
79
|
-
if (!fs2.existsSync(rootPath)) {
|
|
80
|
-
return [];
|
|
81
|
-
}
|
|
82
|
-
const results = [];
|
|
83
|
-
for (const yearEntry of fs2.readdirSync(rootPath, { withFileTypes: true })) {
|
|
84
|
-
if (!yearEntry.isDirectory() || !YEAR_RE.test(yearEntry.name)) continue;
|
|
85
|
-
const yearDir = path2.join(rootPath, yearEntry.name);
|
|
86
|
-
for (const monthEntry of fs2.readdirSync(yearDir, { withFileTypes: true })) {
|
|
87
|
-
if (!monthEntry.isDirectory() || !MONTH_RE.test(monthEntry.name)) continue;
|
|
88
|
-
const monthDir = path2.join(yearDir, monthEntry.name);
|
|
89
|
-
for (const dayEntry of fs2.readdirSync(monthDir, { withFileTypes: true })) {
|
|
90
|
-
if (!dayEntry.isFile()) continue;
|
|
91
|
-
const matches = extension === ".md" ? DAY_FILE_RE.test(dayEntry.name) : RAW_DAY_FILE_RE.test(dayEntry.name);
|
|
92
|
-
if (!matches) continue;
|
|
93
|
-
const day = dayEntry.name.slice(0, extension.length * -1);
|
|
94
|
-
const date = `${yearEntry.name}-${monthEntry.name}-${day}`;
|
|
95
|
-
if (!DATE_RE.test(date)) continue;
|
|
96
|
-
results.push({
|
|
97
|
-
date,
|
|
98
|
-
absolutePath: path2.join(monthDir, dayEntry.name)
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
return results;
|
|
104
|
-
}
|
|
105
|
-
function inDateRange(date, fromDate, toDate) {
|
|
106
|
-
if (fromDate && date < fromDate) {
|
|
107
|
-
return false;
|
|
108
|
-
}
|
|
109
|
-
if (toDate && date > toDate) {
|
|
110
|
-
return false;
|
|
111
|
-
}
|
|
112
|
-
return true;
|
|
113
|
-
}
|
|
114
|
-
function getLedgerRoot(vaultPath) {
|
|
115
|
-
return path2.join(path2.resolve(vaultPath), "ledger");
|
|
116
|
-
}
|
|
117
|
-
function getObservationsRoot(vaultPath) {
|
|
118
|
-
return path2.join(getLedgerRoot(vaultPath), "observations");
|
|
119
|
-
}
|
|
120
|
-
function getArchiveObservationsRoot(vaultPath) {
|
|
121
|
-
return path2.join(getLedgerRoot(vaultPath), "archive", "observations");
|
|
122
|
-
}
|
|
123
|
-
function getLegacyObservationsRoot(vaultPath) {
|
|
124
|
-
return path2.join(path2.resolve(vaultPath), "observations");
|
|
125
|
-
}
|
|
126
|
-
function listLedgerObservationFiles(vaultPath, options = {}) {
|
|
127
|
-
return walkThreeLevelDateTree(getObservationsRoot(vaultPath), ".md").filter((entry) => inDateRange(entry.date, options.fromDate, options.toDate)).map((entry) => ({
|
|
128
|
-
date: entry.date,
|
|
129
|
-
path: entry.absolutePath,
|
|
130
|
-
location: "ledger"
|
|
131
|
-
})).sort((left, right) => left.date.localeCompare(right.date));
|
|
132
|
-
}
|
|
133
|
-
function listArchiveObservationFiles(vaultPath, options = {}) {
|
|
134
|
-
return walkThreeLevelDateTree(getArchiveObservationsRoot(vaultPath), ".md").filter((entry) => inDateRange(entry.date, options.fromDate, options.toDate)).map((entry) => ({
|
|
135
|
-
date: entry.date,
|
|
136
|
-
path: entry.absolutePath,
|
|
137
|
-
location: "archive"
|
|
138
|
-
})).sort((left, right) => left.date.localeCompare(right.date));
|
|
139
|
-
}
|
|
140
|
-
function listLegacyObservationFiles(vaultPath, options = {}) {
|
|
141
|
-
const legacyRoot = getLegacyObservationsRoot(vaultPath);
|
|
142
|
-
if (!fs2.existsSync(legacyRoot)) {
|
|
143
|
-
return [];
|
|
144
|
-
}
|
|
145
|
-
return fs2.readdirSync(legacyRoot, { withFileTypes: true }).filter((entry) => entry.isFile() && DATE_RE.test(entry.name.replace(/\.md$/, "")) && entry.name.endsWith(".md")).map((entry) => {
|
|
146
|
-
const date = entry.name.replace(/\.md$/, "");
|
|
147
|
-
return {
|
|
148
|
-
date,
|
|
149
|
-
path: path2.join(legacyRoot, entry.name),
|
|
150
|
-
location: "legacy"
|
|
151
|
-
};
|
|
152
|
-
}).filter((entry) => inDateRange(entry.date, options.fromDate, options.toDate)).sort((left, right) => left.date.localeCompare(right.date));
|
|
153
|
-
}
|
|
154
|
-
function listObservationFiles(vaultPath, options = {}) {
|
|
155
|
-
const includeLegacy = options.includeLegacy ?? true;
|
|
156
|
-
const includeArchive = options.includeArchive ?? false;
|
|
157
|
-
const dedupeByDate = options.dedupeByDate ?? true;
|
|
158
|
-
const files = [
|
|
159
|
-
...listLedgerObservationFiles(vaultPath, options),
|
|
160
|
-
...includeLegacy ? listLegacyObservationFiles(vaultPath, options) : [],
|
|
161
|
-
...includeArchive ? listArchiveObservationFiles(vaultPath, options) : []
|
|
162
|
-
];
|
|
163
|
-
if (!dedupeByDate) {
|
|
164
|
-
return files.sort((left, right) => left.date.localeCompare(right.date));
|
|
165
|
-
}
|
|
166
|
-
const byDate = /* @__PURE__ */ new Map();
|
|
167
|
-
const locationRank = {
|
|
168
|
-
ledger: 3,
|
|
169
|
-
legacy: 2,
|
|
170
|
-
archive: 1
|
|
171
|
-
};
|
|
172
|
-
for (const file of files) {
|
|
173
|
-
const existing = byDate.get(file.date);
|
|
174
|
-
if (!existing || locationRank[file.location] > locationRank[existing.location]) {
|
|
175
|
-
byDate.set(file.date, file);
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
return [...byDate.values()].sort((left, right) => left.date.localeCompare(right.date));
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
// src/lib/observation-format.ts
|
|
182
|
-
var DATE_HEADING_RE = /^##\s+(\d{4}-\d{2}-\d{2})\s*$/;
|
|
183
|
-
var SCORED_LINE_RE = /^(?:-\s*)?\[(decision|preference|fact|commitment|task|todo|commitment-unresolved|milestone|lesson|relationship|project)\|c=(0(?:\.\d+)?|1(?:\.0+)?)\|i=(0(?:\.\d+)?|1(?:\.0+)?)\]\s+(.+)$/i;
|
|
184
|
-
var EMOJI_LINE_RE = /^(?:-\s*)?(🔴|🟡|🟢)\s+(\d{2}:\d{2})?\s*(.+)$/u;
|
|
185
|
-
var DECISION_RE = /\b(decis(?:ion|ions)?|decid(?:e|ed|ing)|chose|selected|opted|went with|picked)\b/i;
|
|
186
|
-
var PREFERENCE_RE = /\b(prefer(?:ence|s|red)?|likes?|dislikes?|default to|always use|never use|enjoys?|loves?|favou?rite|fan of|interested in|go-to|tend(?:s)? to use|passionate about|hobby|hobbies|(?:I|my|our)\s+(?:own|have|use|got|bought|drive|wear|eat|drink|cook|play|watch|read|listen)|(?:I(?:'m| am))\s+(?:a |an |into |allergic|vegetarian|vegan|gluten|lactose|trying to|learning)|usually|every (?:morning|evening|night|day|week)|routine)\b/i;
|
|
187
|
-
var COMMITMENT_RE = /\b(commit(?:ment|ted)?|promised|deadline|due|scheduled|will deliver|agreed to)\b/i;
|
|
188
|
-
var TODO_RE = /(?:\btodo:\s*|\bwe need to\b|\bdon't forget(?: to)?\b|\bremember to\b|\bmake sure to\b)/i;
|
|
189
|
-
var COMMITMENT_TASK_RE = /\b(?:i'?ll|i will|let me|(?:i'?m\s+)?going to|plan to|should)\b/i;
|
|
190
|
-
var UNRESOLVED_RE = /\b(?:need to figure out|tbd|to be determined)\b/i;
|
|
191
|
-
var DEADLINE_RE = /\b(?:by\s+(?:monday|tuesday|wednesday|thursday|friday|saturday|sunday|tomorrow)|before\s+the\s+\w+|deadline is)\b/i;
|
|
192
|
-
var MILESTONE_RE = /\b(released?|shipped|launched|merged|published|milestone|v\d+\.\d+)\b/i;
|
|
193
|
-
var LESSON_RE = /\b(learn(?:ed|ing|t)|lesson|insight|realized|discovered|never again)\b/i;
|
|
194
|
-
var RELATIONSHIP_RE = /\b(talked to|met with|spoke with|asked|client|partner|teammate|colleague)\b/i;
|
|
195
|
-
var PROJECT_RE = /\b(project|feature|service|repo|api|roadmap|sprint)\b/i;
|
|
196
|
-
function clamp01(value) {
|
|
197
|
-
if (!Number.isFinite(value)) return 0;
|
|
198
|
-
if (value < 0) return 0;
|
|
199
|
-
if (value > 1) return 1;
|
|
200
|
-
return value;
|
|
201
|
-
}
|
|
202
|
-
function scoreFromLegacyPriority(priority) {
|
|
203
|
-
if (priority === "\u{1F534}") return 0.9;
|
|
204
|
-
if (priority === "\u{1F7E1}") return 0.6;
|
|
205
|
-
return 0.2;
|
|
206
|
-
}
|
|
207
|
-
function confidenceFromLegacyPriority(priority) {
|
|
208
|
-
if (priority === "\u{1F534}") return 0.9;
|
|
209
|
-
if (priority === "\u{1F7E1}") return 0.8;
|
|
210
|
-
return 0.7;
|
|
211
|
-
}
|
|
212
|
-
function inferObservationType(content) {
|
|
213
|
-
if (DECISION_RE.test(content)) return "decision";
|
|
214
|
-
if (UNRESOLVED_RE.test(content)) return "commitment-unresolved";
|
|
215
|
-
if (TODO_RE.test(content)) return "todo";
|
|
216
|
-
if (PREFERENCE_RE.test(content)) return "preference";
|
|
217
|
-
if (COMMITMENT_TASK_RE.test(content) || DEADLINE_RE.test(content)) return "task";
|
|
218
|
-
if (COMMITMENT_RE.test(content)) return "commitment";
|
|
219
|
-
if (MILESTONE_RE.test(content)) return "milestone";
|
|
220
|
-
if (LESSON_RE.test(content)) return "lesson";
|
|
221
|
-
if (RELATIONSHIP_RE.test(content)) return "relationship";
|
|
222
|
-
if (PROJECT_RE.test(content)) return "project";
|
|
223
|
-
return "fact";
|
|
224
|
-
}
|
|
225
|
-
function formatScore(value) {
|
|
226
|
-
return clamp01(value).toFixed(2);
|
|
227
|
-
}
|
|
228
|
-
function parseObservationLine(line, date) {
|
|
229
|
-
const scored = line.match(SCORED_LINE_RE);
|
|
230
|
-
if (scored) {
|
|
231
|
-
return {
|
|
232
|
-
date,
|
|
233
|
-
type: scored[1].toLowerCase(),
|
|
234
|
-
confidence: clamp01(Number.parseFloat(scored[2])),
|
|
235
|
-
importance: clamp01(Number.parseFloat(scored[3])),
|
|
236
|
-
content: scored[4].trim(),
|
|
237
|
-
format: "scored",
|
|
238
|
-
rawLine: line
|
|
239
|
-
};
|
|
240
|
-
}
|
|
241
|
-
const emoji = line.match(EMOJI_LINE_RE);
|
|
242
|
-
if (!emoji) {
|
|
243
|
-
return null;
|
|
244
|
-
}
|
|
245
|
-
const priority = emoji[1];
|
|
246
|
-
const time = emoji[2]?.trim();
|
|
247
|
-
const text = emoji[3].trim();
|
|
248
|
-
const content = time ? `${time} ${text}` : text;
|
|
249
|
-
return {
|
|
250
|
-
date,
|
|
251
|
-
type: inferObservationType(content),
|
|
252
|
-
confidence: confidenceFromLegacyPriority(priority),
|
|
253
|
-
importance: scoreFromLegacyPriority(priority),
|
|
254
|
-
content,
|
|
255
|
-
format: "emoji",
|
|
256
|
-
priority,
|
|
257
|
-
time,
|
|
258
|
-
rawLine: line
|
|
259
|
-
};
|
|
260
|
-
}
|
|
261
|
-
function renderScoredObservationLine(record) {
|
|
262
|
-
return `- [${record.type}|c=${formatScore(record.confidence)}|i=${formatScore(record.importance)}] ${record.content.trim()}`;
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
// src/commands/migrate-observations.ts
|
|
266
|
-
function toBackupPath(filePath) {
|
|
267
|
-
if (filePath.toLowerCase().endsWith(".md")) {
|
|
268
|
-
return `${filePath.slice(0, -3)}.emoji-backup.md`;
|
|
269
|
-
}
|
|
270
|
-
return `${filePath}.emoji-backup`;
|
|
271
|
-
}
|
|
272
|
-
function convertObservationMarkdown(markdown) {
|
|
273
|
-
const lines = markdown.split(/\r?\n/);
|
|
274
|
-
let currentDate = "";
|
|
275
|
-
let changed = false;
|
|
276
|
-
const nextLines = lines.map((line) => {
|
|
277
|
-
const heading = line.match(DATE_HEADING_RE);
|
|
278
|
-
if (heading) {
|
|
279
|
-
currentDate = heading[1];
|
|
280
|
-
return line;
|
|
281
|
-
}
|
|
282
|
-
if (!currentDate) {
|
|
283
|
-
return line;
|
|
284
|
-
}
|
|
285
|
-
const parsed = parseObservationLine(line.trim(), currentDate);
|
|
286
|
-
if (!parsed || parsed.format !== "emoji") {
|
|
287
|
-
return line;
|
|
288
|
-
}
|
|
289
|
-
changed = true;
|
|
290
|
-
return renderScoredObservationLine({
|
|
291
|
-
type: parsed.type,
|
|
292
|
-
confidence: parsed.confidence,
|
|
293
|
-
importance: parsed.importance,
|
|
294
|
-
content: parsed.content
|
|
295
|
-
});
|
|
296
|
-
});
|
|
297
|
-
return {
|
|
298
|
-
converted: nextLines.join("\n"),
|
|
299
|
-
changed
|
|
300
|
-
};
|
|
301
|
-
}
|
|
302
|
-
function migrateObservations(vaultPath, options = {}) {
|
|
303
|
-
const dryRun = options.dryRun ?? false;
|
|
304
|
-
const files = listObservationFiles(vaultPath, {
|
|
305
|
-
includeLegacy: true,
|
|
306
|
-
includeArchive: false,
|
|
307
|
-
dedupeByDate: false
|
|
308
|
-
});
|
|
309
|
-
let migrated = 0;
|
|
310
|
-
let backups = 0;
|
|
311
|
-
for (const entry of files) {
|
|
312
|
-
const raw = fs3.readFileSync(entry.path, "utf-8");
|
|
313
|
-
const { converted, changed } = convertObservationMarkdown(raw);
|
|
314
|
-
if (!changed) {
|
|
315
|
-
continue;
|
|
316
|
-
}
|
|
317
|
-
migrated += 1;
|
|
318
|
-
if (dryRun) {
|
|
319
|
-
continue;
|
|
320
|
-
}
|
|
321
|
-
const backupPath = toBackupPath(entry.path);
|
|
322
|
-
if (!fs3.existsSync(backupPath)) {
|
|
323
|
-
fs3.copyFileSync(entry.path, backupPath);
|
|
324
|
-
backups += 1;
|
|
325
|
-
}
|
|
326
|
-
fs3.writeFileSync(entry.path, `${converted.trim()}
|
|
327
|
-
`, "utf-8");
|
|
328
|
-
}
|
|
329
|
-
return {
|
|
330
|
-
scanned: files.length,
|
|
331
|
-
migrated,
|
|
332
|
-
backups,
|
|
333
|
-
dryRun
|
|
334
|
-
};
|
|
335
|
-
}
|
|
336
|
-
async function migrateObservationsCommand(options) {
|
|
337
|
-
const vaultPath = resolveVaultPath({ explicitPath: options.vaultPath });
|
|
338
|
-
const result = migrateObservations(vaultPath, { dryRun: options.dryRun });
|
|
339
|
-
if (result.migrated === 0) {
|
|
340
|
-
console.log("No emoji observations found for migration.");
|
|
341
|
-
return;
|
|
342
|
-
}
|
|
343
|
-
if (result.dryRun) {
|
|
344
|
-
console.log(`Dry run: ${result.migrated} file(s) would be migrated.`);
|
|
345
|
-
return;
|
|
346
|
-
}
|
|
347
|
-
console.log(`Migrated ${result.migrated} file(s); created ${result.backups} backup(s).`);
|
|
348
|
-
}
|
|
349
|
-
function registerMigrateObservationsCommand(program) {
|
|
350
|
-
program.command("migrate-observations").description("Convert legacy emoji observations to scored format with backups").option("--dry-run", "Preview migration without writing files").option("-v, --vault <path>", "Vault path").action(async (rawOptions) => {
|
|
351
|
-
await migrateObservationsCommand({
|
|
352
|
-
vaultPath: rawOptions.vault,
|
|
353
|
-
dryRun: rawOptions.dryRun
|
|
354
|
-
});
|
|
355
|
-
});
|
|
356
|
-
}
|
|
357
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
358
|
-
0 && (module.exports = {
|
|
359
|
-
migrateObservations,
|
|
360
|
-
migrateObservationsCommand,
|
|
361
|
-
registerMigrateObservationsCommand
|
|
362
|
-
});
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
|
|
3
|
-
interface MigrateObservationsOptions {
|
|
4
|
-
vaultPath?: string;
|
|
5
|
-
dryRun?: boolean;
|
|
6
|
-
}
|
|
7
|
-
interface MigrateObservationsResult {
|
|
8
|
-
scanned: number;
|
|
9
|
-
migrated: number;
|
|
10
|
-
backups: number;
|
|
11
|
-
dryRun: boolean;
|
|
12
|
-
}
|
|
13
|
-
declare function migrateObservations(vaultPath: string, options?: {
|
|
14
|
-
dryRun?: boolean;
|
|
15
|
-
}): MigrateObservationsResult;
|
|
16
|
-
declare function migrateObservationsCommand(options: MigrateObservationsOptions): Promise<void>;
|
|
17
|
-
declare function registerMigrateObservationsCommand(program: Command): void;
|
|
18
|
-
|
|
19
|
-
export { type MigrateObservationsOptions, type MigrateObservationsResult, migrateObservations, migrateObservationsCommand, registerMigrateObservationsCommand };
|