forked from HariSekhon/DevOps-Bash-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck_python_pylint.sh
executable file
·60 lines (53 loc) · 1.75 KB
/
check_python_pylint.sh
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
#!/usr/bin/env bash
# vim:ts=4:sts=4:sw=4:et
#
# Author: Hari Sekhon
# Date: 2015-05-25 01:38:24 +0100 (Mon, 25 May 2015)
#
# https://github.com/harisekhon/bash-tools
#
# License: see accompanying Hari Sekhon LICENSE file
#
# If you're using my code you're welcome to connect with me on LinkedIn and optionally send me feedback to help improve or steer this or other code I publish
#
# http://www.linkedin.com/in/harisekhon
#
set -euo pipefail
[ -n "${DEBUG:-}" ] && set -x
srcdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
# shellcheck disable=SC1090
. "$srcdir/lib/utils.sh"
if [ -z "$(find "${1:-.}" -maxdepth 2 -type f -iname '*.py' -o -iname '*.jy')" ]; then
return 0 &>/dev/null || :
exit 0
fi
section "P y L i n t"
start_time="$(start_timer)"
if [ -n "${NOPYLINT:-}" ]; then
echo "\$NOPYLINT environment variable set, skipping PyLint error checks"
elif [ -n "${QUICK:-}" ]; then
echo "\$QUICK environment variable set, skipping PyLint error checks"
else
if command -v pylint &>/dev/null; then
# Can't do this in one pass because pylint -E raises wrong-import-position when it doesn't individually and refuses to respect --disable
#prog_list="
for x in $(find "${1:-.}" -maxdepth 2 -type f -iname '*.py' -o -iname '*.jy' | sort); do
#echo "checking if $x is excluded"
isExcluded "$x" && continue
#echo "added $x for testing"
#prog_list="$prog_list $x"
echo "pylint -E $x"
pylint -E "$x"
done
#echo
#echo "Checking for coding errors:"
#echo
#echo "pylint -E $prog_list"
#echo
#pylint -E $prog_list
hr; echo
fi
fi
time_taken "$start_time"
section2 "PyLint checks passed"
echo