triflux 10.17.1 → 10.17.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
{
|
|
10
10
|
"name": "triflux",
|
|
11
11
|
"description": "Tri-CLI orchestrator for Claude Code. Routes tasks across Claude + Codex + Gemini with consensus intelligence, natural language routing, 42 skills, and cross-model review.",
|
|
12
|
-
"version": "10.17.
|
|
12
|
+
"version": "10.17.2",
|
|
13
13
|
"author": {
|
|
14
14
|
"name": "tellang"
|
|
15
15
|
},
|
|
@@ -30,5 +30,5 @@
|
|
|
30
30
|
]
|
|
31
31
|
}
|
|
32
32
|
],
|
|
33
|
-
"version": "10.17.
|
|
33
|
+
"version": "10.17.2"
|
|
34
34
|
}
|
|
@@ -233,6 +233,29 @@ function hasLiveAncestorChain(pid, procMap, protectedPids) {
|
|
|
233
233
|
return false;
|
|
234
234
|
}
|
|
235
235
|
|
|
236
|
+
function hasLiveCliDescendant(pid, procMap) {
|
|
237
|
+
const children = new Map();
|
|
238
|
+
for (const proc of procMap.values()) {
|
|
239
|
+
if (!Number.isFinite(proc.ppid) || proc.ppid <= 0) continue;
|
|
240
|
+
const list = children.get(proc.ppid) || [];
|
|
241
|
+
list.push(proc);
|
|
242
|
+
children.set(proc.ppid, list);
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
const visited = new Set();
|
|
246
|
+
const stack = [...(children.get(pid) || [])];
|
|
247
|
+
while (stack.length > 0) {
|
|
248
|
+
const proc = stack.pop();
|
|
249
|
+
if (!proc || visited.has(proc.pid)) continue;
|
|
250
|
+
visited.add(proc.pid);
|
|
251
|
+
if (LIVE_CLI_SESSION_ROOT_NAMES.has(normalizeName(proc.name))) {
|
|
252
|
+
return true;
|
|
253
|
+
}
|
|
254
|
+
stack.push(...(children.get(proc.pid) || []));
|
|
255
|
+
}
|
|
256
|
+
return false;
|
|
257
|
+
}
|
|
258
|
+
|
|
236
259
|
/**
|
|
237
260
|
* Legacy wrapper for scoped orphan node runtime cleanup.
|
|
238
261
|
* @param {Parameters<typeof cleanupOrphanRuntimeProcesses>[0]} opts
|
|
@@ -808,7 +831,8 @@ export function cleanupOrphanRuntimeProcesses({
|
|
|
808
831
|
if (legacy) {
|
|
809
832
|
if (
|
|
810
833
|
LEGACY_ORPHAN_KILLABLE_NAMES.has(name) &&
|
|
811
|
-
!hasLiveAncestorChain(proc.pid, procMap, protectedSet)
|
|
834
|
+
!hasLiveAncestorChain(proc.pid, procMap, protectedSet) &&
|
|
835
|
+
!hasLiveCliDescendant(proc.pid, procMap)
|
|
812
836
|
) {
|
|
813
837
|
shouldKill = true;
|
|
814
838
|
killReason = "legacy_orphan_ancestor_chain_dead";
|
|
@@ -816,7 +840,8 @@ export function cleanupOrphanRuntimeProcesses({
|
|
|
816
840
|
} else if (name === "bun.exe") {
|
|
817
841
|
if (
|
|
818
842
|
hasExactGbrainServe(proc.commandLine) &&
|
|
819
|
-
!hasLiveAncestorChain(proc.pid, procMap, protectedSet)
|
|
843
|
+
!hasLiveAncestorChain(proc.pid, procMap, protectedSet) &&
|
|
844
|
+
!hasLiveCliDescendant(proc.pid, procMap)
|
|
820
845
|
) {
|
|
821
846
|
shouldKill = true;
|
|
822
847
|
killReason = "bun_gbrain_serve_orphan";
|
package/package.json
CHANGED
|
@@ -90,6 +90,27 @@ function hasProtectedAncestor(pid, procMap) {
|
|
|
90
90
|
return false;
|
|
91
91
|
}
|
|
92
92
|
|
|
93
|
+
function hasProtectedDescendant(pid, procMap) {
|
|
94
|
+
const children = new Map();
|
|
95
|
+
for (const proc of procMap.values()) {
|
|
96
|
+
if (!Number.isFinite(proc.ppid) || proc.ppid <= 0) continue;
|
|
97
|
+
const list = children.get(proc.ppid) || [];
|
|
98
|
+
list.push(proc);
|
|
99
|
+
children.set(proc.ppid, list);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
const seen = new Set();
|
|
103
|
+
const stack = [...(children.get(Number(pid)) || [])];
|
|
104
|
+
while (stack.length > 0) {
|
|
105
|
+
const proc = stack.pop();
|
|
106
|
+
if (!proc || seen.has(proc.pid)) continue;
|
|
107
|
+
seen.add(proc.pid);
|
|
108
|
+
if (PROTECTED_ANCESTOR_NAMES.has(proc.name)) return true;
|
|
109
|
+
stack.push(...(children.get(proc.pid) || []));
|
|
110
|
+
}
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
|
|
93
114
|
export function shouldKillTrackedPid({
|
|
94
115
|
pid,
|
|
95
116
|
pidFileMtimeMs,
|
|
@@ -110,6 +131,7 @@ export function shouldKillTrackedPid({
|
|
|
110
131
|
}
|
|
111
132
|
|
|
112
133
|
if (hasProtectedAncestor(pid, procMap)) return false;
|
|
134
|
+
if (hasProtectedDescendant(pid, procMap)) return false;
|
|
113
135
|
|
|
114
136
|
return true;
|
|
115
137
|
}
|