style(python): fix code style and some hidden bugs
This commit is contained in:
parent
9c01dbc30b
commit
78c91ccbf9
1 changed files with 23 additions and 26 deletions
|
@ -7,40 +7,37 @@ alias pyfind='find . -name "*.py"'
|
||||||
# Remove python compiled byte-code and mypy/pytest cache in either the current
|
# Remove python compiled byte-code and mypy/pytest cache in either the current
|
||||||
# directory or in a list of specified directories (including sub directories).
|
# directory or in a list of specified directories (including sub directories).
|
||||||
function pyclean() {
|
function pyclean() {
|
||||||
ZSH_PYCLEAN_PLACES=${*:-'.'}
|
find "${@:-.}" -type f -name "*.py[co]" -delete
|
||||||
find ${ZSH_PYCLEAN_PLACES} -type f -name "*.py[co]" -delete
|
find "${@:-.}" -type d -name "__pycache__" -delete
|
||||||
find ${ZSH_PYCLEAN_PLACES} -type d -name "__pycache__" -delete
|
find "${@:-.}" -depth -type d -name ".mypy_cache" -exec rm -r "{}" +
|
||||||
find ${ZSH_PYCLEAN_PLACES} -depth -type d -name ".mypy_cache" -exec rm -r "{}" +
|
find "${@:-.}" -depth -type d -name ".pytest_cache" -exec rm -r "{}" +
|
||||||
find ${ZSH_PYCLEAN_PLACES} -depth -type d -name ".pytest_cache" -exec rm -r "{}" +
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Add the user installed site-packages paths to PYTHONPATH, only if the
|
# Add the user installed site-packages paths to PYTHONPATH, only if the
|
||||||
# directory exists. Also preserve the current PYTHONPATH value.
|
# directory exists. Also preserve the current PYTHONPATH value.
|
||||||
# Feel free to autorun this when .zshrc loads.
|
# Feel free to autorun this when .zshrc loads.
|
||||||
function pyuserpaths() {
|
function pyuserpaths() {
|
||||||
local targets=("python2" "python3") # bins
|
setopt localoptions extendedglob
|
||||||
|
|
||||||
# Get existing interpreters.
|
|
||||||
local interps=()
|
|
||||||
for target in $targets; do
|
|
||||||
[ `command -v $target` ] && interps+=($target)
|
|
||||||
done
|
|
||||||
|
|
||||||
# Check for a non-standard install directory.
|
# Check for a non-standard install directory.
|
||||||
local user_base="${HOME}/.local"
|
local user_base="${PYTHONUSERBASE:-"${HOME}/.local"}"
|
||||||
[ $PYTHONUSERBASE ] && user_base=$PYTHONUSERBASE
|
|
||||||
|
|
||||||
# Add version specific paths, if:
|
local python version site_pkgs
|
||||||
# it exists in the filesystem;
|
for python in python2 python3; do
|
||||||
# it isn't in PYTHONPATH already.
|
# Check if command exists
|
||||||
for interp in $interps; do
|
(( ${+commands[$python]} )) || continue
|
||||||
# Get minor release version.
|
|
||||||
local ver=`$interp -V 2>&1`
|
# Get minor release version.
|
||||||
ver=`echo ${ver:7} | cut -d '.' -f 1,2` # The patch version is variable length, truncate it.
|
# The patch version is variable length, truncate it.
|
||||||
|
version=${(M)${"$($python -V 2>&1)":7}#[^.]##.[^.]##}
|
||||||
local site_pkgs="${user_base}/lib/python${ver}/site-packages"
|
|
||||||
[[ -d $site_pkgs && ! $PYTHONPATH =~ $site_pkgs ]] && export PYTHONPATH=${site_pkgs}:$PYTHONPATH
|
# Add version specific path, if:
|
||||||
done
|
# - it exists in the filesystem
|
||||||
|
# - it isn't in $PYTHONPATH already.
|
||||||
|
site_pkgs="${user_base}/lib/python${version}/site-packages"
|
||||||
|
[[ -d "$site_pkgs" && ! "$PYTHONPATH" =~ (^|:)"$site_pkgs"(:|$) ]] || continue
|
||||||
|
export PYTHONPATH="${site_pkgs}${PYTHONPATH+":${PYTHONPATH}"}"
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
# Grep among .py files
|
# Grep among .py files
|
||||||
|
|
Loading…
Reference in a new issue