grepmax 0.15.0 → 0.15.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/dist/commands/watch.js
CHANGED
|
@@ -43,6 +43,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
43
43
|
};
|
|
44
44
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
45
|
exports.watch = void 0;
|
|
46
|
+
const fs = __importStar(require("node:fs"));
|
|
46
47
|
const node_child_process_1 = require("node:child_process");
|
|
47
48
|
const path = __importStar(require("node:path"));
|
|
48
49
|
const commander_1 = require("commander");
|
|
@@ -77,11 +78,20 @@ exports.watch = new commander_1.Command("watch")
|
|
|
77
78
|
return;
|
|
78
79
|
}
|
|
79
80
|
if (options.background) {
|
|
80
|
-
// Skip spawn if daemon already running
|
|
81
|
-
//
|
|
82
|
-
|
|
81
|
+
// Skip spawn if daemon already running at the same version.
|
|
82
|
+
// If version mismatches (e.g. after npm install -g), shut down the old
|
|
83
|
+
// daemon so we can start a fresh one with the new code.
|
|
84
|
+
const { isDaemonRunning, sendDaemonCommand } = yield Promise.resolve().then(() => __importStar(require("../lib/utils/daemon-client")));
|
|
83
85
|
if (yield isDaemonRunning()) {
|
|
84
|
-
|
|
86
|
+
const cliVersion = JSON.parse(fs.readFileSync(path.join(__dirname, "../../package.json"), "utf-8")).version;
|
|
87
|
+
const resp = yield sendDaemonCommand({ cmd: "ping" });
|
|
88
|
+
if (resp.version && resp.version === cliVersion) {
|
|
89
|
+
process.exit(0);
|
|
90
|
+
}
|
|
91
|
+
console.log(`Daemon version mismatch (${resp.version} → ${cliVersion}), restarting...`);
|
|
92
|
+
yield sendDaemonCommand({ cmd: "shutdown" });
|
|
93
|
+
// Brief wait for old daemon to release socket/lock
|
|
94
|
+
yield new Promise((r) => setTimeout(r, 2000));
|
|
85
95
|
}
|
|
86
96
|
const logFile = path.join(config_1.PATHS.logsDir, "daemon.log");
|
|
87
97
|
const out = (0, log_rotate_1.openRotatedLog)(logFile);
|
|
@@ -1,4 +1,37 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
36
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
37
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -12,7 +45,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
45
|
exports.writeProgress = writeProgress;
|
|
13
46
|
exports.writeDone = writeDone;
|
|
14
47
|
exports.handleCommand = handleCommand;
|
|
48
|
+
const fs = __importStar(require("node:fs"));
|
|
49
|
+
const path = __importStar(require("node:path"));
|
|
15
50
|
const logger_1 = require("../utils/logger");
|
|
51
|
+
const DAEMON_VERSION = (() => {
|
|
52
|
+
try {
|
|
53
|
+
return JSON.parse(fs.readFileSync(path.join(__dirname, "../../../package.json"), "utf-8")).version;
|
|
54
|
+
}
|
|
55
|
+
catch (_a) {
|
|
56
|
+
return "unknown";
|
|
57
|
+
}
|
|
58
|
+
})();
|
|
16
59
|
/**
|
|
17
60
|
* Write a streaming progress line to the IPC connection.
|
|
18
61
|
*/
|
|
@@ -42,7 +85,7 @@ function handleCommand(daemon, cmd, conn) {
|
|
|
42
85
|
(0, logger_1.debug)("daemon", `ipc cmd=${cmd.cmd}${cmd.root ? ` root=${cmd.root}` : ""}`);
|
|
43
86
|
switch (cmd.cmd) {
|
|
44
87
|
case "ping":
|
|
45
|
-
return { ok: true, pid: process.pid, uptime: daemon.uptime() };
|
|
88
|
+
return { ok: true, pid: process.pid, uptime: daemon.uptime(), version: DAEMON_VERSION };
|
|
46
89
|
case "watch": {
|
|
47
90
|
const root = String(cmd.root || "");
|
|
48
91
|
if (!root)
|
package/package.json
CHANGED