我喜欢 Oh My Zsh,但它从未在 JetBrains 产品的终端中正常工作:
- 找不到可执行文件
- 无法使用 pyenv、sdkman、rvm 等版本管理器
Oh My Zsh 是 zsh shell 增强,所以实际问题可以简化为让 zsh 正常工作。在阅读了一些 intellij 问题后,我尝试切换所有终端配置选项(单独和整体),以取得成功。
我喜欢 Oh My Zsh,但它从未在 JetBrains 产品的终端中正常工作:
Oh My Zsh 是 zsh shell 增强,所以实际问题可以简化为让 zsh 正常工作。在阅读了一些 intellij 问题后,我尝试切换所有终端配置选项(单独和整体),以取得成功。
找不到二进制文件,无法运行东西?显然是 $PATH 问题,但是什么以及为什么?
我在 iTerm2 中回应了一条已知的好路径
/Users/starver/.sdkman/candidates/maven/current/bin:/Users/starver/.sdkman/candidates/groovy/current/bin:/Users/starver/.sdkman/candidates/gradle/current/bin:/usr/local/Cellar/pyenv-virtualenv/1.1.3/shims:/Users/starver/.pyenv/shims:/Users/starver/.pyenv/bin:/Users/starver/.cargo/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/go/bin:/opt/X11/bin:/usr/local/git/bin:/Users/starver/bin/:/Users/starver/code/go/bin/:/Users/starver/.rvm/bin
在 IntelliJ 中:
/usr/bin:/bin:/usr/sbin:/sbin
这暗示了启动文件加载问题。我的 zsh 手册页说加载顺序应该是:
/etc/zshenv
$ZDOTDIR/.zshenv
/etc/zprofile
$ZDOTDIR/.zprofile
/etc/zshrc
$ZDOTDIR/.zshrc
/etc/zlogin
$ZDOTDIR/.zlogin
echo
在为每个存在的文件添加一个之后,我得到了 iTerm2 的以下内容:
/etc/zprofile
/Users/starver/.zprofile
/etc/zshrc
/Users/starver/.zshrc
/Users/starver/.zlogin
这在 IntelliJ
/etc/zshrc
/Users/starver/.zshrc
IntelliJ 认为这不是登录 shell。在 Jetbrains 终端配置中,不能输入/bin/zsh --login
; 它没有效果。玩了一会,发现打开Tools -> Terminal -> Shell Integration 让终端变成了“登录shell”,启动文件加载故事也有所改善:
/etc/zshrc
/Users/starver/.zprofile
/Users/starver/.zshrc
/Users/starver/.zlogin
请注意,没有任何全局 zsh 启动文件,这是根本问题:/etc/zprofile
包含:
# system-wide environment settings for zsh(1)
if [ -x /usr/libexec/path_helper ]; then
eval `/usr/libexec/path_helper -s`
fi
其中 man path_helper 解释说:
path_helper 实用程序读取目录 /etc/paths.d 和 /etc/manpaths.d 中文件的内容,并将它们的内容分别附加到 PATH 和 MANPATH 环境变量中。(除非已在环境中设置,否则不会修改 MANPATH 环境变量。)
path_helper
在 shell 启动期间至少执行一次非常重要:paths
并且paths.d
是系统和第三方安装程序定义其路径添加的地方。不执行系统配置文件启动文件是为什么/usr/local/bin
,/usr/local/go
等不在路径上。
我尝试了几种方法,寻找一个优雅的解决方案。显然,jediterm 终端实现阻止挂钩到标准终端启动过程 - 因此它们实现启动文件加载/Applications/IntelliJ IDEA.app/Contents/plugins/terminal/.zshrc
. 我们可以修复那个实现!!将该文件替换为:
#!/bin/zsh
# starver mod
# Jetbrains uses jediterm as a java terminal emulator for all terminal uses.
# There are some apparent limits on use:
# - must use old-style shebang - not the #!/usr/bin/env zsh
# - must implement the startup file loading here
#
# Note: original contents are in lib/terminal.jar
# mappings for Ctrl-left-arrow and Ctrl-right-arrow for word moving
bindkey '^[^[[C' forward-word
bindkey '^[^[[D' backward-word
ZDOTDIR=$_OLD_ZDOTDIR
if [ -n "$JEDITERM_USER_RCFILE" ]
then
source "$JEDITERM_USER_RCFILE"
unset JEDITERM_USER_RCFILE
fi
if [ -n "$ZDOTDIR" ]
then
DOTDIR=$ZDOTDIR
else
DOTDIR=$HOME
fi
if [ -f "/etc/zshenv" ]; then
source "/etc/zshenv"
fi
if [ -f "$DOTDIR/.zshenv" ]; then
source "$DOTDIR/.zshenv"
fi
if [ -n $LOGIN_SHELL ]; then
if [ -f "/etc/zprofile" ]; then
source "/etc/zprofile"
fi
if [ -f "$DOTDIR/.zprofile" ]; then
source "$DOTDIR/.zprofile"
fi
fi
if [ -f "/etc/zshrc" ]; then
source "/etc/zshrc"
fi
if [ -f "$DOTDIR/.zshrc" ]; then
source "$DOTDIR/.zshrc"
fi
if [ -n $LOGIN_SHELL ]; then
if [ -f "/etc/zlogin" ]; then
source "/etc/zlogin"
fi
if [ -f "$DOTDIR/.zlogin" ]; then
source "$DOTDIR/.zlogin"
fi
fi
if [ -n "$JEDITERM_SOURCE" ]
then
source $(echo $JEDITERM_SOURCE)
unset JEDITERM_SOURCE
fi
现在,在 IntelliJ 终端启动时,我看到
/etc/zshrc
/etc/zprofile
/Users/starver/.zprofile
/Users/starver/.shell-common
/etc/zshrc
/Users/starver/.zshrc
/Users/starver/.zlogin
第一个/etc/zshrc
是在插件之前执行的.zshrc
,对此我无能为力,并且不会造成任何不良副作用...
对每个 JetBrains 产品重复该过程,您就可以随时随地享受 Oh My Zsh 的乐趣。
注意:在https://youtrack.jetbrains.com/issue/IDEA-194488中向 JetBrains 报告了问题。
尝试取消注释第一个字符串~/.zshrc
:
# If you come from bash you might have to change your $PATH.
export PATH=$HOME/bin:/usr/local/bin:$PATH
它帮助了我。
zsh --login --interactive
为我工作terminal command
,或简称:
zsh -li
这将在 Mac 和所有登录脚本中加载 /etc/zprofile。
Fedora 32 中 zoppo over zsh 的回复没有任何效果:/
配置文件已加载,但好像缺少其中一些(很抱歉没有那么详细),包括它们手动也不起作用......我~/.zshrc
是空的:所有配置都是/etc/{zshenv, zprofile, zshrc}
.
对我来说,唯一可行的解决方案是使用
sh -c zsh
作为“外壳路径”。然后它就像在 konsole 和其他终端仿真器中一样工作。
我可以确认此答案中的所有内容,但有一个基于事实的更简单的解决方法,即加载path_helper
两次并不重要。
因此,在 JetBrains 修复他们的终端插件之前,只需放入source /etc/zprofile
您的~/.zshrc
文件并获利!
要使用 zsh 修复 sdkman,只需执行以下行:适用于我 Ubuntu 19.04
echo 'source "$HOME/.sdkman/bin/sdkman-init.sh"' >> ~/.zshrc