triflux 10.3.2 → 10.3.4
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/.claude-plugin/plugin.json +22 -22
- package/LICENSE +21 -21
- package/README.ko.md +16 -0
- package/README.md +8 -0
- package/hooks/hook-registry.json +256 -256
- package/hub/adaptive-inject.mjs +1 -1
- package/hub/assign-callbacks.mjs +120 -120
- package/hub/delegator/index.mjs +14 -14
- package/hub/delegator/tool-definitions.mjs +35 -35
- package/hub/hitl.mjs +143 -143
- package/hub/lib/path-utils.mjs +167 -0
- package/hub/router.mjs +791 -791
- package/hub/session-fingerprint.mjs +1 -1
- package/hub/team/cli/commands/attach.mjs +37 -37
- package/hub/team/cli/commands/debug.mjs +74 -74
- package/hub/team/cli/commands/focus.mjs +53 -53
- package/hub/team/cli/commands/list.mjs +24 -24
- package/hub/team/cli/commands/start/start-in-process.mjs +40 -40
- package/hub/team/cli/commands/start/start-mux.mjs +73 -73
- package/hub/team/cli/commands/start/start-wt.mjs +69 -69
- package/hub/team/cli/commands/tasks.mjs +13 -13
- package/hub/team/cli/render.mjs +30 -30
- package/hub/team/cli/services/attach-fallback.mjs +54 -54
- package/hub/team/cli/services/member-selector.mjs +30 -30
- package/hub/team/cli/services/native-control.mjs +116 -116
- package/hub/team/cli/services/task-model.mjs +30 -30
- package/hub/team/notify.mjs +1 -1
- package/hub/team/orchestrator.mjs +161 -161
- package/hub/team/runtime-strategy.mjs +74 -0
- package/hub/team/session.mjs +611 -611
- package/hub/team/shared.mjs +13 -13
- package/hub/team/worktree-lifecycle.mjs +61 -2
- package/hub/tray.mjs +368 -368
- package/hub/workers/codex-mcp.mjs +507 -507
- package/hub/workers/factory.mjs +21 -21
- package/hud/hud-qos-status.mjs +17 -3
- package/hud/mission-board.mjs +53 -0
- package/hud/providers/claude.mjs +95 -22
- package/hud/renderers.mjs +39 -5
- package/mesh/index.mjs +63 -0
- package/mesh/mesh-budget.mjs +128 -0
- package/mesh/mesh-heartbeat.mjs +100 -0
- package/mesh/mesh-protocol.mjs +96 -0
- package/mesh/mesh-queue.mjs +165 -0
- package/mesh/mesh-registry.mjs +78 -0
- package/mesh/mesh-router.mjs +76 -0
- package/package.json +2 -1
- package/scripts/completions/tfx.bash +47 -47
- package/scripts/completions/tfx.fish +44 -44
- package/scripts/completions/tfx.zsh +83 -83
- package/scripts/demo.mjs +169 -0
- package/scripts/headless-guard.mjs +16 -4
- package/scripts/hub-ensure.mjs +120 -120
- package/scripts/keyword-detector.mjs +272 -272
- package/scripts/keyword-rules-expander.mjs +521 -521
- package/scripts/lib/mcp-server-catalog.mjs +118 -118
- package/scripts/lib/skill-state.mjs +220 -0
- package/scripts/notion-read.mjs +553 -553
- package/scripts/test-tfx-route-no-claude-native.mjs +57 -57
- package/scripts/tfx-batch-stats.mjs +96 -96
- package/skills/.omc/state/agent-replay-8f0e10a9-9693-4410-96f5-a6b07e8ed995.jsonl +0 -1
- package/skills/.omc/state/idle-notif-cooldown.json +0 -3
- package/skills/.omc/state/last-tool-error.json +0 -7
- package/skills/.omc/state/subagent-tracking.json +0 -7
- package/skills/tfx-remote-spawn/references/hosts.json +0 -16
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
// hub/lib/path-utils.mjs — Windows/POSIX 경로 변환 유틸리티
|
|
2
|
+
|
|
3
|
+
import { platform } from 'node:os';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Windows 경로를 Git Bash 스타일 POSIX 경로로 변환한다.
|
|
7
|
+
* C:\foo\bar → /c/foo/bar
|
|
8
|
+
* 이미 POSIX 경로면 그대로 반환.
|
|
9
|
+
* null/undefined → 빈 문자열
|
|
10
|
+
* @param {string|null|undefined} windowsPath
|
|
11
|
+
* @returns {string}
|
|
12
|
+
*/
|
|
13
|
+
export function toPosixPath(windowsPath) {
|
|
14
|
+
if (windowsPath == null) return '';
|
|
15
|
+
const p = String(windowsPath);
|
|
16
|
+
if (!p) return '';
|
|
17
|
+
|
|
18
|
+
// 이미 POSIX 경로 (/ 로 시작하거나 드라이브 레터 없음)
|
|
19
|
+
const winDriveMatch = p.match(/^([A-Za-z]):[/\\](.*)/);
|
|
20
|
+
if (!winDriveMatch) {
|
|
21
|
+
// 백슬래시만 있는 상대 경로도 forward slash로 변환
|
|
22
|
+
return p.replace(/\\/g, '/');
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const drive = winDriveMatch[1].toLowerCase();
|
|
26
|
+
const rest = winDriveMatch[2].replace(/\\/g, '/');
|
|
27
|
+
return `/${drive}/${rest}`;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* POSIX 경로(Git Bash 스타일)를 Windows 경로로 변환한다.
|
|
32
|
+
* /c/foo/bar → C:\foo\bar
|
|
33
|
+
* 이미 Windows 경로면 그대로 반환.
|
|
34
|
+
* null/undefined → 빈 문자열
|
|
35
|
+
* @param {string|null|undefined} posixPath
|
|
36
|
+
* @returns {string}
|
|
37
|
+
*/
|
|
38
|
+
export function toWindowsPath(posixPath) {
|
|
39
|
+
if (posixPath == null) return '';
|
|
40
|
+
const p = String(posixPath);
|
|
41
|
+
if (!p) return '';
|
|
42
|
+
|
|
43
|
+
// 이미 Windows 경로
|
|
44
|
+
if (/^[A-Za-z]:/.test(p)) {
|
|
45
|
+
return p.replace(/\//g, '\\');
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Git Bash 스타일: /c/foo/bar
|
|
49
|
+
const gitBashMatch = p.match(/^\/([a-zA-Z])(\/.*)?$/);
|
|
50
|
+
if (gitBashMatch) {
|
|
51
|
+
const drive = gitBashMatch[1].toUpperCase();
|
|
52
|
+
const rest = gitBashMatch[2] ? gitBashMatch[2].replace(/\//g, '\\') : '\\';
|
|
53
|
+
return `${drive}:${rest}`;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return p;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* 현재 OS에 맞게 경로를 정규화한다.
|
|
61
|
+
* win32: backslash, 그 외: forward slash
|
|
62
|
+
* @param {string|null|undefined} p
|
|
63
|
+
* @returns {string}
|
|
64
|
+
*/
|
|
65
|
+
export function normalizePath(p) {
|
|
66
|
+
if (p == null) return '';
|
|
67
|
+
const str = String(p);
|
|
68
|
+
if (process.platform === 'win32') {
|
|
69
|
+
return str.replace(/\//g, '\\');
|
|
70
|
+
}
|
|
71
|
+
return str.replace(/\\/g, '/');
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* 쉘 타입에 맞는 경로로 변환한다.
|
|
76
|
+
* @param {string|null|undefined} path
|
|
77
|
+
* @param {'git-bash'|'wsl'|'cmd'|'powershell'} shellType
|
|
78
|
+
* @returns {string}
|
|
79
|
+
*/
|
|
80
|
+
export function resolveShellPath(path, shellType) {
|
|
81
|
+
if (path == null) return '';
|
|
82
|
+
const p = String(path);
|
|
83
|
+
|
|
84
|
+
switch (shellType) {
|
|
85
|
+
case 'git-bash':
|
|
86
|
+
return toPosixPath(p);
|
|
87
|
+
|
|
88
|
+
case 'wsl': {
|
|
89
|
+
// Git Bash 경로를 먼저 Windows로 변환 후 WSL 형식으로
|
|
90
|
+
let winPath = /^[A-Za-z]:/.test(p) ? p : toWindowsPath(p);
|
|
91
|
+
const wslDriveMatch = winPath.match(/^([A-Za-z]):[/\\](.*)/);
|
|
92
|
+
if (wslDriveMatch) {
|
|
93
|
+
const drive = wslDriveMatch[1].toLowerCase();
|
|
94
|
+
const rest = wslDriveMatch[2].replace(/\\/g, '/');
|
|
95
|
+
return rest ? `/mnt/${drive}/${rest}` : `/mnt/${drive}`;
|
|
96
|
+
}
|
|
97
|
+
// 이미 /mnt/ 형식이면 그대로
|
|
98
|
+
if (p.startsWith('/mnt/')) return p;
|
|
99
|
+
return p.replace(/\\/g, '/');
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
case 'cmd':
|
|
103
|
+
case 'powershell':
|
|
104
|
+
return toWindowsPath(p);
|
|
105
|
+
|
|
106
|
+
default:
|
|
107
|
+
return p;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* 환경 변수와 플랫폼 정보로 현재 쉘 타입을 추론한다.
|
|
113
|
+
* @returns {'git-bash'|'wsl'|'cmd'|'powershell'|'unix'}
|
|
114
|
+
*/
|
|
115
|
+
export function detectShellType() {
|
|
116
|
+
// WSL 감지: WSL_DISTRO_NAME 또는 WSLENV
|
|
117
|
+
if (process.env.WSL_DISTRO_NAME || process.env.WSLENV) {
|
|
118
|
+
return 'wsl';
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// Windows 플랫폼
|
|
122
|
+
if (process.platform === 'win32') {
|
|
123
|
+
const shell = process.env.SHELL || '';
|
|
124
|
+
const term = process.env.TERM || '';
|
|
125
|
+
const msystem = process.env.MSYSTEM || '';
|
|
126
|
+
|
|
127
|
+
// Git Bash 감지: SHELL=/usr/bin/bash + MSYSTEM=MINGW64 등
|
|
128
|
+
if (
|
|
129
|
+
shell.includes('bash') ||
|
|
130
|
+
msystem.startsWith('MINGW') ||
|
|
131
|
+
msystem.startsWith('MSYS') ||
|
|
132
|
+
term === 'xterm'
|
|
133
|
+
) {
|
|
134
|
+
return 'git-bash';
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// PowerShell 감지
|
|
138
|
+
if (process.env.PSModulePath || process.env.PSHOME) {
|
|
139
|
+
return 'powershell';
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
return 'cmd';
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
// 비-Windows
|
|
146
|
+
return 'unix';
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
/**
|
|
150
|
+
* WSL 경로 여부를 확인한다 (/mnt/ 시작).
|
|
151
|
+
* @param {string|null|undefined} p
|
|
152
|
+
* @returns {boolean}
|
|
153
|
+
*/
|
|
154
|
+
export function isWslPath(p) {
|
|
155
|
+
if (p == null) return false;
|
|
156
|
+
return String(p).startsWith('/mnt/');
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
/**
|
|
160
|
+
* Git Bash 경로 여부를 확인한다 (/c/ 또는 /d/ 등 단일 소문자 드라이브 레터).
|
|
161
|
+
* @param {string|null|undefined} p
|
|
162
|
+
* @returns {boolean}
|
|
163
|
+
*/
|
|
164
|
+
export function isGitBashPath(p) {
|
|
165
|
+
if (p == null) return false;
|
|
166
|
+
return /^\/[a-zA-Z](\/|$)/.test(String(p));
|
|
167
|
+
}
|