-
Notifications
You must be signed in to change notification settings - Fork 205
/
Copy pathrunpipenv
executable file
·67 lines (57 loc) · 2.2 KB
/
runpipenv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#!/usr/bin/env bash
set -e
# Helper for starting a Python script with dependencies managed by
# Pipenv. Use it in the shebang line of your Python script:
#
# #!/usr/bin/env runpipenv
#
# When invoked, runpipenv will make sure to call 'pipenv sync' to
# install dependencies from your Pipfile.lock file. Create the
# Pipfile.lock file with 'pipenv lock'.
# Pipenv looks for the Pipfile in the current directory, so we need to
# change to the directory of the script being invoked (passed in $1).
# Using realpath allows $1 to be a symlink to the real Python script.
# The realpath command doesn't exist on OS X, so here is a portable
# replacement.
realpath() {
local path="$1"
if [[ -h "$path" ]]; then
local target=$(readlink "$path")
if [[ $target[0] =~ '^/' ]]; then
echo "$target"
else
echo "$(dirname "$path")/$target"
fi
else
echo "$path"
fi
}
OLD_PWD=$PWD
cd "$(dirname "$(realpath "$1")")"
# Detect if the Pipfile needs Python 2 or Python 3.
PYTHON=python
if grep -q 'python_version\s*=\s*"3' Pipfile; then
PYTHON=python3
fi
# Python 2 outputs version information on stderr, Python 3 uses
# stdout. Furthermore, our dev-env wrapper and Pipenv itself likes to
# chatter on stderr. To work around all that, we combine the two
# channels and use grep to pick out the line we care about.
ACTUAL_VERSION="$(pipenv run python -V 2>&1 | grep '^Python [23]')"
WANTED_VERSION="$($PYTHON -V 2>&1 | grep '^Python [23]')"
if [[ $ACTUAL_VERSION != $WANTED_VERSION ]]; then
cat >&2 <<EOF
[runpipenv] The version of Python in the virtualenv ($ACTUAL_VERSION)
[runpipenv] does not match the version in dev-env ($WANTED_VERSION).
[runpipenv] The virtualenv will be recreated.
EOF
pipenv --rm
fi
# We can now sync the dependencies in the virtualenv Pipenv maintains.
PIPENV_ACTIVE=1 pipenv sync
# We now invoke the script and take care to change back to the
# original working directory first. We pass the target directory and
# any positional arguments as positional arguments to the inner Bash
# process. That way it can take care of passing them through unchanged
# to the Python invocation.
exec pipenv run bash -c 'cd "$0" && python "$@"' "$OLD_PWD" "$@"