rev |
line source |
pankso@3512
|
1 #!/bin/sh
|
pankso@3512
|
2 # Tazbb - SliTaz Build Bot.
|
pankso@3512
|
3 # System wide config file: /etc/slitaz/tazbb.conf
|
pankso@3512
|
4 #
|
pankso@3512
|
5 # Tazbb is a tool to automate package building, it can be run manually
|
pankso@3512
|
6 # or via a cron job. On SliTaz build host, tazbb is run in a chroot env.
|
pankso@3512
|
7 #
|
pankso@3512
|
8 # (c) 2009 SliTaz GNU/Linux project - GNU gpl v3
|
pankso@3512
|
9 #
|
pankso@3512
|
10
|
pankso@3512
|
11 # Include config file or exit if no file found.
|
pankso@3512
|
12 if [ -f "./tazbb.conf" ]; then
|
pankso@3512
|
13 . ./tazbb.conf
|
pankso@3512
|
14 elif [ -f "/etc/slitaz/tazbb.conf" ]; then
|
pankso@3512
|
15 . /etc/slitaz/tazbb.conf
|
pankso@3512
|
16 else
|
pankso@3512
|
17 echo -e "\nNo config file found: tazbb.conf...\n" && exit 0
|
pankso@3512
|
18 fi
|
pascal@5823
|
19 LOG_SUFFIX=""
|
pascal@5823
|
20 case "$HG_WOK" in
|
pascal@5823
|
21 *stable) LOG_SUFFIX="&stable=1";;
|
pascal@5823
|
22 esac
|
pankso@3512
|
23
|
pankso@3512
|
24 # Tazbb is only for root.
|
pankso@3512
|
25 if test $(id -u) != 0 ; then
|
pankso@3512
|
26 echo -e "\nYou must be root to run: `basename $0`.\n" && exit 0
|
pankso@3512
|
27 fi
|
pankso@3512
|
28
|
pankso@3537
|
29 # Let tazbb finish is work and make sure needed files exist.
|
pankso@3512
|
30 if [ -f $LOCK_FILE ]; then
|
pankso@3512
|
31 case $1 in
|
pankso@3512
|
32 usage|list-*|*block)
|
pankso@3512
|
33 continue ;;
|
pankso@3512
|
34 *)
|
pankso@3512
|
35 echo -e "\nTazbb is already running and locked...\n"
|
pankso@3512
|
36 exit 0 ;;
|
pankso@3512
|
37 esac
|
pankso@3512
|
38 else
|
pankso@3512
|
39 mkdir -p $DB_DIR $LOG_DIR
|
pankso@3512
|
40 touch $LOCK_FILE $DB_DIR/blocked
|
pankso@3512
|
41 fi
|
pankso@3512
|
42
|
pascal@4236
|
43 # Set KERNEL variable
|
pascal@4236
|
44 if [ -s $BUILD_WOK/linux/receipt ]; then
|
pascal@4236
|
45 . $BUILD_WOK/linux/receipt
|
pascal@4236
|
46 KERNEL=$VERSION
|
pascal@4236
|
47 fi
|
pascal@4236
|
48
|
pascal@5916
|
49 # Get revision
|
pascal@5922
|
50 cd $HG_WOK
|
pascal@5916
|
51 NEW_REV=`hg head --template '{rev}\n'`
|
pascal@5922
|
52 cd - > /dev/null
|
pascal@5916
|
53
|
pankso@3512
|
54 usage()
|
pankso@3512
|
55 {
|
pankso@3512
|
56 echo -e "\nSliTaz developers and build host tool\n
|
pankso@3512
|
57 \033[1mUsage: \033[0m `basename $0` [command] [--option]
|
pankso@3512
|
58 \033[1mCommands: \033[0m\n
|
pascal@4996
|
59 usage Print this short usage and command list.
|
pascal@4996
|
60 list-pkgs List last cooked packages with date.
|
pascal@4996
|
61 report Run in report mode and dont cook anything [--verbose].
|
pascal@4996
|
62 cook Cook, install and log a single package build.
|
pascal@4996
|
63 cook-all Cook all missing, modified or unbuilt packages.
|
pascal@4996
|
64 cook-commit Cook all packages affected by a commit in the last update.
|
pascal@4996
|
65 test-pkgs Execute a test suite on all packages [--verbose].
|
pascal@4996
|
66 [un]block Block or unblock a package to skip or enable building.
|
pascal@4996
|
67 mail Send mail to package maintainer with tazbbmail.
|
pascal@4996
|
68 check-depends Verify DEPENDS value with library needs [--verbose].
|
pascal@4996
|
69 clean-up Remove old packages [--verbose|--dry-run].
|
pascal@4996
|
70 clean-log Remove all generated build log files.\n"
|
pankso@3512
|
71 }
|
pankso@3512
|
72
|
pankso@3512
|
73 status()
|
pankso@3512
|
74 {
|
pankso@3512
|
75 local CHECK=$?
|
pankso@3512
|
76 echo -en "\033[70G"
|
pankso@3512
|
77 if [ $CHECK = 0 ]; then
|
pankso@3512
|
78 echo "Done"
|
pankso@3512
|
79 else
|
pankso@3512
|
80 echo "Failed"
|
pankso@3512
|
81 fi
|
pankso@3512
|
82 return $CHECK
|
pankso@3512
|
83 }
|
pankso@3512
|
84
|
pankso@3512
|
85 top_summary()
|
pankso@3512
|
86 {
|
pankso@3512
|
87 cat > $DB_DIR/summary << _EOT_
|
pankso@3512
|
88 Update : `date`
|
pankso@3512
|
89 Revision : $NEW_REV (<a href="$HG_URL/log/$NEW_REV">changelog</a>)
|
pankso@3512
|
90 _EOT_
|
pankso@3512
|
91 }
|
pankso@3512
|
92
|
pankso@3512
|
93 packages_summary()
|
pankso@3512
|
94 {
|
pankso@3512
|
95 if ! grep -q "^Packages" $DB_DIR/summary; then
|
pankso@3512
|
96 cat >> $DB_DIR/summary << _EOT_
|
pankso@3512
|
97 Packages : `ls $BUILD_WOK | wc -l` in the wok, `cat $DB_DIR/cooklist | wc -l` to cook, \
|
pankso@3512
|
98 `cat $DB_DIR/blocked | wc -l` blocked, `cat $DB_DIR/corrupted | wc -l` corrupted
|
pankso@3512
|
99 _EOT_
|
pankso@3512
|
100 fi
|
pankso@3512
|
101 }
|
pankso@3512
|
102
|
pascal@4996
|
103 VERBOSE=""
|
pascal@4996
|
104
|
pankso@3512
|
105 packages_summary_update()
|
pankso@3512
|
106 {
|
pankso@3512
|
107 sed -i s/"[0-9]* in the wok"/"`ls $BUILD_WOK | wc -l` in the wok"/ \
|
pankso@3512
|
108 $DB_DIR/summary
|
pankso@3512
|
109 sed -i s/"[0-9]* to cook"/"`cat $DB_DIR/cooklist | wc -l` to cook"/ \
|
pankso@3512
|
110 $DB_DIR/summary
|
pankso@3512
|
111 sed -i s/"[0-9]* blocked"/"`cat $DB_DIR/blocked | wc -l` blocked"/ \
|
pankso@3512
|
112 $DB_DIR/summary
|
pankso@3512
|
113 sed -i s/"[0-9]* corrupted"/"`cat $DB_DIR/corrupted | wc -l` corrupted"/ \
|
pankso@3512
|
114 $DB_DIR/summary
|
pankso@3512
|
115 }
|
pankso@3512
|
116
|
pankso@3512
|
117 list_packages()
|
pankso@3512
|
118 {
|
pankso@3512
|
119 cd $PACKAGES_REPOSITORY
|
pankso@3512
|
120 ls -1t *.tazpkg | head -20 | \
|
pankso@3512
|
121 while read file
|
pankso@3512
|
122 do
|
pankso@3512
|
123 echo -n $(stat -c '%y' $PACKAGES_REPOSITORY/$file | cut -d. -f1)
|
pankso@3512
|
124 echo " $file"
|
pankso@3512
|
125 done
|
pankso@3512
|
126 }
|
pankso@3512
|
127
|
pankso@3512
|
128 show_report()
|
pankso@3512
|
129 {
|
pankso@3512
|
130 echo "Cooklist"
|
pankso@3512
|
131 echo "================================================================================"
|
pankso@3512
|
132 cat $DB_DIR/cooklist && echo ""
|
pascal@4447
|
133 echo "Packlist"
|
pascal@4447
|
134 echo "================================================================================"
|
pascal@4447
|
135 cat $DB_DIR/packlist && echo ""
|
pankso@3512
|
136 echo "Blocked"
|
pankso@3512
|
137 echo "================================================================================"
|
pankso@3512
|
138 cat $DB_DIR/blocked && echo ""
|
pankso@3512
|
139 echo ""
|
pankso@3512
|
140 }
|
pankso@3512
|
141
|
pascal@4163
|
142 # URL encoding
|
pascal@4163
|
143 escape()
|
pascal@4163
|
144 {
|
pascal@4163
|
145 echo $1 | sed -e 's/+/%2B/g' -e 's|/|%2F|g' -e 's/:/%3A/g'
|
pascal@4163
|
146 }
|
pascal@4163
|
147
|
pankso@3512
|
148 update_wok()
|
pankso@3512
|
149 {
|
pascal@4447
|
150 local forced
|
pascal@4447
|
151 forced=""
|
pankso@3512
|
152 echo ""
|
pascal@4447
|
153 echo "(updating flavors)" > $DB_DIR/running
|
pascal@4447
|
154 cd $HG_FLAVORS
|
pascal@4447
|
155 LAST_REV=`hg head --template '{rev}\n'`
|
pascal@4447
|
156 hg pull && hg update
|
pascal@4447
|
157 NEW_REV=`hg head --template '{rev}\n'`
|
pascal@4447
|
158 if [ "$NEW_REV" != "$LAST_REV" ]; then
|
pascal@4447
|
159 size=`du -sh $HG_FLAVORS | awk '{ print $1 }'`
|
pascal@4447
|
160 echo -n "Copying Hg flavors to the build flavors ($size)... "
|
pascal@4447
|
161 cp -a $HG_FLAVORS/* $BUILD_FLAVORS
|
pascal@4447
|
162 cp -a $HG_FLAVORS/.hg $BUILD_FLAVORS
|
pascal@4447
|
163 echo -e "Done\n"
|
pascal@4447
|
164 forced="yes"
|
pascal@4447
|
165 fi
|
pankso@3512
|
166 echo "(updating wok)" > $DB_DIR/running
|
pankso@3512
|
167 cd $HG_WOK
|
pankso@3512
|
168 LAST_REV=`hg head --template '{rev}\n'`
|
pankso@3512
|
169 hg pull && hg update
|
pankso@3512
|
170 NEW_REV=`hg head --template '{rev}\n'`
|
pankso@3512
|
171 # Gen a new summary and link last revision for the web interface.
|
pankso@3512
|
172 echo -e "\nHg wok : $HG_WOK ($NEW_REV)"
|
pankso@3512
|
173 echo -e "Build wok : $BUILD_WOK ($LAST_REV)\n"
|
pankso@3512
|
174 top_summary
|
pankso@3512
|
175 # Copy Hg wok if new revision or exit to stop process since nothing
|
pankso@3537
|
176 # have change (--forced can be used).
|
pankso@3512
|
177 if [ "$NEW_REV" != "$LAST_REV" ]; then
|
pankso@3512
|
178 size=`du -sh $HG_WOK | awk '{ print $1 }'`
|
pankso@3512
|
179 echo -n "Copying Hg wok to the build wok ($size)... "
|
pankso@3537
|
180 #rsync -r -n -t $HG_WOK/ $BUILD_WOK/
|
pankso@3512
|
181 cp -a $HG_WOK/* $BUILD_WOK
|
pankso@3512
|
182 cp -a $HG_WOK/.hg $BUILD_WOK
|
pankso@3512
|
183 echo -e "Done\n"
|
pankso@3512
|
184 else
|
pankso@3512
|
185 if [ "$1" = "cook-all" ] || [ "$1" = "cook-commit" ]; then
|
pascal@4447
|
186 if [ "$2" != "--forced" -a -z "$forced" ]; then
|
pankso@3512
|
187 echo -e "Nothing to cook...\n"
|
pankso@3512
|
188 packages_summary
|
pankso@3512
|
189 rm -f $LOCK_FILE && exit 0
|
pankso@3512
|
190 fi
|
pankso@3512
|
191 fi
|
pankso@3512
|
192 fi
|
pankso@3512
|
193 }
|
pankso@3512
|
194
|
pascal@4447
|
195 # Running 'tazbb report' should not pack anything and --verbose option
|
pascal@4447
|
196 # can be used to display more messages.
|
pascal@4447
|
197 check_flavors()
|
pascal@4447
|
198 {
|
pascal@4447
|
199 # Clean up last results.
|
pascal@4447
|
200 rm -f $DB_DIR/packlist && touch $DB_DIR/packlist
|
pascal@4447
|
201 echo ""
|
pascal@4447
|
202 echo "Checking all files in: $HG_FLAVORS"
|
pascal@4447
|
203 echo "================================================================================"
|
pascal@4447
|
204 echo "(checking flavors)" > $DB_DIR/running
|
pascal@4447
|
205 for flavor in $(cd $HG_FLAVORS ; ls)
|
pascal@4447
|
206 do
|
pascal@4447
|
207 [ "$2" = "--verbose" ] && echo "Flavor : $flavor"
|
pascal@4447
|
208 if [ ! -s $PACKAGES_REPOSITORY/$flavor.flavor ]; then
|
pascal@4447
|
209 echo $flavor >> $DB_DIR/packlist
|
pascal@4447
|
210 [ "$1" = "report" ] && echo "Missing : $flavor"
|
pascal@4447
|
211 echo "Missing flavor : $flavor" >> $DB_DIR/report
|
pascal@4447
|
212 continue
|
pascal@4447
|
213 fi
|
pascal@4452
|
214 for i in $(find $HG_FLAVORS/$flavor -type f); do
|
pascal@4447
|
215 [ $PACKAGES_REPOSITORY/$flavor.flavor -nt \
|
pascal@4447
|
216 $i ] && continue
|
pascal@4447
|
217 echo $flavor >> $DB_DIR/packlist
|
pascal@4900
|
218 [ "$1" = "report" ] && echo "Refresh : $flavor for $i"
|
pascal@4447
|
219 echo "Refresh flavor : $flavor" >> $DB_DIR/report
|
pascal@4447
|
220 continue 2
|
pascal@4447
|
221 done
|
pascal@4447
|
222 [ -s $HG_FLAVORS/$flavor/packages.list ] &&
|
pascal@4447
|
223 for i in $(cat $HG_FLAVORS/$flavor/packages.list); do
|
pascal@4902
|
224 if [ ! -d $BUILD_WOK/$i ]; then
|
pascal@4901
|
225 [ "$1" = "report" ] &&
|
pascal@4901
|
226 echo "Fix flavor for $i: $flavor"
|
pascal@4901
|
227 echo "Fix flavor for $i: $flavor" >> $DB_DIR/report
|
pascal@4901
|
228 continue
|
pascal@4901
|
229 fi
|
pascal@4447
|
230 [ $PACKAGES_REPOSITORY/$flavor.flavor -nt \
|
pascal@4447
|
231 $BUILD_WOK/$i/taz ] && continue
|
pascal@4447
|
232 echo $flavor >> $DB_DIR/packlist
|
pascal@4900
|
233 [ "$1" = "report" ] && echo "Repack : $flavor for $i"
|
pascal@4447
|
234 echo "Repack flavor : $flavor" >> $DB_DIR/report
|
pascal@4447
|
235 continue 2
|
pascal@4447
|
236 done
|
pascal@4447
|
237 done
|
pascal@4963
|
238
|
pascal@4963
|
239 # Check for meta flavors
|
pascal@4963
|
240 for flavor in $(cd $HG_FLAVORS ; ls)
|
pascal@4963
|
241 do
|
pascal@4963
|
242 grep -q ^ROOTFS_SELECTION $HG_FLAVORS/$flavor/receipt || continue
|
pascal@4963
|
243 . $HG_FLAVORS/$flavor/receipt
|
pascal@4963
|
244 set -- $ROOTFS_SELECTION
|
pascal@4963
|
245 if [ $PACKAGES_REPOSITORY/$2.flavor -nt \
|
pascal@4963
|
246 $PACKAGES_REPOSITORY/$flavor.flavor ]; then
|
pascal@4963
|
247 echo $flavor >> $DB_DIR/packlist
|
pascal@4963
|
248 [ "$1" = "report" ] && echo "Refresh : $flavor for $2"
|
pascal@4963
|
249 echo "Refresh meta flavor : $flavor" >> $DB_DIR/report
|
pascal@4963
|
250 continue
|
pascal@4963
|
251 fi
|
pascal@4963
|
252 if grep -q ^$2$ $DB_DIR/packlist ; then
|
pascal@4963
|
253 echo $flavor >> $DB_DIR/packlist
|
pascal@4963
|
254 [ "$1" = "report" ] && echo "Repack : $flavor for $2"
|
pascal@4963
|
255 echo "Repack meta flavor : $flavor" >> $DB_DIR/report
|
pascal@4963
|
256 continue
|
pascal@4963
|
257 fi
|
pascal@4963
|
258 done
|
pascal@4447
|
259 }
|
pascal@4447
|
260
|
pascal@4447
|
261 # Here we pack all flavors found in the packlist.
|
pascal@4447
|
262 pack_flavors()
|
pascal@4447
|
263 {
|
pascal@4447
|
264 [ -s $DB_DIR/packlist ] || return
|
pascal@4447
|
265 [ $PACKAGES_REPOSITORY/packages.list -nt /var/lib/tazpkg/packages.list ] &&
|
pascal@4447
|
266 cp -a $PACKAGES_REPOSITORY/packages.list /var/lib/tazpkg/packages.list
|
pascal@4447
|
267 cd $PACKAGES_REPOSITORY
|
pascal@4447
|
268 for flavor in $(cat $DB_DIR/packlist)
|
pascal@4447
|
269 do
|
pascal@4447
|
270 tazlito pack-flavor $flavor
|
pascal@4447
|
271 # Remove flavor from the packlist and empty lines for HTML <pre>.
|
pascal@4447
|
272 sed -i /"^$flavor$"/d $DB_DIR/packlist
|
pascal@4447
|
273 sed -i '/^$/d' $DB_DIR/packlist
|
pascal@4447
|
274 done
|
pascal@4447
|
275 cd - > /dev/null
|
pascal@4447
|
276 }
|
pascal@4447
|
277
|
pankso@3512
|
278 # Running 'tazbb report' should not cook anything and --verbose option
|
pankso@3512
|
279 # can be used to display more messages.
|
pankso@3512
|
280 check_wok()
|
pankso@3512
|
281 {
|
pankso@3512
|
282 # Clean up last results.
|
pankso@3512
|
283 rm -f $DB_DIR/cooklist && touch $DB_DIR/cooklist
|
pankso@3512
|
284 rm -f $DB_DIR/report && touch $DB_DIR/report
|
pankso@3512
|
285 rm -f $DB_DIR/unbuilt && touch $DB_DIR/unbuilt
|
pankso@3512
|
286 echo "Checking all files in: $HG_WOK"
|
pankso@3512
|
287 echo "================================================================================"
|
pankso@3512
|
288 echo "(checking wok)" > $DB_DIR/running
|
pascal@6051
|
289 TOOLCHAIN="$(. $HG_WOK/slitaz-toolchain/receipt ; echo $DEPENDS)"
|
pankso@3512
|
290 for pkg in $HG_WOK/*
|
pankso@3512
|
291 do
|
pankso@3512
|
292 EXTRAVERSION=""
|
pankso@3512
|
293 WANTED=""
|
pascal@6049
|
294 BUILD_DEPENDS=""
|
pascal@6048
|
295 [ -s $pkg/receipt ] || continue
|
pankso@3512
|
296 . $pkg/receipt
|
pankso@3512
|
297 [ "$2" = "--verbose" ] && echo "Package : $PACKAGE"
|
pankso@3512
|
298 # Skip blocked packages.
|
pankso@3512
|
299 if grep -qs "^$PACKAGE$" $DB_DIR/blocked; then
|
pankso@3512
|
300 echo "Blocked : $PACKAGE ($VERSION)" && continue
|
pankso@3512
|
301 fi
|
pankso@3512
|
302
|
pascal@4447
|
303 # Some packages may compute VERSION at cook time (bristuff)
|
pascal@4447
|
304 if grep -q ^get_version $pkg/receipt; then
|
pankso@3512
|
305 . $BUILD_WOK/$PACKAGE/taz/*/receipt
|
pankso@3512
|
306 fi
|
pankso@3512
|
307
|
pankso@3537
|
308 # First check if package exit. Package naming _must_ be in the form of:
|
pankso@3512
|
309 # $PACKAGE-$VERSION or $PACKAGE-${VERSION}$EXTRAVERSION (Kernel string).
|
pankso@3512
|
310 if [ ! -f $PACKAGES_REPOSITORY/$PACKAGE-$VERSION.tazpkg ]; then
|
pankso@3512
|
311 [ -z "$EXTRAVERSION" ] && EXTRAVERSION="_$KERNEL"
|
pankso@3512
|
312 if [ ! -f $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg ]; then
|
pankso@3512
|
313 [ "$1" = "report" ] && echo "Missing : $PACKAGE ($VERSION)"
|
pankso@3512
|
314 echo "Missing : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
315 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
316 fi
|
pankso@3512
|
317 else
|
pankso@3512
|
318 # Check if package is up-to-date.
|
pascal@5881
|
319 PKG_YEAR=`date -u -r $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}${EXTRAVERSION}.tazpkg '+%Y'`
|
pascal@5881
|
320 PKG_DATE=`date -u -r $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}${EXTRAVERSION}.tazpkg '+%m%d%H%M'`
|
pankso@3512
|
321 for file in `find $pkg -type f`
|
pankso@3512
|
322 do
|
pascal@5881
|
323 FILE_YEAR=`date -u -r $file '+%Y'`
|
pascal@5881
|
324 FILE_DATE=`date -u -r $file '+%m%d%H%M'`
|
pankso@3512
|
325 [ "$2" = "--verbose" ] && echo " -> Checking: $file"
|
pascal@5881
|
326 if [ "$FILE_YEAR" -ge "$PKG_YEAR" -a "$FILE_DATE" -gt "$PKG_DATE" ] && ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pankso@3512
|
327 [ "$1" = "report" ] && echo "Refresh : $PACKAGE ($VERSION)"
|
pankso@3512
|
328 echo "Refresh : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
329 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
330 fi
|
pankso@3512
|
331 done
|
pankso@3512
|
332 fi
|
pankso@3537
|
333 # Now check if package is built and not already in the list.
|
pankso@3512
|
334 if [ ! -d $BUILD_WOK/$PACKAGE/taz ] && ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pankso@3512
|
335 [ "$1" = "report" ] && echo "Unbuilt : $PACKAGE ($VERSION)"
|
pankso@3512
|
336 echo "Unbuilt : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
337 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
338 fi
|
pascal@6049
|
339 if ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pascal@6053
|
340 case " $TOOLCHAIN " in
|
pascal@6053
|
341 *\ $PACKAGE\ *) continue;;
|
pascal@6053
|
342 esac
|
pascal@6051
|
343 for dep in $BUILD_DEPENDS $TOOLCHAIN ; do
|
pascal@6049
|
344 [ $BUILD_WOK/$PACKAGE/taz -nt $BUILD_WOK/$dep/taz ] && continue
|
pascal@6049
|
345 [ "$1" = "report" ] && echo "Refresh : $PACKAGE (older than $dep)"
|
pascal@6049
|
346 echo "Refresh : $PACKAGE (older than $dep)" >> $DB_DIR/report
|
pascal@6049
|
347 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pascal@6049
|
348 break
|
pascal@6049
|
349 done
|
pascal@6049
|
350 fi
|
pankso@3512
|
351 # Rebuild unbuilt packages list with link to log file. This list
|
pankso@3537
|
352 # is also generated by cook_inslall to have real time stats.
|
pankso@3512
|
353 if [ ! -d $BUILD_WOK/$PACKAGE/taz ]; then
|
pascal@5823
|
354 echo "<a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">$PACKAGE</a>" \
|
pankso@3512
|
355 >> $DB_DIR/unbuilt
|
pankso@3512
|
356 fi
|
pankso@3512
|
357 done
|
pankso@3512
|
358 packages_summary
|
pankso@3512
|
359 }
|
pankso@3512
|
360
|
pankso@3537
|
361 # Create a new cooklist and summary (dont modify report) so 'tazbb cook-commit'
|
pankso@3512
|
362 # can cook last changes.
|
pankso@3512
|
363 check_commit()
|
pankso@3512
|
364 {
|
pankso@3512
|
365 echo "(checking commit)" > $DB_DIR/running
|
pankso@3512
|
366 cd $HG_WOK
|
pankso@3512
|
367 # Clean up last results.
|
pankso@3512
|
368 rm -f $DB_DIR/cooklist && touch $DB_DIR/cooklist
|
pankso@3512
|
369 # Get the name of modified packages by the revision range. +1 last
|
pankso@3537
|
370 # commit was build by the previous build.
|
pankso@3512
|
371 LAST_REV=$(($LAST_REV+1))
|
pankso@3512
|
372 echo -e "Will cook from revision $LAST_REV to $NEW_REV\n"
|
pankso@3512
|
373 for file in `hg log --rev=$LAST_REV:$NEW_REV --template '{files}\n'`
|
pankso@3512
|
374 do
|
pankso@3512
|
375 pkg=`echo $file | cut -d "/" -f 1`
|
pankso@3512
|
376 if ! grep -q ^$pkg$ $DB_DIR/cooklist; then
|
pankso@3512
|
377 . $pkg/receipt
|
pankso@3512
|
378 echo "Commit : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
379 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
380 fi
|
pankso@3512
|
381 done
|
pankso@3512
|
382 packages_summary
|
pankso@3512
|
383 }
|
pankso@3512
|
384
|
pascal@4174
|
385 # Cook one package
|
pascal@4174
|
386 cook_package()
|
pascal@4174
|
387 {
|
pascal@4174
|
388 EXTRAVERSION=""
|
pascal@4174
|
389 DEPENDS=""
|
pascal@4174
|
390 BUILD_DEPENDS=""
|
pascal@4174
|
391 SOURCE=""
|
pascal@4174
|
392 WANTED=""
|
pascal@5823
|
393 echo "(cooking <a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>)" > $DB_DIR/running
|
pascal@4174
|
394 tazwok clean $pkg
|
pascal@4174
|
395 script -c "echo 'install' | tazwok cook $pkg" $LOG_DIR/$pkg.log
|
pascal@4174
|
396 # Install new package (important for new shared libs). Note
|
pascal@4174
|
397 # that tests are done separatly with 'test_packages' and should
|
pascal@4174
|
398 # be done by tazwok.
|
pascal@4174
|
399 if [ -f $BUILD_WOK/$pkg/taz/*/receipt ]; then
|
pascal@5013
|
400 TAZBB_NO_INSTALL=""
|
pascal@4174
|
401 . $BUILD_WOK/$pkg/taz/*/receipt
|
pascal@5013
|
402 [ -n "$TAZBB_NO_INSTALL" ] && return 0
|
pascal@4174
|
403 echo "(installing $PACKAGE-${VERSION}$EXTRAVERSION.tazpkg)" \
|
pascal@4174
|
404 > $DB_DIR/running
|
pascal@4174
|
405 yes | tazpkg install \
|
pascal@4174
|
406 $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg \
|
pascal@4174
|
407 --forced
|
pascal@4174
|
408 return 0
|
pascal@4174
|
409 fi
|
pascal@4174
|
410 return 1
|
pascal@4174
|
411 }
|
pascal@4174
|
412
|
pascal@4174
|
413 # Sort list according WANTED and BUILD_DEPENDS
|
pascal@4174
|
414 sort_cook_list()
|
pascal@4174
|
415 {
|
pascal@4174
|
416 sort | while read pkg; do
|
pascal@4174
|
417 echo -n "$pkg"
|
pascal@4174
|
418 WANTED=""
|
pascal@4174
|
419 BUILD_DEPENDS=""
|
pascal@4174
|
420 . $BUILD_WOK/$pkg/receipt
|
pascal@4185
|
421 MISSING=""
|
pascal@4174
|
422 for i in $WANTED $BUILD_DEPENDS ; do
|
pascal@4174
|
423 if [ ! -f $BUILD_WOK/$i/taz/*/receipt ]; then
|
pascal@4185
|
424 case " $MISSING " in
|
pascal@4185
|
425 *\ $i\ *);;
|
pascal@4185
|
426 *) echo -n " $i";;
|
pascal@4185
|
427 esac
|
pascal@4185
|
428 MISSING="$MISSING $i"
|
pascal@4174
|
429 fi
|
pascal@4174
|
430 done
|
pascal@4174
|
431 echo ""
|
pascal@4185
|
432 done | awk '
|
pascal@4185
|
433 function show(name)
|
pascal@4185
|
434 {
|
pascal@4185
|
435 print name;
|
pascal@4185
|
436 got[name]++;
|
pascal@4185
|
437 if (revdepcnt[name] > 0)
|
pascal@4185
|
438 for (i = split(revdep[name], pkg, " "); i > 0; i--)
|
pascal@4185
|
439 if (--depcnt[pkg[i]] == 0) show(pkg[i]);
|
pascal@4185
|
440 }
|
pascal@4185
|
441
|
pascal@4185
|
442 {
|
pascal@4185
|
443 if ($2 == "") show($1);
|
pascal@4185
|
444 else {
|
pascal@4185
|
445 depcnt[$1] = NF - 1;
|
pascal@4185
|
446 unres = unres " " $1;
|
pascal@4185
|
447 for (i = 2; i <= NF; i++) {
|
pascal@4185
|
448 if (got[$i] > 0) continue;
|
pascal@4185
|
449 revdepcnt[$i]++;
|
pascal@4185
|
450 revdep[$i] = revdep[$i] " " $1;
|
pascal@4174
|
451 }
|
pascal@4174
|
452 }
|
pascal@4185
|
453 }
|
pascal@4185
|
454 END {
|
pascal@4185
|
455 for (i = split(unres, pkg, " "); i > 0; i--)
|
pascal@4185
|
456 if (depcnt[pkg[i]] > 0) print pkg[i];
|
pascal@4185
|
457 }
|
pascal@4174
|
458 '
|
pascal@4174
|
459 }
|
pascal@4174
|
460
|
pankso@3512
|
461 # Here we cook all packages found in the cooklist.
|
pankso@3512
|
462 cook_install()
|
pankso@3512
|
463 {
|
pankso@3512
|
464 echo "" > $DB_DIR/unbuilt
|
pascal@4174
|
465 for pkg in `cat $DB_DIR/cooklist | sort_cook_list`
|
pankso@3512
|
466 do
|
pascal@4174
|
467 if ! cook_package $pkg; then
|
pankso@3512
|
468 # Link to build log.
|
pascal@5823
|
469 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pankso@3512
|
470 $DB_DIR/unbuilt
|
pankso@3512
|
471 fi
|
pascal@4996
|
472 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
473 if [ -n "$missing_depends" ]; then
|
pascal@4996
|
474 cat >> $LOG_DIR/$pkg.log <<EOT
|
pascal@4996
|
475
|
pascal@4996
|
476 Update $pkg receipt for DEPENDS :
|
pascal@4996
|
477 The package $pkg depends on packages $missing_depends
|
pascal@4996
|
478
|
pascal@4996
|
479 EOT
|
pascal@4996
|
480 # Unbuild package
|
pascal@4996
|
481 rm -rf $BUILD_WOK/$pkg/taz
|
pascal@4996
|
482 # Link to build log.
|
pascal@5823
|
483 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pascal@4996
|
484 $DB_DIR/unbuilt
|
pascal@4996
|
485 fi
|
pankso@3512
|
486 # Remove package from the cooklist and empty lines for HTML <pre>.
|
pankso@3512
|
487 sed -i /"^$pkg$"/d $DB_DIR/cooklist
|
pankso@3512
|
488 sed -i '/^$/d' $DB_DIR/cooklist
|
pankso@3537
|
489 packages_summary_update
|
pankso@3512
|
490 done
|
pankso@3512
|
491 }
|
pankso@3512
|
492
|
pascal@4996
|
493 # Build depends_to_skip list with packages to remove from depends_to_add list
|
pascal@4996
|
494 # These packages are already present in depends_to_add trees
|
pascal@4996
|
495 scan_depends_to_skip()
|
pascal@4996
|
496 {
|
pascal@4996
|
497 local i
|
pascal@4996
|
498 case " $depends_to_skip " in
|
pascal@4996
|
499 *\ $1\ *) return;;
|
pascal@4996
|
500 esac
|
pascal@4996
|
501 [ -d $BUILD_WOK/$1 ] || return
|
pascal@4996
|
502 DEPENDS=""
|
pascal@4996
|
503 . $BUILD_WOK/$1/receipt
|
pascal@4996
|
504 for i in $DEPENDS ; do
|
pascal@4996
|
505 case " $depends_to_add " in
|
pascal@4996
|
506 *\ $i\ *) depends_to_skip="$depends_to_skip $i";;
|
pascal@4996
|
507 esac
|
pascal@4996
|
508 done
|
pascal@4996
|
509 for i in $DEPENDS ; do
|
pascal@4996
|
510 scan_depends_to_skip $i
|
pascal@4996
|
511 done
|
pascal@4996
|
512 }
|
pascal@4996
|
513
|
pascal@4996
|
514 # Reduce depends list by scanning nested depends
|
pascal@4996
|
515 show_missing_depends()
|
pascal@4996
|
516 {
|
pascal@4996
|
517 local i
|
pascal@4996
|
518 depends_to_add=""
|
pascal@4996
|
519 depends_to_skip="$2"
|
pascal@4996
|
520 for i in $1 ; do
|
pascal@4996
|
521 case " $depends_to_add " in
|
pascal@4996
|
522 *\ $i\ *) continue;;
|
pascal@4996
|
523 esac
|
pascal@4996
|
524 depends_to_add="$depends_to_add$i "
|
pascal@4996
|
525 done
|
pascal@4996
|
526 for i in $depends_to_add ; do
|
pascal@4996
|
527 scan_depends_to_skip $i
|
pascal@4996
|
528 done
|
pascal@4996
|
529 for i in $depends_to_add ; do
|
pascal@4996
|
530 case " $depends_to_skip " in
|
pascal@4996
|
531 *\ $i\ *) continue;;
|
pascal@4996
|
532 esac
|
pascal@4996
|
533 echo -n "$i "
|
pascal@4996
|
534 done
|
pascal@4996
|
535 }
|
pascal@4996
|
536
|
pascal@4996
|
537 # Build all_depends variable
|
pascal@4996
|
538 scan_dep()
|
pascal@4996
|
539 {
|
pascal@4996
|
540 local i
|
pascal@4996
|
541 all_depends="$all_depends$PACKAGE "
|
pascal@4996
|
542 for i in $DEPENDS $SUGGESTED ; do
|
pascal@4996
|
543 case " $all_depends " in
|
pascal@4996
|
544 *\ $i\ *) continue;;
|
pascal@4996
|
545 esac
|
pascal@4996
|
546 [ -d $BUILD_WOK/$i ] || {
|
pascal@4996
|
547 all_depends="$all_depends$i "
|
pascal@4996
|
548 continue
|
pascal@4996
|
549 }
|
pascal@4996
|
550 DEPENDS=""
|
pascal@4996
|
551 SUGGESTED=""
|
pascal@4996
|
552 . $BUILD_WOK/$i/receipt
|
pascal@4996
|
553 scan_dep
|
pascal@4996
|
554 done
|
pascal@4996
|
555 }
|
pascal@4996
|
556
|
pascal@4996
|
557 # Check for ELF file
|
pascal@4996
|
558 is_elf()
|
pascal@4996
|
559 {
|
pascal@4996
|
560 [ "$(dd if=$1 bs=1 skip=1 count=3 2> /dev/null)" = "ELF" ]
|
pascal@4996
|
561 }
|
pascal@4996
|
562
|
pascal@4996
|
563 # Print shared library dependencies
|
pascal@4996
|
564 ldd()
|
pascal@4996
|
565 {
|
pascal@4996
|
566 LD_PRELOAD="" LD_TRACE_LOADED_OBJECTS=1 /lib/ld*.so $1 2> /dev/null
|
pascal@4996
|
567 }
|
pascal@4996
|
568
|
pascal@4996
|
569 # scan a file for shared libraries and display according package names
|
pascal@4996
|
570 check_depends_file()
|
pascal@4996
|
571 {
|
pascal@4996
|
572 file=$1
|
pascal@4996
|
573 is_elf $file || continue
|
pascal@4996
|
574 case "$file" in
|
pascal@4996
|
575 *.o|*.ko|*.ko.gz) continue;;
|
pascal@4996
|
576 esac
|
pascal@4996
|
577 [ -s /tmp/files.list.tazbb$$ ] ||
|
pascal@4996
|
578 unlzma -c $PACKAGES_REPOSITORY/files.list.lzma >/tmp/files.list.tazbb$$
|
pascal@4996
|
579 ldd $file | while read lib rem; do
|
pascal@4996
|
580 case "$lib" in
|
pascal@4996
|
581 statically|linux-gate.so*|ld-*.so|*/ld-*.so)
|
pascal@4996
|
582 continue;;
|
pascal@4996
|
583 esac
|
pascal@4996
|
584 for dep in $(grep $lib /tmp/files.list.tazbb$$ | cut -d: -f1); do
|
pascal@4996
|
585 case " $all_depends " in
|
pascal@4996
|
586 *\ $dep\ *) continue 2;;
|
pascal@4996
|
587 esac
|
pascal@4996
|
588 for vdep in $(grep $dep $PACKAGES_REPOSITORY/packages.equiv | cut -d= -f1); do
|
pascal@4996
|
589 case " $all_depends " in
|
pascal@4996
|
590 *\ $vdep\ *) continue 3;;
|
pascal@4996
|
591 esac
|
pascal@4996
|
592 done
|
pascal@4996
|
593 done
|
pascal@4996
|
594 [ -n "$dep" ] || dep="UNKNOWN"
|
pascal@4996
|
595 all_depends="$all_depends $dep"
|
pascal@4996
|
596 if [ -n "$VERBOSE" ]; then
|
pascal@4996
|
597 echo "${file#*fs} depends on package $dep for the shared library $lib" 1>&2
|
pascal@4996
|
598 fi
|
pascal@4996
|
599 echo -n "$dep "
|
pascal@4996
|
600 done
|
pascal@4996
|
601 }
|
pascal@4996
|
602
|
pascal@4996
|
603 DEFAULT_DEPENDS="glibc-base"
|
pascal@4996
|
604
|
pascal@4996
|
605 # scan a package for shared libraries and display missing package in DEPENDS
|
pascal@4996
|
606 check_depends_pkg()
|
pascal@4996
|
607 {
|
pascal@4996
|
608 pkg=$1
|
pascal@4996
|
609 echo "(checking depends for $pkg)" > $DB_DIR/running
|
pascal@4996
|
610 tmp=/tmp/tazbb$$
|
pascal@4996
|
611 mkdir $tmp
|
pascal@4996
|
612 package=$(basename $pkg)
|
pascal@4996
|
613 if ! cd ${package%%-*}*/taz/${package%.tazpkg}/.. 2> /dev/null; then
|
pascal@4996
|
614 cd $tmp
|
pascal@4996
|
615 tazpkg extract $pkg > /dev/null 2>&1
|
pascal@4996
|
616 fi
|
pascal@4996
|
617 . */receipt
|
pascal@4996
|
618 all_depends="$DEFAULT_DEPENDS "
|
pascal@4996
|
619 scan_dep
|
pascal@4996
|
620 toadd=$(find */fs -type f | while read file ; do
|
pascal@4996
|
621 check_depends_file $file
|
pascal@4996
|
622 done)
|
pascal@4996
|
623 . */receipt
|
pascal@4996
|
624 rm -rf */
|
pascal@4996
|
625 cd - > /dev/null
|
pascal@4996
|
626 rm -rf $tmp
|
pascal@4996
|
627 show_missing_depends "$toadd" "$DEPENDS $SUGGESTED"
|
pascal@4996
|
628 }
|
pascal@4996
|
629
|
pascal@4996
|
630 check_depends_this_file()
|
pascal@4996
|
631 {
|
pascal@4996
|
632 file=$1
|
pascal@4996
|
633 all_depends="$DEFAULT_DEPENDS "
|
pascal@4996
|
634 scan_dep
|
pascal@4996
|
635 check_depends_file $file
|
pascal@4996
|
636 }
|
pascal@4996
|
637
|
pankso@3512
|
638 # Remove old packages in the build wok and clean pkgs repository. The
|
pankso@3512
|
639 # Hg wok is copied into the build wok so packages removed by hg must be
|
pankso@3512
|
640 # removed. To remove old packages in the repository we look into the
|
pankso@3537
|
641 # build wok and dont remove unbuilt packages. Clean-up will also remove
|
pankso@3512
|
642 # all corrupted packages.
|
pankso@3512
|
643 clean_up()
|
pankso@3512
|
644 {
|
pankso@3512
|
645 touch $DB_DIR/removed
|
pankso@3512
|
646 echo -e "\nCleaning the build wok, old and corrupted packages...\n"
|
pankso@3512
|
647 echo "(cleaning)" > $DB_DIR/running
|
pankso@4208
|
648 for pkg in `ls $BUILD_WOK`
|
pankso@3512
|
649 do
|
pankso@4208
|
650 if [ ! -d $HG_WOK/$pkg ]; then
|
pankso@3512
|
651 case $2 in
|
pankso@3512
|
652 --dry-run)
|
pankso@3512
|
653 echo "Removing directory : $pkg" ;;
|
pankso@3512
|
654 --verbose)
|
pankso@3512
|
655 echo "Removing directory : $pkg"
|
pankso@3512
|
656 rm -rf $BUILD_WOK/$pkg ;;
|
pankso@3512
|
657 *)
|
pankso@3512
|
658 rm -rf $BUILD_WOK/$pkg ;;
|
pankso@3512
|
659 esac
|
pankso@3512
|
660 fi
|
pankso@3512
|
661 done
|
pankso@3512
|
662 # Build a packages list with EXTRAVERSION so we can grep into it.
|
pankso@3512
|
663 rm -f $DB_DIR/packaged && touch $DB_DIR/packaged
|
pankso@3512
|
664 for receipt in $BUILD_WOK/*/taz/*/receipt
|
pankso@3512
|
665 do
|
pankso@3512
|
666 EXTRAVERSION=""
|
pankso@3512
|
667 . $receipt
|
pankso@3512
|
668 echo "$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg" >> $DB_DIR/packaged
|
pankso@3512
|
669 done
|
pankso@3512
|
670 for pkg in `cd $PACKAGES_REPOSITORY && ls *.tazpkg`
|
pankso@3512
|
671 do
|
pankso@3512
|
672 if ! grep -q "^$pkg$" $DB_DIR/packaged; then
|
pankso@3512
|
673 case $2 in
|
pankso@3512
|
674 --dry-run)
|
pankso@3512
|
675 echo "Removing package : $pkg" ;;
|
pankso@3512
|
676 --verbose)
|
pankso@3512
|
677 echo "Removing package : $pkg"
|
pankso@3512
|
678 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
679 rm -f $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
680 *)
|
pankso@3512
|
681 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
682 rm -f $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
683 esac
|
pankso@3512
|
684 fi
|
pankso@3512
|
685 done
|
pankso@3512
|
686 # Remove all corrupted packages
|
pankso@3512
|
687 for pkg in `cat $DB_DIR/corrupted | awk '{ print $3 }'`
|
pankso@3512
|
688 do
|
pankso@3512
|
689 case $2 in
|
pankso@3512
|
690 --dry-run)
|
pankso@3512
|
691 echo "Removing corrupted: $pkg" ;;
|
pankso@3512
|
692 --verbose)
|
pankso@3512
|
693 echo "Removing corrupted: $pkg"
|
pankso@3512
|
694 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
695 rm -rf $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
696 *)
|
pankso@3512
|
697 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
698 rm -rf $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
699 esac
|
pankso@3512
|
700 done
|
pankso@3512
|
701 echo ""
|
pankso@3512
|
702 # Keep the 20 last removed packages list.
|
pankso@3512
|
703 cat $DB_DIR/removed | tail -n 20 > /tmp/removed.tail
|
pankso@3512
|
704 mv -f /tmp/removed.tail $DB_DIR/removed
|
pankso@5132
|
705 # Clean packages stuff/ directory
|
pankso@5132
|
706 echo -e "\nCleaning the build wok stuff/ directories...\n"
|
pankso@5132
|
707 for pkg in `ls $BUILD_WOK`
|
pankso@5132
|
708 do
|
pankso@5132
|
709 if [ -d "$BUILD_WOK/$pkg/stuff" ]; then
|
pankso@5132
|
710 cd $BUILD_WOK/$pkg
|
pankso@5132
|
711 for file in `find stuff -type f`
|
pankso@5132
|
712 do
|
pankso@5132
|
713 if [ ! -f "$HG_WOK/$pkg/$file" ]; then
|
pankso@5132
|
714 echo "Removing: $pkg/$file"
|
pankso@5132
|
715 rm $file
|
pankso@5132
|
716 fi
|
pankso@5132
|
717 done
|
pankso@5132
|
718 fi
|
pankso@5132
|
719 done
|
pankso@3512
|
720 }
|
pankso@3512
|
721
|
pankso@3512
|
722 blocked_urls()
|
pankso@3512
|
723 {
|
pankso@3512
|
724 rm -f $DB_DIR/blocked.urls
|
pankso@3512
|
725 for pkg in `cat $DB_DIR/blocked`
|
pankso@3512
|
726 do
|
pankso@3512
|
727 if [ -f $LOG_DIR/$pkg.log ]; then
|
pascal@5823
|
728 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pankso@3512
|
729 $DB_DIR/blocked.urls
|
pankso@3512
|
730 else
|
pankso@3512
|
731 echo "$pkg" >> $DB_DIR/blocked.urls
|
pankso@3512
|
732 fi
|
pankso@3512
|
733 done
|
pankso@3512
|
734 }
|
pankso@3512
|
735
|
pankso@3512
|
736 # 4k, not a meta or a get-* package and no files = buggy package
|
pankso@3512
|
737 test_packages()
|
pankso@3512
|
738 {
|
pankso@3512
|
739 echo -e "\nTesting all packages in: $PACKAGES_REPOSITORY"
|
pankso@3512
|
740 echo "================================================================================"
|
pankso@3512
|
741 echo "(testing packages)" > $DB_DIR/running
|
pankso@3512
|
742 rm -f $DB_DIR/corrupted && touch $DB_DIR/corrupted
|
pankso@3512
|
743 for pkg in $PACKAGES_REPOSITORY/*.tazpkg
|
pankso@3512
|
744 do
|
pankso@3512
|
745 tmp=/tmp/bb-test.$$
|
pankso@3512
|
746 CATEGORY=""
|
pankso@3512
|
747 if du $pkg | grep -qw '^4' && ! echo `basename $pkg` | grep -q '^get-'; then
|
pankso@3512
|
748 mkdir -p $tmp && cd $tmp
|
pascal@4700
|
749 cpio -i receipt >/dev/null 2>&1 < $pkg
|
pankso@3512
|
750 . ./receipt
|
pankso@3512
|
751 if [ "$CATEGORY" != "meta" ]; then
|
pankso@3512
|
752 [ "$2" = "--verbose" ] && echo "Testing: $PACKAGE"
|
pascal@5882
|
753 cpio -i fs.cpio.gz >/dev/null 2>&1 < $pkg
|
pascal@5882
|
754 cpio -i fs.cpio.lzma >/dev/null 2>&1 < $pkg
|
pascal@4850
|
755 if [ ! -f fs.cpio.gz -a ! -f fs.cpio.lzma ]; then
|
pankso@3516
|
756 echo "Missing filesystem `basename $pkg`"
|
pankso@3512
|
757 if [ -f $LOG_DIR/$PACKAGE.log ];then
|
pascal@5823
|
758 echo "Missing filesystem `basename $pkg` <a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">Log</a>" \
|
pankso@3512
|
759 >> $DB_DIR/corrupted
|
pankso@3512
|
760 else
|
pankso@3516
|
761 echo "Missing filesystem `basename $pkg`" \
|
pankso@3512
|
762 >> $DB_DIR/corrupted
|
pankso@3512
|
763 fi
|
pankso@3512
|
764 else
|
pascal@4850
|
765 ( zcat fs.cpio.gz 2> /dev/null || \
|
pascal@4850
|
766 unlzma -c fs.cpio.lzma ) | \
|
pascal@4850
|
767 cpio -id >/dev/null 2>&1
|
pascal@4395
|
768 files=`find fs -type f -o -type l`
|
pankso@3512
|
769 if [ -z "$files" ]; then
|
pankso@3516
|
770 echo "Empty filesystem `basename $pkg`"
|
pankso@3512
|
771 if [ -f $LOG_DIR/$PACKAGE.log ]; then
|
pascal@5823
|
772 echo "Empty filesystem `basename $pkg` <a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">Log</a>" \
|
pankso@3512
|
773 >> $DB_DIR/corrupted
|
pankso@3512
|
774 else
|
pankso@3516
|
775 echo "Empty filesystem `basename $pkg`" \
|
pankso@3512
|
776 >> $DB_DIR/corrupted
|
pankso@3512
|
777 fi
|
pankso@3512
|
778 fi
|
pankso@3512
|
779 fi
|
pankso@3512
|
780 fi
|
pankso@3512
|
781 cd .. && rm -rf $tmp
|
pankso@3512
|
782 fi
|
pankso@3512
|
783 done
|
pankso@3512
|
784 packages_summary_update
|
pankso@3512
|
785 echo ""
|
pankso@3512
|
786 }
|
pankso@3512
|
787
|
pascal@4447
|
788 # Generate flavor list
|
pascal@4447
|
789 gen_flavor_list()
|
pascal@4447
|
790 {
|
pascal@4447
|
791 cd $PACKAGES_REPOSITORY
|
pascal@4447
|
792 noheader=""
|
pascal@4447
|
793 for i in *.flavor; do
|
pascal@4447
|
794 tazlito show-flavor $i --brief $noheader
|
pascal@4447
|
795 noheader="--noheader"
|
pascal@4447
|
796 done > flavors.list
|
pascal@4447
|
797 cd - > /dev/null
|
pascal@4447
|
798 }
|
pascal@4447
|
799
|
pankso@3512
|
800 case "$1" in
|
pankso@3512
|
801 list-pkgs)
|
pankso@3512
|
802 # List last cooked packages.
|
pankso@3512
|
803 list_packages ;;
|
pankso@3512
|
804 report)
|
pankso@3512
|
805 # Run in report mode. If an update is done we must cook-all to
|
pankso@3512
|
806 # rebuild all updated packages.
|
pankso@3512
|
807 [ "$2" == "--update" ] && update_wok $@ || echo ""
|
pankso@3512
|
808 check_wok $@
|
pascal@4447
|
809 check_flavors $@
|
pankso@3512
|
810 test_packages $@
|
pankso@3512
|
811 show_report ;;
|
pankso@4110
|
812 cook)
|
pankso@4110
|
813 # Cook, install and log a single package build.
|
pankso@4110
|
814 if [ -z $2 ]; then
|
pankso@4110
|
815 echo "Please specify a package on the command line."
|
pankso@4110
|
816 rm -f $LOCK_FILE && exit 0
|
pankso@4110
|
817 fi
|
pankso@4110
|
818 pkg=$2
|
pankso@4110
|
819 echo "Starting to cook and install: $pkg"
|
pascal@4174
|
820 if ! cook_package $pkg; then
|
pankso@4110
|
821 echo "Unable to install: $pkg"
|
pankso@4110
|
822 fi ;;
|
pankso@3512
|
823 cook-all)
|
pankso@3512
|
824 # Update wok, gen report (with cooklist), cook all packages, test,
|
pankso@3512
|
825 # clean, gen new report and lists.
|
pankso@3512
|
826 update_wok $@
|
pankso@3512
|
827 check_wok $@
|
pankso@3512
|
828 cook_install
|
pankso@3512
|
829 test_packages $@
|
pascal@5034
|
830 check_flavors $@
|
pascal@5034
|
831 pack_flavors
|
pankso@3512
|
832 clean_up $@
|
pankso@3512
|
833 check_wok $@
|
pankso@3512
|
834 echo "(generating lists)" > $DB_DIR/running
|
pankso@3512
|
835 tazwok gen-list --text
|
pascal@4447
|
836 check_flavors $@
|
pascal@4447
|
837 gen_flavor_list
|
pankso@3512
|
838 echo "" ;;
|
pankso@3512
|
839 cook-commit)
|
pankso@3512
|
840 # Cook all packages affected by the last commits in the wok.
|
pankso@3529
|
841 # Clean up is done only by cook-all to avoid rebuild of corrupted
|
pankso@3529
|
842 # packages on each commit.
|
pankso@3512
|
843 update_wok $@
|
pankso@3512
|
844 check_commit
|
pankso@3512
|
845 cook_install
|
pankso@3512
|
846 test_packages $@
|
pascal@5034
|
847 check_flavors $@
|
pascal@5034
|
848 pack_flavors
|
pankso@3512
|
849 check_wok $@
|
pascal@5034
|
850 check_flavors $@
|
pankso@3512
|
851 echo "(generating lists)" > $DB_DIR/running
|
pankso@3512
|
852 tazwok gen-list --text
|
pascal@4447
|
853 gen_flavor_list
|
pankso@3512
|
854 echo "" ;;
|
pankso@3512
|
855 block)
|
pankso@3512
|
856 # Add a pkg name to the list of blocked packages.
|
pankso@3512
|
857 echo ""
|
pankso@3512
|
858 if grep -qs "^$2$" $DB_DIR/blocked; then
|
pankso@3512
|
859 echo -e "$2 is already in the blocked packages list."
|
pankso@3512
|
860 else
|
pankso@3512
|
861 echo -n "Adding $2 to : $DB_DIR/blocked... "
|
pankso@3512
|
862 echo "$2" >> $DB_DIR/blocked && echo "Done"
|
pankso@3512
|
863 if grep -q "^$2$" $DB_DIR/cooklist; then
|
pankso@3512
|
864 echo -n "Removing $2 from : $DB_DIR/cooklist... "
|
pankso@3512
|
865 sed -i /"^$2$"/d $DB_DIR/cooklist && echo "Done"
|
pankso@3512
|
866 packages_summary_update
|
pankso@3512
|
867 fi
|
pankso@3512
|
868 fi
|
pankso@3512
|
869 blocked_urls
|
pankso@3512
|
870 echo "" ;;
|
pankso@3512
|
871 unblock)
|
pankso@3512
|
872 # Remove a pkg name from the list of blocked packages.
|
pankso@3512
|
873 echo ""
|
pankso@3512
|
874 if grep -qs "^$2$" $DB_DIR/blocked; then
|
pankso@3512
|
875 echo -n "Removing $2 from : $DB_DIR/blocked... "
|
pankso@3512
|
876 sed -i /"^$2$"/d $DB_DIR/blocked
|
pankso@3512
|
877 sed -i '/^$/d' $DB_DIR/blocked && echo "Done"
|
pankso@3512
|
878 echo -n "Adding $2 to : $DB_DIR/cooklist... "
|
pankso@3512
|
879 echo "$2" >> $DB_DIR/cooklist && echo "Done"
|
pankso@3512
|
880 packages_summary_update
|
pankso@3512
|
881 else
|
pankso@3512
|
882 echo -e "$2 is not in the blocked packages list."
|
pankso@3512
|
883 fi
|
pankso@3512
|
884 blocked_urls
|
pankso@3512
|
885 echo "" ;;
|
pankso@3512
|
886 test-pkgs)
|
pankso@3537
|
887 # Start a test suite on all builded packages.
|
pankso@3512
|
888 test_packages $@ ;;
|
pankso@3512
|
889 test-suite)
|
pankso@3537
|
890 # Start a test suite on all builded package and the wok using
|
pankso@3512
|
891 # the great 'tazwok check'.
|
pankso@3512
|
892 #
|
pankso@3512
|
893 # test_packages > $LOG_DIR/test-suite.log
|
pankso@3512
|
894 # tazwok check >> $LOG_DIR/test-suite.log
|
pankso@3512
|
895 #
|
pankso@3512
|
896 test_packages $@
|
pankso@3512
|
897 script -c "tazwok check" $LOG_DIR/test-suite.log ;;
|
pankso@3590
|
898 mail)
|
pankso@3590
|
899 # Tazbbmail Pythom script wrapper.
|
pankso@3590
|
900 PACKAGE=$2
|
pankso@3590
|
901 tazbbmail $PACKAGE ;;
|
pankso@3512
|
902 clean-up)
|
pankso@3512
|
903 # Remove old packages and generate new packages lists.
|
pankso@3512
|
904 update_wok $@
|
pankso@3512
|
905 clean_up $@
|
pankso@3512
|
906 packages_summary_update
|
pankso@3512
|
907 [ "$2" != "--dry-run" ] && tazwok gen-list --text ;;
|
pankso@3512
|
908 clean-log)
|
pankso@3512
|
909 logs=`ls $LOG_DIR | wc -l`
|
pankso@3512
|
910 echo -n "Cleaning: $LOG_DIR... "
|
pankso@3512
|
911 rm -rf $LOG_DIR/*
|
pankso@3512
|
912 echo "$logs log removed" ;;
|
pascal@4996
|
913 check-depends)
|
pascal@4996
|
914 case "$2" in
|
pascal@4996
|
915 wok)
|
pascal@4996
|
916 for pkg in $PACKAGES_REPOSITORY/*.tazpkg ; do
|
pascal@4996
|
917 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
918 [ -n "$missing_depends" ] &&
|
pascal@4996
|
919 echo "The package $pkg depends on $missing_depends."
|
pascal@4996
|
920 done ;;
|
pascal@4996
|
921 package)
|
pascal@4996
|
922 pkg=$3
|
pascal@4996
|
923 VERBOSE=$4
|
pascal@4996
|
924 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
925 [ -n "$missing_depends" ] &&
|
pascal@4996
|
926 echo "The package $pkg depends on $missing_depends."
|
pascal@4996
|
927 ;;
|
pascal@4996
|
928 file)
|
pascal@4996
|
929 file=3
|
pascal@4996
|
930 VERBOSE=$4
|
pascal@4996
|
931 missing_depends="$(check_depends_this_file $file)"
|
pascal@4996
|
932 [ -n "$missing_depends" ] &&
|
pascal@4996
|
933 echo "The file $file depends on $missing_depends."
|
pascal@4996
|
934 ;;
|
pascal@4996
|
935 *) cat <<EOT
|
pascal@4996
|
936 check-depends wok check every package in wok.
|
pascal@4996
|
937 check-depends package <pkg> check one package.
|
pascal@4996
|
938 check-depends file <filename> check one file only.
|
pascal@4996
|
939 EOT
|
pascal@4996
|
940 ;;
|
pascal@4996
|
941 esac ;;
|
pankso@3512
|
942 *)
|
pankso@3512
|
943 usage ;;
|
pankso@3512
|
944 esac
|
pankso@3512
|
945
|
pankso@3512
|
946 echo "" > $DB_DIR/running
|
pascal@4996
|
947 rm -f $LOCK_FILE /tmp/files.list.tazbb$$
|
pankso@3512
|
948
|
pankso@3512
|
949 exit 0
|