pyenv/libexec/pyenv-local

56 lines
1.6 KiB
Text
Raw Permalink Normal View History

#!/usr/bin/env bash
#
# Summary: Set or show the local application-specific Python version(s)
2013-01-18 03:41:41 -05:00
#
# Usage: pyenv local <version> <version2> <..>
2013-01-18 03:41:41 -05:00
# pyenv local --unset
#
# Sets the local application-specific Python version(s) by writing the
2013-01-18 03:41:41 -05:00
# version name to a file named `.python-version'.
#
# When you run a Python command, pyenv will look for a `.python-version'
# file in the current directory and each parent directory. If no such
# file is found in the tree, pyenv will use the global Python version
# specified with `pyenv global'. A version specified with the
# `PYENV_VERSION' environment variable takes precedence over local
# and global versions.
#
# <version> can be specified multiple times and should be a version
# tag known to pyenv. The special version string `system' will use
# your default system Python. Run `pyenv versions' for a list of
# available Python versions.
#
# Example: To enable the python2.7 and python3.7 shims to find their
# respective executables you could set both versions with:
#
# 'pyenv local 3.7.0 2.7.15'
2013-01-18 03:41:41 -05:00
set -e
[ -n "$PYENV_DEBUG" ] && set -x
# Provide pyenv completions
if [ "$1" = "--complete" ]; then
echo --unset
echo system
exec pyenv-versions --bare
fi
versions=("$@")
if [ "$versions" = "--unset" ]; then
2016-03-03 19:00:53 -05:00
rm -f .python-version
elif [ -n "$versions" ]; then
2014-01-02 12:05:40 -05:00
pyenv-version-file-write .python-version "${versions[@]}"
else
2016-03-03 19:00:53 -05:00
if version_file="$(pyenv-version-file "$PWD")"; then
IFS=: versions=($(pyenv-version-file-read "$version_file"))
for version in "${versions[@]}"; do
echo "$version"
done
else
echo "pyenv: no local version configured for this directory" >&2
exit 1
fi
fi