fix(doctor): require --restart-sessions flag to cycle patrol sessions (gt-j44ri)

Previously `gt doctor --fix` would automatically kill and restart patrol
sessions when fixing stale settings.json files. This was disruptive as it
interrupted work without explicit consent.

Now session cycling only happens when `--restart-sessions` is explicitly
passed along with `--fix`. Without the flag, settings files are updated
but running sessions are left alone.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
capable
2026-01-07 00:18:02 -08:00
committed by Steve Yegge
parent 59799f551c
commit ee167ae1f1
3 changed files with 24 additions and 17 deletions

View File

@@ -326,14 +326,17 @@ func (c *ClaudeSettingsCheck) Fix(ctx *CheckContext) error {
continue
}
// Only cycle patrol roles that can auto-recover (daemon restarts them).
// Crew and polecats are spawned on-demand and won't auto-restart.
if sf.agentType == "witness" || sf.agentType == "refinery" ||
sf.agentType == "deacon" || sf.agentType == "mayor" {
running, _ := t.HasSession(sf.sessionName)
if running {
// Cycle the agent by killing and letting gt up restart it
_ = t.KillSession(sf.sessionName)
// Only cycle patrol roles if --restart-sessions was explicitly passed.
// This prevents unexpected session restarts during routine --fix operations.
// Crew and polecats are spawned on-demand and won't auto-restart anyway.
if ctx.RestartSessions {
if sf.agentType == "witness" || sf.agentType == "refinery" ||
sf.agentType == "deacon" || sf.agentType == "mayor" {
running, _ := t.HasSession(sf.sessionName)
if running {
// Cycle the agent by killing and letting gt up restart it
_ = t.KillSession(sf.sessionName)
}
}
}
}

View File

@@ -38,9 +38,10 @@ func (s CheckStatus) String() string {
// CheckContext provides context for running checks.
type CheckContext struct {
TownRoot string // Root directory of the Gas Town workspace
RigName string // Rig name (empty for town-level checks)
Verbose bool // Enable verbose output
TownRoot string // Root directory of the Gas Town workspace
RigName string // Rig name (empty for town-level checks)
Verbose bool // Enable verbose output
RestartSessions bool // Restart patrol sessions when fixing (requires explicit --restart-sessions flag)
}
// RigPath returns the full path to the rig directory.