mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-11-26 21:51:05 +01:00
Merge branch 'ohmyzsh:master' into master
This commit is contained in:
commit
182c893834
1 changed files with 56 additions and 31 deletions
|
@ -1,43 +1,68 @@
|
||||||
# This plugin loads pyenv into the current shell and provides prompt info via
|
# This plugin loads pyenv into the current shell and provides prompt info via
|
||||||
# the 'pyenv_prompt_info' function. Also loads pyenv-virtualenv if available.
|
# the 'pyenv_prompt_info' function. Also loads pyenv-virtualenv if available.
|
||||||
|
|
||||||
# Load pyenv only if command not already available
|
# Look for pyenv in $PATH and verify that it's not a part of pyenv-win in WSL
|
||||||
if command -v pyenv &> /dev/null && [[ "$(uname -r)" != *icrosoft* ]]; then
|
if ! command -v pyenv &>/dev/null; then
|
||||||
FOUND_PYENV=1
|
|
||||||
else
|
|
||||||
FOUND_PYENV=0
|
FOUND_PYENV=0
|
||||||
|
elif [[ "${commands[pyenv]}" = */pyenv-win/* && "$(uname -r)" = *icrosoft* ]]; then
|
||||||
|
FOUND_PYENV=0
|
||||||
|
else
|
||||||
|
FOUND_PYENV=1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Look for pyenv and try to load it (will only work on interactive shells)
|
||||||
if [[ $FOUND_PYENV -ne 1 ]]; then
|
if [[ $FOUND_PYENV -ne 1 ]]; then
|
||||||
pyenvdirs=("$HOME/.pyenv" "/usr/local/pyenv" "/opt/pyenv" "/usr/local/opt/pyenv")
|
pyenvdirs=("$HOME/.pyenv" "/usr/local/pyenv" "/opt/pyenv" "/usr/local/opt/pyenv")
|
||||||
for dir in $pyenvdirs; do
|
for dir in $pyenvdirs; do
|
||||||
if [[ -d $dir/bin ]]; then
|
if [[ -d "$dir/bin" ]]; then
|
||||||
export PATH="$PATH:$dir/bin"
|
|
||||||
FOUND_PYENV=1
|
FOUND_PYENV=1
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $FOUND_PYENV -ne 1 ]]; then
|
if [[ $FOUND_PYENV -ne 1 ]]; then
|
||||||
if (( $+commands[brew] )) && dir=$(brew --prefix pyenv 2>/dev/null); then
|
if (( $+commands[brew] )) && dir=$(brew --prefix pyenv 2>/dev/null); then
|
||||||
if [[ -d $dir/bin ]]; then
|
if [[ -d "$dir/bin" ]]; then
|
||||||
export PATH="$PATH:$dir/bin"
|
|
||||||
FOUND_PYENV=1
|
FOUND_PYENV=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# If we found pyenv, load it but show a caveat about non-interactive shells
|
||||||
|
if [[ $FOUND_PYENV -eq 1 ]]; then
|
||||||
|
cat <<EOF
|
||||||
|
Found pyenv, but it is badly configured. pyenv might not work for
|
||||||
|
non-interactive shells (for example, when run from a script).
|
||||||
|
${bold_color}
|
||||||
|
To fix this message, add these lines to the '.profile' and '.zprofile' files
|
||||||
|
in your home directory:
|
||||||
|
|
||||||
|
export PYENV_ROOT="${dir/#$HOME/\$HOME}"
|
||||||
|
export PATH="\$PYENV_ROOT/bin:\$PATH"
|
||||||
|
eval "\$(pyenv init --path)"
|
||||||
|
${reset_color}
|
||||||
|
For more info go to https://github.com/pyenv/pyenv/#installation.
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Configuring in .zshrc only makes pyenv available for interactive shells
|
||||||
|
export PYENV_ROOT=$dir
|
||||||
|
export PATH="$PYENV_ROOT/bin:$PATH"
|
||||||
|
eval "$(pyenv init --path)"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ $FOUND_PYENV -eq 1 ]]; then
|
if [[ $FOUND_PYENV -eq 1 ]]; then
|
||||||
eval "$(pyenv init - --no-rehash zsh)"
|
eval "$(pyenv init - --no-rehash zsh)"
|
||||||
if (( $+commands[pyenv-virtualenv-init] )); then
|
|
||||||
|
if (( ${+commands[pyenv-virtualenv-init]} )); then
|
||||||
eval "$(pyenv virtualenv-init - zsh)"
|
eval "$(pyenv virtualenv-init - zsh)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
function pyenv_prompt_info() {
|
function pyenv_prompt_info() {
|
||||||
echo "$(pyenv version-name)"
|
echo "$(pyenv version-name)"
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
# fallback to system python
|
# Fall back to system python
|
||||||
function pyenv_prompt_info() {
|
function pyenv_prompt_info() {
|
||||||
echo "system: $(python -V 2>&1 | cut -f 2 -d ' ')"
|
echo "system: $(python -V 2>&1 | cut -f 2 -d ' ')"
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue