diff --git a/src/extraction/index.ts b/src/extraction/index.ts index 95e47e85f..db69d25ad 100644 --- a/src/extraction/index.ts +++ b/src/extraction/index.ts @@ -191,7 +191,7 @@ export function buildDefaultIgnore(rootDir: string): Ignore { * (See issue #193.) */ function collectGitFiles(repoDir: string, prefix: string, files: Set): void { - const gitOpts = { cwd: repoDir, encoding: 'utf-8' as const, timeout: 30000, maxBuffer: 50 * 1024 * 1024, stdio: ['pipe', 'pipe', 'pipe'] as ['pipe', 'pipe', 'pipe'] }; + const gitOpts = { cwd: repoDir, encoding: 'utf-8' as const, timeout: 30000, maxBuffer: 50 * 1024 * 1024, stdio: ['pipe', 'pipe', 'pipe'] as ['pipe', 'pipe', 'pipe'], windowsHide: true }; // Tracked files. --recurse-submodules pulls in files from active submodules, // which the index would otherwise represent only as a commit pointer. @@ -241,7 +241,7 @@ function getGitVisibleFiles(rootDir: string): Set | null { const gitRoot = execFileSync( 'git', ['rev-parse', '--show-toplevel'], - { cwd: rootDir, encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'] } + { cwd: rootDir, encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'], windowsHide: true } ).trim(); if (path.resolve(gitRoot) !== path.resolve(rootDir)) { @@ -250,7 +250,7 @@ function getGitVisibleFiles(rootDir: string): Set | null { execFileSync( 'git', ['check-ignore', '-q', path.resolve(rootDir)], - { cwd: rootDir, encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'] } + { cwd: rootDir, encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'], windowsHide: true } ); // Directory is gitignored by parent repo — fall back to filesystem walk return null; @@ -291,7 +291,7 @@ function getGitChangedFiles(rootDir: string): GitChanges | null { const output = execFileSync( 'git', ['status', '--porcelain', '--no-renames'], - { cwd: rootDir, encoding: 'utf-8', timeout: 10000, stdio: ['pipe', 'pipe', 'pipe'] } + { cwd: rootDir, encoding: 'utf-8', timeout: 10000, stdio: ['pipe', 'pipe', 'pipe'], windowsHide: true } ); const modified: string[] = []; diff --git a/src/extraction/wasm-runtime-flags.ts b/src/extraction/wasm-runtime-flags.ts index e44c84d8d..c1b30a63e 100644 --- a/src/extraction/wasm-runtime-flags.ts +++ b/src/extraction/wasm-runtime-flags.ts @@ -98,6 +98,7 @@ export function relaunchWithWasmRuntimeFlagsIfNeeded(scriptPath: string): void { const result = spawnSync(process.execPath, argv, { stdio: 'inherit', env: { ...process.env, [RELAUNCH_GUARD_ENV]: '1', [HOST_PPID_ENV]: String(process.ppid) }, + windowsHide: true, }); if (result.error) { diff --git a/src/installer/index.ts b/src/installer/index.ts index ce102aa2e..5893f7b6e 100644 --- a/src/installer/index.ts +++ b/src/installer/index.ts @@ -119,7 +119,7 @@ export async function runInstallerWithOptions(opts: RunInstallerOptions): Promis const s = clack.spinner(); s.start('Installing codegraph CLI...'); try { - execSync('npm install -g @colbymchenry/codegraph', { stdio: 'pipe' }); + execSync('npm install -g @colbymchenry/codegraph', { stdio: 'pipe', windowsHide: true }); s.stop('Installed codegraph CLI on PATH'); } catch { s.stop('Could not install (permission denied)'); diff --git a/src/installer/targets/antigravity.ts b/src/installer/targets/antigravity.ts index 9ecc4bc8c..1c128491a 100644 --- a/src/installer/targets/antigravity.ts +++ b/src/installer/targets/antigravity.ts @@ -124,6 +124,7 @@ function resolveCodegraphCommand(): string { encoding: 'utf-8', stdio: ['ignore', 'pipe', 'ignore'], shell: '/bin/bash', + windowsHide: true, }).trim(); if (resolved && fs.existsSync(resolved)) return resolved; } catch { diff --git a/src/mcp/engine.ts b/src/mcp/engine.ts index 15439b047..fec96d506 100644 --- a/src/mcp/engine.ts +++ b/src/mcp/engine.ts @@ -147,8 +147,7 @@ export class MCPEngine { const resolvedRoot = findNearestCodeGraphRoot(searchFrom); if (!resolvedRoot) { - // No .codegraph/ above searchFrom — that's not an error, sessions may - // still discover one later via roots/list. + // No .codegraph/ above searchFrom. Sessions may still discover one later via roots/list this.projectPath = searchFrom; return; } diff --git a/src/sync/git-hooks.ts b/src/sync/git-hooks.ts index 3344c5ff9..a657d7545 100644 --- a/src/sync/git-hooks.ts +++ b/src/sync/git-hooks.ts @@ -44,6 +44,7 @@ export function isGitRepo(projectRoot: string): boolean { cwd: projectRoot, encoding: 'utf8', stdio: ['ignore', 'pipe', 'ignore'], + windowsHide: true, }).trim(); return out === 'true'; } catch { @@ -61,6 +62,7 @@ function gitHooksDir(projectRoot: string): string | null { cwd: projectRoot, encoding: 'utf8', stdio: ['ignore', 'pipe', 'ignore'], + windowsHide: true, }).trim(); if (!out) return null; return path.isAbsolute(out) ? out : path.resolve(projectRoot, out); diff --git a/src/sync/worktree.ts b/src/sync/worktree.ts index 27bfca546..bf370b178 100644 --- a/src/sync/worktree.ts +++ b/src/sync/worktree.ts @@ -35,6 +35,7 @@ export function gitWorktreeRoot(dir: string): string | null { cwd: dir, encoding: 'utf8', stdio: ['ignore', 'pipe', 'ignore'], + windowsHide: true, }).trim(); return out ? realpath(out) : null; } catch {