-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathblatt.sh
More file actions
executable file
·199 lines (181 loc) · 4.98 KB
/
blatt.sh
File metadata and controls
executable file
·199 lines (181 loc) · 4.98 KB
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
#!/usr/bin/env bash
# blatt - (Gentoo) build log arch testing tool
# by Denis M. (Phr33d0m)
# Wyatt Epp
ARGCOUNT=1
E_NOFILE=1
E_WIP=2
E_FLAGSARETOUCHING=4
E_WRONGARGS=33
if [[ $# -lt $ARGCOUNT ]]; then
echo "Simple tool to find build system issues."
echo "Usage: $(basename $0) /path/to/logs-dir/<cat>:<pkg>-<ver>-....log"
echo " -a : All tests (default)"
echo " -f : Compiler flag tests"
echo " -h : Hardcoded call test"
echo " -l : Static library tests"
exit $E_WRONGARGS
fi
DOSTUFF="all" #default
while getopts "a:f:h:l:" OPTION; do
case $OPTION in
'a')
DOSTUFF="all"
;;
'f')
DOSTUFF="flagrespect"
;;
'h')
DOSTUFF="hardcalls"
;;
'l')
DOSTUFF="lafiles"
;;
'?')
;;
esac
done
CMD_GREP=$(command -v egrep)
CMD_GREP_ARGS="--color=always --"
CMDS=""
CMDS_ALT=""
ISSUES=0
HARDCALLS=0
STATIC_REFUGEES=0
RODNEY_DANGERFFLAG=0 #No respect, I tell ya!
VFLAG_O=0
VFLAG_G=0
PKG_NAME=""
### COLOURS
NORM=$(tput sgr0) #NORMal
RED=$(tput setaf 1)
GREEN=$(tput setaf 2)
YELLOW=$(tput setaf 3)
BOLD=$(tput bold)
#Takes: Filename / Sets: CAT,PN,PV,PACAKGE
function atomise(){
ATOM=($(qatom $(head -1 $1|sed 's/.*:[[:space:]]*//')))
CAT=${ATOM[0]}
PN=${ATOM[1]}
PV=${ATOM[2]}
PACKAGE=$CAT/$PN-$PV
}
### HARDCODED CALLS
#TODO: Move this pile of stuff into a function so it only runs if necessary.
# Set up our grep command
for i in $(ls --color=never /usr/bin/x86_64-pc-linux-gnu-* | sed 's:/usr/bin/x86_64-pc-linux-gnu-::g'); do
CMDS+="^"$i"[[:space:]]|libtool.* "$i"[[:space:]]|";
#CMDS_ALT+="libtool.* "$i"|";
done
CMDS=${CMDS%?} #Slice off last character
#CMDS_ALT=${CMDS_ALT%?} #Slice off last character
# Escape +- for safety
CMDS=$(echo $CMDS | sed 's:\+:\\+:g;s:\-:\\-:g')
#CMDS_ALT=$(echo $CMDS_ALT | sed 's:\+:\\+:g;s:\-:\\-:g')
function hardcalls(){ # 1: filename 2: PACKAGE
if [[ $PN == "gvim" ]];then
echo -e $RED"gvim has issues and will screw with your terminal"
echo -e $BOLD"TODO: continue ignoring gvim's logs. Do it manually."$NORM
return
fi
TREACLE=$($CMD_GREP $CMD_GREP_ARGS "$CMDS" $1)
if [[ $TREACLE ]]; then
let HARDCALLS++
fi
}
### CHECK: STATIC LIBS
#
function lafiles(){
if [[ $(head -4 $1|grep "USE.*static-libs") ]]; then
return # The USEs in the log are build-time
else
# If there are static libs after this point, that's a bug
LAFF=$(qlist -C $PACKAGE|$CMD_GREP '.*\.a$|.*\.la$')
if [[ $LAFF ]]; then
let STATIC_REFUGEES++
fi
fi
}
### CHECK: CFLAGS/CXXFLAGS respect
#
function flagrespect(){
#TODO: Patch log output to have this (or ask Zac)
CFLAGS=$(portageq envvar CFLAGS)
CXXFLAGS=$(portageq envvar CXXFLAGS)
#CFLAGS="-march=native -O2 -pipe"
#CXXFLAGS="-march=native -msse4 -msse4.1 -msse4.2 -O2 -pipe"
if [[ $CFLAGS == $CXXFLAGS ]]; then
echo -e $BOLD$RED"CFLAGS and CXXFLAGS must not match!"$NORM
return
else
RANGE=$(egrep -i "?*x86_64.*-g[++,cc].*\.c?*$" $1|grep -v "configure:") #Filter out all noise
FLAGSPAM=$($CMD_GREP -v "x86_64.*-gcc.*$CFLAGS|x86_64.*-g++.*$CXXFLAGS" <(echo "$RANGE") )
# Less magical. Just decides which one to use.
grep -lq "gcc" <(echo "$RANGE") && SSTRING=$CFLAGS
grep -lq "g++" <(echo "$RANGE") && SSTRING=$CXXFLAGS
VFLAG_G=$($CMD_GREP $CMD_GREP_ARGS "$SSTRING.* -[g,g0] " <(echo "$RANGE"))
VFLAG_O=$($CMD_GREP $CMD_GREP_ARGS "$SSTRING .* -O[[:digit:],s]" <(echo "$RANGE"))
if [[ $FLAGSPAM || $VFLAG_G || $VFLAG_O ]]; then
let RODNEY_DANGERFFLAG++
fi
fi
}
### MAIN STORY
### Call requested tests on each desired file
#TODO: convert to getopts and optional running
for I in $*; do
if [[ -d $I || ! -e $I ]]; then continue; fi #Skip directories and non-files
if [[ $( head -1 $I|grep '^No package.*') ]]; then continue; fi #Skip uninstalls
atomise $I
case $DOSTUFF in #This is awful right now. More for structure
'hardcalls'|'all')
hardcalls $I
;;&
'lafiles'|'all')
lafiles $I
;;&
'flagrespect'|'all')
flagrespect $I
;;
?) # should be unreachable right now.
exit 0
esac
# Can just keep attaching things as tests get added.
# Any non-negative value makes the if resolve true.
ISSUES=$(( $HARDCALLS+ \
$STATIC_REFUGEES+ \
$RODNEY_DANGERFFLAG ))
#TODO: Make per-package report files
if [[ $ISSUES -gt 0 ]]; then
echo -e $BOLD$RED">>> $PACKAGE: ISSUES FOUND"$NORM
if [[ $HARDCALLS -gt 0 ]]; then
echo -e $BOLD$YELLOW"> Hardcoded calls:"$NORM
echo -e "$TREACLE"$NORM
HARDCALLS=0
fi
if [[ $STATIC_REFUGEES -gt 0 ]]; then
echo -e $BOLD$YELLOW"> Static Libraries in Dynamic Packages:"$NORM
echo -e "$LAFF"
STATIC_REFUGEES=0
fi
if [[ $RODNEY_DANGERFFLAG -gt 0 ]]; then
if [[ $FLAGSPAM ]]; then
echo -e $BOLD$YELLOW"> Not respecting CFLAGS/CXXFLAGS:"$NORM
echo -e "$FLAGSPAM"
fi
if [[ $VFLAG_G ]]; then
echo -e $BOLD$YELLOW"> Added extra -g:"$NORM
echo -e "$VFLAG_G"
VFLAG_G=0
fi
if [[ $VFLAG_O ]]; then
echo -e $BOLD$YELLOW"> Added extra -O:"$NORM
echo -e "$VFLAG_O"
VFLAG_O=0
fi
RODNEY_DANGERFFLAG=0
fi
else
echo -e $BOLD$GREEN">>> $PACKAGE: NO ISSUES FOUND"$NORM
fi
done