summaryrefslogtreecommitdiff
path: root/cad/src/tools/SEMBot/runPylint.sh
blob: adb105d1906e753e366cf3350e9625783b921b33 (plain)
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/bin/sh

# $Id$

# Usage: ./runPylint.sh &>Pylint.log

# Run Pylint 
pushd SVN-D/cad/src
export LC_ALL="C"

# Remove old reports
rm -rf pylint_*

BATCH_NUMBER=0
# Some files break Pylint, exclude them
CAPITAL_M_STAR=`ls M*.py|grep -v MWsemantics.py`
CAPITAL_T_STAR=`ls T*.py|grep -v TreeView.py|grep -v TreeWidget.py`
PM_STAR=`ls PM/PM_*.py|grep -v PM_CheckBox|grep -v PM_Slider.py`
# Run in batches
rm -rf ../../../Logs
mkdir ../../../Logs
find . -type d | cpio -pudvm ../../../Logs
#exit 1
for batch in `find . -type f -name "*.py" | grep -v .svn | grep -v experimental | grep -v tools | grep -v outtakes | grep -v scratch | grep -v .png` 
do
  echo "Running batch $BATCH_NUMBER: $batch"
  /usr/local/bin/pylint --rcfile=../../../Pylint.rcfile $batch > pylint_global.txt

  # Post process results
  ../../../pylint_global.pl pylint_global.txt ${BATCH_NUMBER} pylint.${BATCH_NUMBER}.result > pylint_global.${BATCH_NUMBER}.html
  cp pylint_global.${BATCH_NUMBER}.html ../../../Logs/$batch.html

  let BATCH_NUMBER=BATCH_NUMBER+1
done

# Aggregate code "grades"
TOTAL=0
for name in `ls pylint.*.result`
do
  X=`cat $name`
  TOTAL=`echo $TOTAL + $X | bc`
done
FCOUNT=`ls pylint.*.result | wc -l`
AVG=`echo $TOTAL / $FCOUNT | bc`
echo "scale=3" > tmp.txt
#echo "average=("`cat pylint.0.result`+`cat pylint.1.result`+`cat pylint.2.result`+`cat pylint.3.result`+`cat pylint.5.result`+`cat pylint.6.result`+`cat pylint.7.result`+`cat pylint.8.result`+`cat pylint.9.result`+`cat pylint.10.result`+`cat pylint.11.result`+`cat pylint.12.result`")/13" >> tmp.txt
average=$AVG
echo "Average = $average"
echo $average >> tmp.txt
echo "if (average > 2.5) {" >> tmp.txt
echo "  if (average > 5.0) {" >> tmp.txt
echo "    if (average > 7.5) {" >> tmp.txt
echo "      ;" >> tmp.txt
echo "    } else {" >> tmp.txt
echo "      \"<font style=\"; print \"\q\"; \"color: #ffffff; background: #3ab0b6\"; print \"\q\"; \">&nbsp;\"" >> tmp.txt
echo "    }" >> tmp.txt
echo "  } else {" >> tmp.txt
echo "    \"<font style=\"; print \"\q\"; \"color: #ffffff; background: #fd5053\"; print \"\q\"; \">&nbsp;\"" >> tmp.txt
echo "  }" >> tmp.txt
echo "} else {" >> tmp.txt
echo "  \"<font style=\"; print \"\q\"; \"color: #ffffff; background: #ff0000\"; print \"\q\"; \">&nbsp;\"" >> tmp.txt
echo "}" >> tmp.txt
echo "average; \"</font>\"" >> tmp.txt
echo "quit" >> tmp.txt
echo `bc -q tmp.txt` > ../../../Pylint.result
#rm pylint.?.result tmp.txt

popd

# Generate filtered summary reports:
# (their output files have links in index.php)

# W0403 - Relative import %s. Emitted when an import statement uses a package-relative pathname.
cd Logs
grep -r W0403 *  > ../W0403.txt

# W0611 - Unused import %s. Emitted when an imported module or variable is not used.
grep -r W0611 * > ../W0611.txt

# E0602 - Undefined variable %s. Emitted when a non-builtin symbol is used, but no 
# definition or import of it can be found.
grep -r E0602 * > ../E0602.txt
cd ..

# Consider adding summary reports for the following:
# W0311 - Bad indentation
# ? - Tabs in indentation

# end