mirror of
https://github.com/pyenv/pyenv.git
synced 2024-11-21 20:47:00 -05:00
Merge pull request #129 from blueyed/optimize-pyenv-which
Optimize pyenv-which: implement remove_from_path in Bash
This commit is contained in:
commit
77bd5bc6c9
2 changed files with 55 additions and 33 deletions
|
@ -15,43 +15,17 @@ if [ "$1" = "--complete" ]; then
|
||||||
exec pyenv shims --short
|
exec pyenv shims --short
|
||||||
fi
|
fi
|
||||||
|
|
||||||
expand_path() {
|
|
||||||
if [ ! -d "$1" ]; then
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
local cwd="$(pwd)"
|
|
||||||
cd "$1"
|
|
||||||
pwd
|
|
||||||
cd "$cwd"
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_from_path() {
|
remove_from_path() {
|
||||||
local path_to_remove="$(expand_path "$1")"
|
local path_to_remove="$1"
|
||||||
local result=""
|
local path_before
|
||||||
|
local result=":$PATH:"
|
||||||
if [ -z "$path_to_remove" ]; then
|
while [ "$path_before" != "$result" ]; do
|
||||||
echo "${PATH}"
|
path_before="$result"
|
||||||
return
|
result="${result//:$path_to_remove:/:}"
|
||||||
fi
|
|
||||||
|
|
||||||
local paths
|
|
||||||
IFS=: paths=($PATH)
|
|
||||||
|
|
||||||
for path in "${paths[@]}"; do
|
|
||||||
path="$(expand_path "$path" || true)"
|
|
||||||
if [ -n "$path" ] && [ "$path" != "$path_to_remove" ]; then
|
|
||||||
result="${result}${path}:"
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "${result%:}"
|
echo "${result%:}"
|
||||||
}
|
}
|
||||||
|
|
||||||
OLDIFS="$IFS"
|
|
||||||
IFS=: versions=($(pyenv-version-name))
|
|
||||||
IFS=: PYENV_VERSION="${versions[*]}"
|
|
||||||
IFS="$OLDIFS"
|
|
||||||
PYENV_COMMAND="$1"
|
PYENV_COMMAND="$1"
|
||||||
|
|
||||||
if [ -z "$PYENV_COMMAND" ]; then
|
if [ -z "$PYENV_COMMAND" ]; then
|
||||||
|
@ -59,6 +33,10 @@ if [ -z "$PYENV_COMMAND" ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
OLDIFS="$IFS"
|
||||||
|
IFS=: versions=(${PYENV_VERSION:-$(pyenv-version-name)})
|
||||||
|
IFS="$OLDIFS"
|
||||||
|
|
||||||
for version in "${versions[@]}"; do
|
for version in "${versions[@]}"; do
|
||||||
if [ "$version" = "system" ]; then
|
if [ "$version" = "system" ]; then
|
||||||
PATH="$(remove_from_path "${PYENV_ROOT}/shims")"
|
PATH="$(remove_from_path "${PYENV_ROOT}/shims")"
|
||||||
|
@ -67,6 +45,7 @@ for version in "${versions[@]}"; do
|
||||||
PYENV_COMMAND_PATH="${PYENV_ROOT}/versions/${version}/bin/${PYENV_COMMAND}"
|
PYENV_COMMAND_PATH="${PYENV_ROOT}/versions/${version}/bin/${PYENV_COMMAND}"
|
||||||
fi
|
fi
|
||||||
if [ -x "$PYENV_COMMAND_PATH" ]; then
|
if [ -x "$PYENV_COMMAND_PATH" ]; then
|
||||||
|
PYENV_VERSION="$version"
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
@ -80,6 +59,9 @@ done
|
||||||
|
|
||||||
if [ -x "$PYENV_COMMAND_PATH" ]; then
|
if [ -x "$PYENV_COMMAND_PATH" ]; then
|
||||||
echo "$PYENV_COMMAND_PATH"
|
echo "$PYENV_COMMAND_PATH"
|
||||||
|
elif ! [ -d "${PYENV_ROOT}/versions/${PYENV_VERSION}" ]; then
|
||||||
|
echo "pyenv: version \`$PYENV_VERSION' is not installed" >&2
|
||||||
|
exit 1
|
||||||
else
|
else
|
||||||
echo "pyenv: $PYENV_COMMAND: command not found" >&2
|
echo "pyenv: $PYENV_COMMAND: command not found" >&2
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,9 @@ create_executable() {
|
||||||
|
|
||||||
PYENV_VERSION=3.4 run pyenv-which py.test
|
PYENV_VERSION=3.4 run pyenv-which py.test
|
||||||
assert_success "${PYENV_ROOT}/versions/3.4/bin/py.test"
|
assert_success "${PYENV_ROOT}/versions/3.4/bin/py.test"
|
||||||
|
|
||||||
|
PYENV_VERSION=3.4:2.7 run pyenv-which py.test
|
||||||
|
assert_success "${PYENV_ROOT}/versions/3.4/bin/py.test"
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "searches PATH for system version" {
|
@test "searches PATH for system version" {
|
||||||
|
@ -31,6 +34,31 @@ create_executable() {
|
||||||
assert_success "${PYENV_TEST_DIR}/bin/kill-all-humans"
|
assert_success "${PYENV_TEST_DIR}/bin/kill-all-humans"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@test "searches PATH for system version (shims prepended)" {
|
||||||
|
create_executable "${PYENV_TEST_DIR}/bin" "kill-all-humans"
|
||||||
|
create_executable "${PYENV_ROOT}/shims" "kill-all-humans"
|
||||||
|
|
||||||
|
PATH="${PYENV_ROOT}/shims:$PATH" PYENV_VERSION=system run pyenv-which kill-all-humans
|
||||||
|
assert_success "${PYENV_TEST_DIR}/bin/kill-all-humans"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "searches PATH for system version (shims appended)" {
|
||||||
|
create_executable "${PYENV_TEST_DIR}/bin" "kill-all-humans"
|
||||||
|
create_executable "${PYENV_ROOT}/shims" "kill-all-humans"
|
||||||
|
|
||||||
|
PATH="$PATH:${PYENV_ROOT}/shims" PYENV_VERSION=system run pyenv-which kill-all-humans
|
||||||
|
assert_success "${PYENV_TEST_DIR}/bin/kill-all-humans"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "searches PATH for system version (shims spread)" {
|
||||||
|
create_executable "${PYENV_TEST_DIR}/bin" "kill-all-humans"
|
||||||
|
create_executable "${PYENV_ROOT}/shims" "kill-all-humans"
|
||||||
|
|
||||||
|
PATH="${PYENV_ROOT}/shims:${PYENV_ROOT}/shims:/tmp/non-existent:$PATH:${PYENV_ROOT}/shims" \
|
||||||
|
PYENV_VERSION=system run pyenv-which kill-all-humans
|
||||||
|
assert_success "${PYENV_TEST_DIR}/bin/kill-all-humans"
|
||||||
|
}
|
||||||
|
|
||||||
@test "version not installed" {
|
@test "version not installed" {
|
||||||
create_executable "3.4" "py.test"
|
create_executable "3.4" "py.test"
|
||||||
PYENV_VERSION=3.3 run pyenv-which py.test
|
PYENV_VERSION=3.3 run pyenv-which py.test
|
||||||
|
@ -68,7 +96,19 @@ echo HELLO="\$(printf ":%s" "\${hellos[@]}")"
|
||||||
exit
|
exit
|
||||||
SH
|
SH
|
||||||
|
|
||||||
PYENV_HOOK_PATH="$hook_path" IFS=$' \t\n' run pyenv-which anything
|
PYENV_HOOK_PATH="$hook_path" IFS=$' \t\n' PYENV_VERSION=system run pyenv-which anything
|
||||||
assert_success
|
assert_success
|
||||||
assert_output "HELLO=:hello:ugly:world:again"
|
assert_output "HELLO=:hello:ugly:world:again"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@test "discovers version from pyenv-version-name" {
|
||||||
|
mkdir -p "$PYENV_ROOT"
|
||||||
|
cat > "${PYENV_ROOT}/version" <<<"3.4"
|
||||||
|
create_executable "3.4" "python"
|
||||||
|
|
||||||
|
mkdir -p "$PYENV_TEST_DIR"
|
||||||
|
cd "$PYENV_TEST_DIR"
|
||||||
|
|
||||||
|
PYENV_VERSION= run pyenv-which python
|
||||||
|
assert_success "${PYENV_ROOT}/versions/3.4/bin/python"
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue