Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improved foreground process identification #6

Merged

Conversation

joncrangle
Copy link
Contributor

The PR updates the match statement so that it covers Windows directories (backslash for dirs) as well as unix-based systems (forward slash).

I created this as a draft because I'd like to test it some more on various platforms with different processes running and also to get some feedback.

If a foreground process isn't found (which is expected behaviour for most non-local domains), the idea is to then check the domain name. If it isn't a local domain, we would then use the domain name for the process name, because resolving the foreground process won't be possible.

If we're dealing with a local domain and couldn't resolve a foreground process name, the idea is to use the tab title as the process name. Wezterm will attempt to resolve the OSC 1/2 sequences to fill in a title name (see get_title in Wezterm docs), and the title will default to "Wezterm" otherwise.

I know Windows has some odd behaviour with OSC 2 sequences that I'd like to test further as well to see what the tab title gets set to, and whether we would need to do some matching for Windows PCs.

@joncrangle joncrangle marked this pull request as ready for review September 4, 2024 17:07
@joncrangle
Copy link
Contributor Author

I found that using the title before domain worked better. For sshmux domains, Wezterm is able to guess the foreground process and set the title to that process, so it made sense to check that before checking the domain. This works well on Mac and Linux.

Wezterm sometimes fails to correctly guess the foreground process on Windows, and will show the running shell process (pwsh.exe in my case) rather than its child process. This is a Windows issue, and to get around it the user would need to alias commands using env vars (see discussion in wez/wezterm#3597). I can't think of a way to get around this within the plugin, but it isn't breaking since this component will still always return a value, with 'wezterm' being the fallback default.

@michaelbrusegard michaelbrusegard merged commit 1d1ed6a into michaelbrusegard:main Sep 4, 2024
@joncrangle joncrangle deleted the process-improvements branch September 5, 2024 04:57
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.

2 participants