litmus-cli 1.0.4 → 1.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/tracker.d.ts.map +1 -1
- package/dist/lib/tracker.js +4 -2
- package/dist/lib/tracker.js.map +1 -1
- package/dist/watcher.cjs +22 -3
- package/package.json +1 -1
- package/src/lib/tracker.ts +5 -2
- package/src/lib/watcher.cjs +22 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tracker.d.ts","sourceRoot":"","sources":["../../src/lib/tracker.ts"],"names":[],"mappings":"AAOA;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"tracker.d.ts","sourceRoot":"","sources":["../../src/lib/tracker.ts"],"names":[],"mappings":"AAOA;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CA4BrD"}
|
package/dist/lib/tracker.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { spawn } from "child_process";
|
|
2
|
-
import { mkdirSync, writeFileSync } from "fs";
|
|
2
|
+
import { mkdirSync, openSync, writeFileSync } from "fs";
|
|
3
3
|
import path from "path";
|
|
4
4
|
import { fileURLToPath } from "url";
|
|
5
5
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
@@ -12,6 +12,7 @@ export function startTracker(projectDir) {
|
|
|
12
12
|
const litmusDir = path.join(projectDir, ".litmus");
|
|
13
13
|
const activityLog = path.join(litmusDir, "activity.jsonl");
|
|
14
14
|
const pidFile = path.join(litmusDir, "tracker.pid");
|
|
15
|
+
const errLog = path.join(litmusDir, "tracker.log");
|
|
15
16
|
const watcherScript = path.join(__dirname, "watcher.cjs");
|
|
16
17
|
try {
|
|
17
18
|
mkdirSync(litmusDir, { recursive: true });
|
|
@@ -19,9 +20,10 @@ export function startTracker(projectDir) {
|
|
|
19
20
|
catch {
|
|
20
21
|
// Non-critical
|
|
21
22
|
}
|
|
23
|
+
const errFd = openSync(errLog, "a");
|
|
22
24
|
const child = spawn("node", [watcherScript, projectDir, activityLog], {
|
|
23
25
|
detached: true,
|
|
24
|
-
stdio: "ignore",
|
|
26
|
+
stdio: ["ignore", "ignore", errFd],
|
|
25
27
|
});
|
|
26
28
|
if (child.pid) {
|
|
27
29
|
child.unref();
|
package/dist/lib/tracker.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tracker.js","sourceRoot":"","sources":["../../src/lib/tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,IAAI,CAAA;
|
|
1
|
+
{"version":3,"file":"tracker.js","sourceRoot":"","sources":["../../src/lib/tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,IAAI,CAAA;AACvD,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAA;AAEnC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;AAE9D;;;;GAIG;AACH,MAAM,UAAU,YAAY,CAAC,UAAkB;IAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC,CAAA;IAClD,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAA;IAC1D,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;IACnD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;IAClD,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;IAEzD,IAAI,CAAC;QACH,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,eAAe;IACjB,CAAC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAEnC,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,aAAa,EAAE,UAAU,EAAE,WAAW,CAAC,EAAE;QACpE,QAAQ,EAAE,IAAI;QACd,KAAK,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC;KACnC,CAAC,CAAA;IAEF,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;QACd,KAAK,CAAC,KAAK,EAAE,CAAA;QACb,IAAI,CAAC;YACH,aAAa,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,CAAA;QACnD,CAAC;QAAC,MAAM,CAAC;YACP,eAAe;QACjB,CAAC;IACH,CAAC;AACH,CAAC"}
|
package/dist/watcher.cjs
CHANGED
|
@@ -14,8 +14,16 @@ const path = require("path")
|
|
|
14
14
|
|
|
15
15
|
const [, , projectDir, activityLogPath] = process.argv
|
|
16
16
|
|
|
17
|
+
process.stderr.write(`[watcher] starting: projectDir=${projectDir} log=${activityLogPath}\n`)
|
|
18
|
+
process.stderr.write(`[watcher] node ${process.version}, platform=${process.platform}, arch=${process.arch}\n`)
|
|
19
|
+
|
|
17
20
|
if (!projectDir || !activityLogPath) {
|
|
18
|
-
process.stderr.write("
|
|
21
|
+
process.stderr.write("[watcher] missing arguments\n")
|
|
22
|
+
process.exit(1)
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if (!fs.existsSync(projectDir)) {
|
|
26
|
+
process.stderr.write(`[watcher] projectDir does not exist: ${projectDir}\n`)
|
|
19
27
|
process.exit(1)
|
|
20
28
|
}
|
|
21
29
|
|
|
@@ -48,13 +56,24 @@ function write(type, relPath) {
|
|
|
48
56
|
log.write(event + "\n")
|
|
49
57
|
}
|
|
50
58
|
|
|
59
|
+
process.on("uncaughtException", (err) => {
|
|
60
|
+
process.stderr.write(`[watcher] uncaughtException: ${err.stack || err}\n`)
|
|
61
|
+
process.exit(1)
|
|
62
|
+
})
|
|
63
|
+
|
|
51
64
|
try {
|
|
52
|
-
fs.watch(projectDir, { recursive: true }, (eventType, filename) => {
|
|
65
|
+
const watcher = fs.watch(projectDir, { recursive: true }, (eventType, filename) => {
|
|
53
66
|
if (!filename) return
|
|
54
67
|
if (shouldIgnore(filename)) return
|
|
55
68
|
write(eventType, filename)
|
|
56
69
|
})
|
|
70
|
+
|
|
71
|
+
watcher.on("error", (err) => {
|
|
72
|
+
process.stderr.write(`[watcher] fs.watch error: ${err}\n`)
|
|
73
|
+
})
|
|
74
|
+
|
|
75
|
+
process.stderr.write("[watcher] started successfully\n")
|
|
57
76
|
} catch (err) {
|
|
58
|
-
process.stderr.write(`[watcher] failed to start: ${err}\n`)
|
|
77
|
+
process.stderr.write(`[watcher] failed to start: ${err.stack || err}\n`)
|
|
59
78
|
process.exit(1)
|
|
60
79
|
}
|
package/package.json
CHANGED
package/src/lib/tracker.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { spawn } from "child_process"
|
|
2
|
-
import { mkdirSync, writeFileSync } from "fs"
|
|
2
|
+
import { mkdirSync, openSync, writeFileSync } from "fs"
|
|
3
3
|
import path from "path"
|
|
4
4
|
import { fileURLToPath } from "url"
|
|
5
5
|
|
|
@@ -14,6 +14,7 @@ export function startTracker(projectDir: string): void {
|
|
|
14
14
|
const litmusDir = path.join(projectDir, ".litmus")
|
|
15
15
|
const activityLog = path.join(litmusDir, "activity.jsonl")
|
|
16
16
|
const pidFile = path.join(litmusDir, "tracker.pid")
|
|
17
|
+
const errLog = path.join(litmusDir, "tracker.log")
|
|
17
18
|
const watcherScript = path.join(__dirname, "watcher.cjs")
|
|
18
19
|
|
|
19
20
|
try {
|
|
@@ -22,9 +23,11 @@ export function startTracker(projectDir: string): void {
|
|
|
22
23
|
// Non-critical
|
|
23
24
|
}
|
|
24
25
|
|
|
26
|
+
const errFd = openSync(errLog, "a")
|
|
27
|
+
|
|
25
28
|
const child = spawn("node", [watcherScript, projectDir, activityLog], {
|
|
26
29
|
detached: true,
|
|
27
|
-
stdio: "ignore",
|
|
30
|
+
stdio: ["ignore", "ignore", errFd],
|
|
28
31
|
})
|
|
29
32
|
|
|
30
33
|
if (child.pid) {
|
package/src/lib/watcher.cjs
CHANGED
|
@@ -14,8 +14,16 @@ const path = require("path")
|
|
|
14
14
|
|
|
15
15
|
const [, , projectDir, activityLogPath] = process.argv
|
|
16
16
|
|
|
17
|
+
process.stderr.write(`[watcher] starting: projectDir=${projectDir} log=${activityLogPath}\n`)
|
|
18
|
+
process.stderr.write(`[watcher] node ${process.version}, platform=${process.platform}, arch=${process.arch}\n`)
|
|
19
|
+
|
|
17
20
|
if (!projectDir || !activityLogPath) {
|
|
18
|
-
process.stderr.write("
|
|
21
|
+
process.stderr.write("[watcher] missing arguments\n")
|
|
22
|
+
process.exit(1)
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if (!fs.existsSync(projectDir)) {
|
|
26
|
+
process.stderr.write(`[watcher] projectDir does not exist: ${projectDir}\n`)
|
|
19
27
|
process.exit(1)
|
|
20
28
|
}
|
|
21
29
|
|
|
@@ -48,13 +56,24 @@ function write(type, relPath) {
|
|
|
48
56
|
log.write(event + "\n")
|
|
49
57
|
}
|
|
50
58
|
|
|
59
|
+
process.on("uncaughtException", (err) => {
|
|
60
|
+
process.stderr.write(`[watcher] uncaughtException: ${err.stack || err}\n`)
|
|
61
|
+
process.exit(1)
|
|
62
|
+
})
|
|
63
|
+
|
|
51
64
|
try {
|
|
52
|
-
fs.watch(projectDir, { recursive: true }, (eventType, filename) => {
|
|
65
|
+
const watcher = fs.watch(projectDir, { recursive: true }, (eventType, filename) => {
|
|
53
66
|
if (!filename) return
|
|
54
67
|
if (shouldIgnore(filename)) return
|
|
55
68
|
write(eventType, filename)
|
|
56
69
|
})
|
|
70
|
+
|
|
71
|
+
watcher.on("error", (err) => {
|
|
72
|
+
process.stderr.write(`[watcher] fs.watch error: ${err}\n`)
|
|
73
|
+
})
|
|
74
|
+
|
|
75
|
+
process.stderr.write("[watcher] started successfully\n")
|
|
57
76
|
} catch (err) {
|
|
58
|
-
process.stderr.write(`[watcher] failed to start: ${err}\n`)
|
|
77
|
+
process.stderr.write(`[watcher] failed to start: ${err.stack || err}\n`)
|
|
59
78
|
process.exit(1)
|
|
60
79
|
}
|