-
Notifications
You must be signed in to change notification settings - Fork 29.8k
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
Prepending PATH env var with environmentVariableCollection doesn't work on macOS #99878
Comments
Fixes #2209, but currently a bit doesn't currently work well because of microsoft/vscode#99878.
Fixes #2209, but doesn't currently work well because of microsoft/vscode#99878.
@DanTup to see whether it's a vscode problem or otherwise you can do a trace log to see what environment the terminal is starting up with https://github.com/microsoft/vscode/wiki/Terminal-Issues#enabling-trace-logging If the prepend is there, I don't think there's anything we can do? |
@Tyriar I believe the issue is as you describe, which is the default shell startup is building its wn path (with I don't know the solution, but it feels broken enough that it seems worthwhile trying to solve. For example could VS Code pass its own script to the shell to execute that does the prepending? Or could it reliable send an |
I had tried with your samples and calling I'm not saying it's VS Code's fault, I just think it's worth VS Code trying to work around in order to have this feature work well. I waited a really long time for this feature, and it sucks that it doesn't seem like I'll be able to use it 😞 |
Yeah this is annoying... I really don't like sending text but it does seem like a workaround is in order. How about the terminal checks on macOS for whether |
I guess you mean whether it's set in |
Yes I mean checking the args the terminal is launched with, which will take |
We (vscode-go) were trying to use this API to change the Following the suggestion, I first tried to sendText command to each shell terminal on darwin in addition to the So, I switched to completely avoid the call of |
… API vscode.ExtensionContext.EnvironmentVariableCollection is available since 1.46 (May 2020 release https://code.visualstudio.com/updates/v1_46#_environment-variable-collection) This API is specifically designed to help easy mutation of terminal environment, so we are trying to use it now. I hope this helps to address a couple of bugs related to the shell detection and the correct command and path escaping discovered during testing on Windows. Unfortunately, this API does not work well on Mac microsoft/vscode#99878 due to the peculiarity described in https://code.visualstudio.com/docs/editor/integrated-terminal#_why-are-there-duplicate-paths-in-the-terminals-path-environment-variable-andor-why-are-they-reversed So, we use the new API only for non-darwin OSes for now. On Mac, we send the command as done before unless users explicitly chose to use `-l` or `--login` parameter. And moved addGoRuntimeBaseToPATH to goEnvironmentStatus.ts because I think this is a better place. Updates golang#378 Change-Id: I56ada362fb422bca9c789eae30c6239cac5b4711
… API vscode.ExtensionContext.EnvironmentVariableCollection is available since 1.46 (May 2020 release https://code.visualstudio.com/updates/v1_46#_environment-variable-collection) This API is specifically designed to help easy mutation of terminal environment, so we are trying to use it now. I hope this helps to address a couple of bugs related to the shell detection and the correct command and path escaping discovered during testing on Windows. Unfortunately, this API does not work well on Mac microsoft/vscode#99878 due to the peculiarity described in https://code.visualstudio.com/docs/editor/integrated-terminal#_why-are-there-duplicate-paths-in-the-terminals-path-environment-variable-andor-why-are-they-reversed So, we use the new API only for non-darwin OSes for now. On Mac, we send the command as done before unless users explicitly chose to use `-l` or `--login` parameter. And moved addGoRuntimeBaseToPATH to goEnvironmentStatus.ts because I think this is a better place. Updates #378 Change-Id: I56ada362fb422bca9c789eae30c6239cac5b4711 Reviewed-on: https://go-review.googlesource.com/c/vscode-go/+/245127 Reviewed-by: Brayden Cloud <bcloud@google.com> Reviewed-by: Hyang-Ah Hana Kim <hyangah@gmail.com>
@Tyriar I probably misinterpreted your following suggesting in my implementation. Here you meant that the workaround is to send the export commands when
|
@Tyriar I would also like to have this work on macOS. Any variable you set is probably overridden by the rc files. How about the workaround used by Jetbrains IDEs? They seem to have define the startup order and after sourcing the Its not ideal and looks very ugly, but better than sending texts after activation. I remember you were also not a big fan sending texts to terminal - #98490 (comment) I was trying to write an extension to set paths and variables, and they are comfortably overwritten by the startup scripts. collection.prepend("PATH", `${pythonPath}:`);
collection.replace("JAVA_HOME", javaDir); So |
I misuderstood the comment in microsoft/vscode#99878 (comment) which resulted in that the PATH change does not apply with the default shell args settings in OS X. As noted in #544 (comment) VS Code sets `-l` as the default shell arg. I also attempted to run updateIntegratedTerminal after running environmentVariableCollection.prepend. But it seems like the onDidOpenTerminal handler is not invoked when VS Code relaunches the terminals to apply the environmentVariableCollection changes. Tested manually with "terminal.integrated.shellArgs.osx": [] and without the setting. Fixes #544 Change-Id: Icbaaa5131893038f85e322bad1491a99f26378fd Reviewed-on: https://go-review.googlesource.com/c/vscode-go/+/251161 Reviewed-by: Suzy Mueller <suzmue@golang.org>
I'm not very familiar with how this works, but now a lot of it has shipped do you have a better idea of whether it can solve this? Judging by the issues being linked here above, it isn't only Dart that would really like this. If you think it'd work but don't plan to work on it, could you provide any pointers for if someone wanted to try and contribute it? Thanks! |
@DanTup actually had a discussion with the Python team around this so I'm guessing this will get prioritized soon. The way I'm envisioning this working is for some environment variable being set (VSCODE_ENV_CONTRIBUTION or something?) and the shell integration script checking that and re-applying it after the init scripts run |
Awesome, thanks! I'm definitely interested in testing this if/when there's something more concrete :-) |
@DanTup the fix for this just got merged if you want to take it for a spin in tomorrow's build. What it does is on mac, when you use a login shell and shell integration is enabled, we'll add the prepended items inside the shell integration script after the profile has run. This should work for bash, zsh and fish (pwsh didn't seem to need the fix). |
@Tyriar thanks! This seems to work. However, the UI when changing it doesn't seem very clear: There's a yellow warning triangle here, but hovering over it or clicking on it gives no indication of the problem. There's another white warning triangle on the side, but the hover for it doesn't appear for quite a long time after you hover over it. I don't think it's very discoverable if a user has an existing session and this changes (and this is made worse by the terminal seeming to persist across reloads). Is there anything that can be done to improve this? (I can file a new issue about it if necessary). |
Great, thanks! :-) |
…ions microsoft#171066 introduced a fix for applying PATH prefix on macOS login shells that resolved microsoft#99878. However it had little issues for each shell implementation. This PR contains the following fixes: `bash` fix: - Add missing `:` separator in the path setter to avoid path corruption - Add missing quotes to avoid path interpretation `zsh` fix: - Add missing `:` separator in the path setter to avoid path corruption - Add missing quotes to avoid path interpretation - Move patching outside of `.zprofile` check as clean macOS install doesn't include this file, nevertheless PATH patching should still happen `fish` fix: - use `set -gx PATH` instead of `fish_add_path` as the latter has no effect on updating the path if entries already exist in it. Which is the case for some extensions, like [`vscode-micromamba`](https://github.com/mamba-org/vscode-micromamba) which modify process environment and after login shell rc processing path entries end up in the end.
This was covered a little bit in #94153 but that issue is locked and can't be discussed there. This feature feels pretty broken on macOS and I hope might be revisited.
The issue is on macOS prepending to
PATH
:This ends up being added to the end of the path, rather than the start. @Tyriar wrote up why this is in microsoft/vscode-docs@38653d4 and offered two workarounds, however neither of them are usable in my testing (as well as not really being feasible to tell all users to change):
"terminal.integrated.inheritEnv": false
makes no difference at all, the PATH till is added to the end (this is a problem because the purpose of usingprepend
above is that we need to override any existing SDK on PATH with the one the user just selected)"terminal.integrated.shellArgs": []
results in a completely emptyPATH
besides the values I've prepended, which means that pretty much everything else is missing and won't work. This might be solvable by pushingprocess.env.PATH
intoenvironmentVariableCollection
too, however the prompt to the user would look ridiculous as it would include their entire PATHI appreciate this probably isn't VS Code's fault, but given macOS is fairly common and this behaviour seems to happen on a clean macOS install (it happens on both of mine, and I've customised almost nothing) it feels like it's worth trying to fix (maybe even if it means sending
export PATH=foo:$PATH
once the shell is initialised? 😄).The text was updated successfully, but these errors were encountered: