Skip to content

Conversation

@PhantomYdn
Copy link

When multiple opencode instances share the same CWD, the previous CWD-based discovery could select the wrong instance. This was particularly problematic with tmux provider since opencode processes spawned via tmux are not descendants of Neovim.

Changes:

  • Add get_port() method to provider interface
  • Implement get_port() for tmux provider using pane PID tracing
  • Add process utilities (get_descendants, get_listening_port)
  • Check provider's get_port() before falling back to CWD discovery
  • Other providers return nil (fallback to existing behavior)

Fixes #118

When multiple opencode instances share the same CWD, the previous
CWD-based discovery could select the wrong instance. This was
particularly problematic with tmux provider since opencode processes
spawned via tmux are not descendants of Neovim.

Changes:
- Add get_port() method to provider interface
- Implement get_port() for tmux provider using pane PID tracing
- Add process utilities (get_descendants, get_listening_port)
- Check provider's get_port() before falling back to CWD discovery
- Other providers return nil (fallback to existing behavior)

Fixes NickvanDyke#118
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

bug: potentially targets zombie opencode processes

1 participant