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
|
pascal@6122
|
32 usage|list-*|*block|check-receipt)
|
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@6065
|
289 TOOLCHAIN="$(. $HG_WOK/slitaz-toolchain/receipt ; echo $DEPENDS)"
|
pascal@6065
|
290 TOOLCHAIN="$TOOLCHAIN glibc linux" # break cook loop
|
pankso@3512
|
291 for pkg in $HG_WOK/*
|
pankso@3512
|
292 do
|
pankso@3512
|
293 EXTRAVERSION=""
|
pankso@3512
|
294 WANTED=""
|
pascal@6049
|
295 BUILD_DEPENDS=""
|
pascal@6048
|
296 [ -s $pkg/receipt ] || continue
|
pankso@3512
|
297 . $pkg/receipt
|
pankso@3512
|
298 [ "$2" = "--verbose" ] && echo "Package : $PACKAGE"
|
pankso@3512
|
299 # Skip blocked packages.
|
pankso@3512
|
300 if grep -qs "^$PACKAGE$" $DB_DIR/blocked; then
|
pankso@3512
|
301 echo "Blocked : $PACKAGE ($VERSION)" && continue
|
pankso@3512
|
302 fi
|
pankso@3512
|
303
|
pascal@4447
|
304 # Some packages may compute VERSION at cook time (bristuff)
|
pascal@4447
|
305 if grep -q ^get_version $pkg/receipt; then
|
pankso@3512
|
306 . $BUILD_WOK/$PACKAGE/taz/*/receipt
|
pankso@3512
|
307 fi
|
pankso@3512
|
308
|
pankso@3537
|
309 # First check if package exit. Package naming _must_ be in the form of:
|
pankso@3512
|
310 # $PACKAGE-$VERSION or $PACKAGE-${VERSION}$EXTRAVERSION (Kernel string).
|
pankso@3512
|
311 if [ ! -f $PACKAGES_REPOSITORY/$PACKAGE-$VERSION.tazpkg ]; then
|
pankso@3512
|
312 [ -z "$EXTRAVERSION" ] && EXTRAVERSION="_$KERNEL"
|
pankso@3512
|
313 if [ ! -f $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg ]; then
|
pankso@3512
|
314 [ "$1" = "report" ] && echo "Missing : $PACKAGE ($VERSION)"
|
pankso@3512
|
315 echo "Missing : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
316 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
317 fi
|
pankso@3512
|
318 else
|
pankso@3512
|
319 # Check if package is up-to-date.
|
pascal@5881
|
320 PKG_YEAR=`date -u -r $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}${EXTRAVERSION}.tazpkg '+%Y'`
|
pascal@5881
|
321 PKG_DATE=`date -u -r $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}${EXTRAVERSION}.tazpkg '+%m%d%H%M'`
|
pankso@3512
|
322 for file in `find $pkg -type f`
|
pankso@3512
|
323 do
|
pascal@5881
|
324 FILE_YEAR=`date -u -r $file '+%Y'`
|
pascal@5881
|
325 FILE_DATE=`date -u -r $file '+%m%d%H%M'`
|
pankso@3512
|
326 [ "$2" = "--verbose" ] && echo " -> Checking: $file"
|
pascal@5881
|
327 if [ "$FILE_YEAR" -ge "$PKG_YEAR" -a "$FILE_DATE" -gt "$PKG_DATE" ] && ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pankso@3512
|
328 [ "$1" = "report" ] && echo "Refresh : $PACKAGE ($VERSION)"
|
pankso@3512
|
329 echo "Refresh : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
330 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
331 fi
|
pankso@3512
|
332 done
|
pankso@3512
|
333 fi
|
pankso@3537
|
334 # Now check if package is built and not already in the list.
|
pankso@3512
|
335 if [ ! -d $BUILD_WOK/$PACKAGE/taz ] && ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pankso@3512
|
336 [ "$1" = "report" ] && echo "Unbuilt : $PACKAGE ($VERSION)"
|
pankso@3512
|
337 echo "Unbuilt : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
338 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
339 fi
|
pascal@6049
|
340 if ! grep -q $PACKAGE $DB_DIR/cooklist; then
|
pascal@6053
|
341 case " $TOOLCHAIN " in
|
pascal@6053
|
342 *\ $PACKAGE\ *) continue;;
|
pascal@6053
|
343 esac
|
pascal@6062
|
344 case "$PACKAGE" in
|
pascal@6062
|
345 tazbb|tazwok|tazpkg) continue;;
|
pascal@6062
|
346 esac
|
pascal@6051
|
347 for dep in $BUILD_DEPENDS $TOOLCHAIN ; do
|
pascal@6049
|
348 [ $BUILD_WOK/$PACKAGE/taz -nt $BUILD_WOK/$dep/taz ] && continue
|
pascal@6049
|
349 [ "$1" = "report" ] && echo "Refresh : $PACKAGE (older than $dep)"
|
pascal@6049
|
350 echo "Refresh : $PACKAGE (older than $dep)" >> $DB_DIR/report
|
pascal@6049
|
351 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pascal@6049
|
352 break
|
pascal@6049
|
353 done
|
pascal@6049
|
354 fi
|
pankso@3512
|
355 # Rebuild unbuilt packages list with link to log file. This list
|
pankso@3537
|
356 # is also generated by cook_inslall to have real time stats.
|
pankso@3512
|
357 if [ ! -d $BUILD_WOK/$PACKAGE/taz ]; then
|
pascal@5823
|
358 echo "<a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">$PACKAGE</a>" \
|
pankso@3512
|
359 >> $DB_DIR/unbuilt
|
pankso@3512
|
360 fi
|
pankso@3512
|
361 done
|
pankso@3512
|
362 packages_summary
|
pankso@3512
|
363 }
|
pankso@3512
|
364
|
pankso@3537
|
365 # Create a new cooklist and summary (dont modify report) so 'tazbb cook-commit'
|
pankso@3512
|
366 # can cook last changes.
|
pankso@3512
|
367 check_commit()
|
pankso@3512
|
368 {
|
pankso@3512
|
369 echo "(checking commit)" > $DB_DIR/running
|
pankso@3512
|
370 cd $HG_WOK
|
pankso@3512
|
371 # Clean up last results.
|
pankso@3512
|
372 rm -f $DB_DIR/cooklist && touch $DB_DIR/cooklist
|
pankso@3512
|
373 # Get the name of modified packages by the revision range. +1 last
|
pankso@3537
|
374 # commit was build by the previous build.
|
pankso@3512
|
375 LAST_REV=$(($LAST_REV+1))
|
pankso@3512
|
376 echo -e "Will cook from revision $LAST_REV to $NEW_REV\n"
|
pankso@3512
|
377 for file in `hg log --rev=$LAST_REV:$NEW_REV --template '{files}\n'`
|
pankso@3512
|
378 do
|
pankso@3512
|
379 pkg=`echo $file | cut -d "/" -f 1`
|
pankso@3512
|
380 if ! grep -q ^$pkg$ $DB_DIR/cooklist; then
|
pankso@3512
|
381 . $pkg/receipt
|
pankso@3512
|
382 echo "Commit : $PACKAGE ($VERSION)" >> $DB_DIR/report
|
pankso@3512
|
383 echo "$PACKAGE" >> $DB_DIR/cooklist
|
pankso@3512
|
384 fi
|
pankso@3512
|
385 done
|
pankso@3512
|
386 packages_summary
|
pankso@3512
|
387 }
|
pankso@3512
|
388
|
pascal@4174
|
389 # Cook one package
|
pascal@4174
|
390 cook_package()
|
pascal@4174
|
391 {
|
pascal@4174
|
392 EXTRAVERSION=""
|
pascal@4174
|
393 DEPENDS=""
|
pascal@4174
|
394 BUILD_DEPENDS=""
|
pascal@4174
|
395 SOURCE=""
|
pascal@4174
|
396 WANTED=""
|
pascal@5823
|
397 echo "(cooking <a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>)" > $DB_DIR/running
|
pascal@4174
|
398 tazwok clean $pkg
|
pascal@6111
|
399 script -c "tazbb check-receipt $pkg && echo 'install' | tazwok cook $pkg" $LOG_DIR/$pkg.log
|
pascal@4174
|
400 # Install new package (important for new shared libs). Note
|
pascal@4174
|
401 # that tests are done separatly with 'test_packages' and should
|
pascal@4174
|
402 # be done by tazwok.
|
pascal@4174
|
403 if [ -f $BUILD_WOK/$pkg/taz/*/receipt ]; then
|
pascal@5013
|
404 TAZBB_NO_INSTALL=""
|
pascal@4174
|
405 . $BUILD_WOK/$pkg/taz/*/receipt
|
pascal@5013
|
406 [ -n "$TAZBB_NO_INSTALL" ] && return 0
|
pascal@4174
|
407 echo "(installing $PACKAGE-${VERSION}$EXTRAVERSION.tazpkg)" \
|
pascal@4174
|
408 > $DB_DIR/running
|
pascal@4174
|
409 yes | tazpkg install \
|
pascal@4174
|
410 $PACKAGES_REPOSITORY/$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg \
|
pascal@4174
|
411 --forced
|
pascal@4174
|
412 return 0
|
pascal@4174
|
413 fi
|
pascal@4174
|
414 return 1
|
pascal@4174
|
415 }
|
pascal@4174
|
416
|
pascal@4174
|
417 # Sort list according WANTED and BUILD_DEPENDS
|
pascal@4174
|
418 sort_cook_list()
|
pascal@4174
|
419 {
|
pascal@4174
|
420 sort | while read pkg; do
|
pascal@4174
|
421 echo -n "$pkg"
|
pascal@4174
|
422 WANTED=""
|
pascal@4174
|
423 BUILD_DEPENDS=""
|
pascal@4174
|
424 . $BUILD_WOK/$pkg/receipt
|
pascal@4185
|
425 MISSING=""
|
pascal@4174
|
426 for i in $WANTED $BUILD_DEPENDS ; do
|
pascal@6091
|
427 # Verify that the dependancy exists and is older
|
pascal@6094
|
428 [ -f $BUILD_WOK/$i/taz/*/receipt ] &&
|
pascal@6094
|
429 [ $BUILD_WOK/$pkg/taz/*/receipt \
|
pascal@6094
|
430 -nt $BUILD_WOK/$i/taz/*/receipt ] && continue
|
pascal@6094
|
431 WANTED=""
|
pascal@6094
|
432 [ -f $BUILD_WOK/$i/receipt ] &&
|
pascal@6094
|
433 . $BUILD_WOK/$i/receipt
|
pascal@6094
|
434 # This dependancy may be cooked
|
pascal@6094
|
435 # by another package
|
pascal@6094
|
436 [ -n "$WANTED" ] && i=$WANTED
|
pascal@6091
|
437 case " $MISSING " in
|
pascal@6091
|
438 *\ $i\ *);;
|
pascal@6091
|
439 *) echo -n " $i";;
|
pascal@6091
|
440 esac
|
pascal@6091
|
441 MISSING="$MISSING $i"
|
pascal@4174
|
442 done
|
pascal@4174
|
443 echo ""
|
pascal@6100
|
444 done | awk '{ deps[$1] = $0; }
|
pascal@6100
|
445 END {
|
pascal@6100
|
446 while (1) {
|
pascal@6100
|
447 skipped = 0;
|
pascal@6100
|
448 done = 0;
|
pascal@6100
|
449 for (entry in deps) {
|
pascal@6100
|
450 for (i = split(deps[entry], pkg, " "); i > 1; i--)
|
pascal@6100
|
451 if (deps[pkg[i]] != "") break;
|
pascal@6100
|
452 if (i == 1) {
|
pascal@6100
|
453 print pkg[1];
|
pascal@6100
|
454 deps[pkg[1]] = "";
|
pascal@6100
|
455 done++;
|
pascal@6100
|
456 }
|
pascal@6100
|
457 else if (i > 1) skipped++;
|
pascal@6100
|
458 }
|
pascal@6100
|
459 if (skipped == 0) break;
|
pascal@6100
|
460 if (done == 0) { # cross deps !!
|
pascal@6100
|
461 for (entry in deps) {
|
pascal@6100
|
462 if (split(deps[entry], pkg, " ") > 1)
|
pascal@6100
|
463 print pkg[1];
|
pascal@6100
|
464 }
|
pascal@6100
|
465 break;
|
pascal@4174
|
466 }
|
pascal@4174
|
467 }
|
pascal@4185
|
468 }
|
pascal@4174
|
469 '
|
pascal@4174
|
470 }
|
pascal@4174
|
471
|
pankso@3512
|
472 # Here we cook all packages found in the cooklist.
|
pankso@3512
|
473 cook_install()
|
pankso@3512
|
474 {
|
pankso@3512
|
475 echo "" > $DB_DIR/unbuilt
|
pascal@4174
|
476 for pkg in `cat $DB_DIR/cooklist | sort_cook_list`
|
pankso@3512
|
477 do
|
pascal@4174
|
478 if ! cook_package $pkg; then
|
pankso@3512
|
479 # Link to build log.
|
pascal@5823
|
480 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pankso@3512
|
481 $DB_DIR/unbuilt
|
pankso@3512
|
482 fi
|
pascal@4996
|
483 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
484 if [ -n "$missing_depends" ]; then
|
pascal@4996
|
485 cat >> $LOG_DIR/$pkg.log <<EOT
|
pascal@4996
|
486
|
pascal@4996
|
487 Update $pkg receipt for DEPENDS :
|
pascal@4996
|
488 The package $pkg depends on packages $missing_depends
|
pascal@4996
|
489
|
pascal@4996
|
490 EOT
|
pascal@4996
|
491 # Unbuild package
|
pascal@4996
|
492 rm -rf $BUILD_WOK/$pkg/taz
|
pascal@4996
|
493 # Link to build log.
|
pascal@5823
|
494 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pascal@4996
|
495 $DB_DIR/unbuilt
|
pascal@4996
|
496 fi
|
pankso@3512
|
497 # Remove package from the cooklist and empty lines for HTML <pre>.
|
pankso@3512
|
498 sed -i /"^$pkg$"/d $DB_DIR/cooklist
|
pankso@3512
|
499 sed -i '/^$/d' $DB_DIR/cooklist
|
pankso@3537
|
500 packages_summary_update
|
pankso@3512
|
501 done
|
pankso@3512
|
502 }
|
pankso@3512
|
503
|
pascal@6111
|
504 # Check for misc variables
|
pascal@6111
|
505 check_variables()
|
pascal@6111
|
506 {
|
pascal@6111
|
507 PACKAGE=""
|
pascal@6111
|
508 VERSION=""
|
pascal@6111
|
509 EXTRAVERSION=""
|
pascal@6111
|
510 CATEGORY=""
|
pascal@6111
|
511 SHORT_DESC=""
|
pascal@6111
|
512 MAINTAINER=""
|
pascal@6111
|
513 WEB_SITE=""
|
pascal@6111
|
514 PACKED_SIZE=""
|
pascal@6111
|
515 UNPACKED_SIZE=""
|
pascal@6111
|
516 . $BUILD_WOK/$1/receipt
|
pascal@6111
|
517 if [ "$PACKAGE" != "$1" ]; then
|
pascal@6111
|
518 echo "The PACKAGE variable should be $1"
|
pascal@6111
|
519 return 1
|
pascal@6111
|
520 fi
|
pascal@6111
|
521 if [ -z "$VERSION" ]; then
|
pascal@6111
|
522 echo "No VERSION in $1"
|
pascal@6111
|
523 return 1
|
pascal@6111
|
524 fi
|
pascal@6111
|
525 if [ -z "$SHORT_DESC" ]; then
|
pascal@6111
|
526 echo "No SHORT_DESC in $1"
|
pascal@6111
|
527 return 1
|
pascal@6111
|
528 fi
|
pascal@6111
|
529 case "$MAINTAINER" in
|
pascal@6111
|
530 '') echo "No MAINTAINER in $1"
|
pascal@6111
|
531 return 1 ;;
|
pascal@6111
|
532 *\<*|*\>*)
|
pascal@6111
|
533 echo "Invalid MAINTAINER in $1"
|
pascal@6111
|
534 return 1 ;;
|
pascal@6111
|
535 *@*) ;;
|
pascal@6111
|
536 *) echo "No email address for MAINTAINER in $1"
|
pascal@6111
|
537 return 1 ;;
|
pascal@6111
|
538 esac
|
pascal@6111
|
539 if [ -z "$WEB_SITE" ]; then
|
pascal@6111
|
540 echo "No WEB_SITE in $1"
|
pascal@6111
|
541 return 1
|
pascal@6111
|
542 fi
|
pascal@6111
|
543 if [ -n "$EXTRAVERSION" ]; then
|
pascal@6111
|
544 echo "Hardcoded EXTRAVERSION in $1"
|
pascal@6111
|
545 return 1
|
pascal@6111
|
546 fi
|
pascal@6111
|
547 if [ -n "$PACKED_SIZE" ]; then
|
pascal@6111
|
548 echo "Hardcoded PACKED_SIZE in $1"
|
pascal@6111
|
549 return 1
|
pascal@6111
|
550 fi
|
pascal@6111
|
551 if [ -n "$UNPACKED_SIZE" ]; then
|
pascal@6111
|
552 echo "Hardcoded UNPACKED_SIZE in $1"
|
pascal@6111
|
553 return 1
|
pascal@6111
|
554 fi
|
pascal@6111
|
555 case " base-system x-window utilities network graphics multimedia \
|
pascal@6111
|
556 office development system-tools security games misc meta \
|
pascal@6111
|
557 non-free " in
|
pascal@6111
|
558 *\ $CATEGORY\ *);;
|
pascal@6111
|
559 *) echo "Invalid CATEGORY in $1 : $CATEGORY"
|
pascal@6111
|
560 return 1;
|
pascal@6111
|
561 esac
|
pascal@6111
|
562 return 0
|
pascal@6111
|
563 }
|
pascal@6111
|
564
|
pascal@6111
|
565 # Check for WANTED version
|
pascal@6111
|
566 check_wanted_version()
|
pascal@6111
|
567 {
|
pascal@6111
|
568 WANTED=""
|
pascal@6111
|
569 . $BUILD_WOK/$1/receipt
|
pascal@6123
|
570 if [ -n "$WANTED" ]; then
|
pascal@6111
|
571 expected=$VERSION
|
pascal@6111
|
572 VERSION=
|
pascal@6111
|
573 . $BUILD_WOK/$WANTED/receipt
|
pascal@6111
|
574 if [ "$VERSION" != "$expected" ]; then
|
pascal@6121
|
575 echo "$1: expected wanted version $expected, found $VERSION"
|
pascal@6111
|
576 return 1
|
pascal@6111
|
577 fi
|
pascal@6111
|
578 fi
|
pascal@6111
|
579 return 0
|
pascal@6111
|
580 }
|
pascal@6111
|
581
|
pascal@6111
|
582 # Check for loop in BUILD_DEPENDS/WANTED
|
pascal@6111
|
583 check_build_depends()
|
pascal@6111
|
584 {
|
pascal@6111
|
585 local i
|
pascal@6111
|
586 BUILD_DEPENDS=""
|
pascal@6111
|
587 WANTED=""
|
pascal@6111
|
588 . $BUILD_WOK/$1/receipt
|
pascal@6111
|
589 for i in $BUILD_DEPENDS $WANTED ; do
|
pascal@6111
|
590 case " $2 " in
|
pascal@6111
|
591 *\ $i\ *) echo "Loop in BUILD_DEPENDS/WANTED chain $2 $i"
|
pascal@6111
|
592 return 1 ;;
|
pascal@6111
|
593 *) check_build_depends $i "$2 $1" || return 1 ;;
|
pascal@6111
|
594 esac
|
pascal@6111
|
595 done
|
pascal@6111
|
596 return 0
|
pascal@6111
|
597 }
|
pascal@6111
|
598
|
pascal@4996
|
599 # Build depends_to_skip list with packages to remove from depends_to_add list
|
pascal@4996
|
600 # These packages are already present in depends_to_add trees
|
pascal@4996
|
601 scan_depends_to_skip()
|
pascal@4996
|
602 {
|
pascal@4996
|
603 local i
|
pascal@4996
|
604 case " $depends_to_skip " in
|
pascal@4996
|
605 *\ $1\ *) return;;
|
pascal@4996
|
606 esac
|
pascal@4996
|
607 [ -d $BUILD_WOK/$1 ] || return
|
pascal@4996
|
608 DEPENDS=""
|
pascal@4996
|
609 . $BUILD_WOK/$1/receipt
|
pascal@4996
|
610 for i in $DEPENDS ; do
|
pascal@4996
|
611 case " $depends_to_add " in
|
pascal@4996
|
612 *\ $i\ *) depends_to_skip="$depends_to_skip $i";;
|
pascal@4996
|
613 esac
|
pascal@4996
|
614 done
|
pascal@4996
|
615 for i in $DEPENDS ; do
|
pascal@4996
|
616 scan_depends_to_skip $i
|
pascal@4996
|
617 done
|
pascal@4996
|
618 }
|
pascal@4996
|
619
|
pascal@4996
|
620 # Reduce depends list by scanning nested depends
|
pascal@4996
|
621 show_missing_depends()
|
pascal@4996
|
622 {
|
pascal@4996
|
623 local i
|
pascal@4996
|
624 depends_to_add=""
|
pascal@4996
|
625 depends_to_skip="$2"
|
pascal@4996
|
626 for i in $1 ; do
|
pascal@4996
|
627 case " $depends_to_add " in
|
pascal@4996
|
628 *\ $i\ *) continue;;
|
pascal@4996
|
629 esac
|
pascal@4996
|
630 depends_to_add="$depends_to_add$i "
|
pascal@4996
|
631 done
|
pascal@4996
|
632 for i in $depends_to_add ; do
|
pascal@4996
|
633 scan_depends_to_skip $i
|
pascal@4996
|
634 done
|
pascal@4996
|
635 for i in $depends_to_add ; do
|
pascal@4996
|
636 case " $depends_to_skip " in
|
pascal@4996
|
637 *\ $i\ *) continue;;
|
pascal@4996
|
638 esac
|
pascal@4996
|
639 echo -n "$i "
|
pascal@4996
|
640 done
|
pascal@4996
|
641 }
|
pascal@4996
|
642
|
pascal@4996
|
643 # Build all_depends variable
|
pascal@4996
|
644 scan_dep()
|
pascal@4996
|
645 {
|
pascal@4996
|
646 local i
|
pascal@4996
|
647 all_depends="$all_depends$PACKAGE "
|
pascal@4996
|
648 for i in $DEPENDS $SUGGESTED ; do
|
pascal@4996
|
649 case " $all_depends " in
|
pascal@4996
|
650 *\ $i\ *) continue;;
|
pascal@4996
|
651 esac
|
pascal@4996
|
652 [ -d $BUILD_WOK/$i ] || {
|
pascal@4996
|
653 all_depends="$all_depends$i "
|
pascal@4996
|
654 continue
|
pascal@4996
|
655 }
|
pascal@4996
|
656 DEPENDS=""
|
pascal@4996
|
657 SUGGESTED=""
|
pascal@4996
|
658 . $BUILD_WOK/$i/receipt
|
pascal@4996
|
659 scan_dep
|
pascal@4996
|
660 done
|
pascal@4996
|
661 }
|
pascal@4996
|
662
|
pascal@4996
|
663 # Check for ELF file
|
pascal@4996
|
664 is_elf()
|
pascal@4996
|
665 {
|
pascal@4996
|
666 [ "$(dd if=$1 bs=1 skip=1 count=3 2> /dev/null)" = "ELF" ]
|
pascal@4996
|
667 }
|
pascal@4996
|
668
|
pascal@4996
|
669 # Print shared library dependencies
|
pascal@4996
|
670 ldd()
|
pascal@4996
|
671 {
|
pascal@4996
|
672 LD_PRELOAD="" LD_TRACE_LOADED_OBJECTS=1 /lib/ld*.so $1 2> /dev/null
|
pascal@4996
|
673 }
|
pascal@4996
|
674
|
pascal@4996
|
675 # scan a file for shared libraries and display according package names
|
pascal@4996
|
676 check_depends_file()
|
pascal@4996
|
677 {
|
pascal@4996
|
678 file=$1
|
pascal@4996
|
679 is_elf $file || continue
|
pascal@4996
|
680 case "$file" in
|
pascal@4996
|
681 *.o|*.ko|*.ko.gz) continue;;
|
pascal@4996
|
682 esac
|
pascal@4996
|
683 [ -s /tmp/files.list.tazbb$$ ] ||
|
pascal@4996
|
684 unlzma -c $PACKAGES_REPOSITORY/files.list.lzma >/tmp/files.list.tazbb$$
|
pascal@4996
|
685 ldd $file | while read lib rem; do
|
pascal@4996
|
686 case "$lib" in
|
pascal@4996
|
687 statically|linux-gate.so*|ld-*.so|*/ld-*.so)
|
pascal@4996
|
688 continue;;
|
pascal@4996
|
689 esac
|
pascal@4996
|
690 for dep in $(grep $lib /tmp/files.list.tazbb$$ | cut -d: -f1); do
|
pascal@4996
|
691 case " $all_depends " in
|
pascal@4996
|
692 *\ $dep\ *) continue 2;;
|
pascal@4996
|
693 esac
|
pascal@4996
|
694 for vdep in $(grep $dep $PACKAGES_REPOSITORY/packages.equiv | cut -d= -f1); do
|
pascal@4996
|
695 case " $all_depends " in
|
pascal@4996
|
696 *\ $vdep\ *) continue 3;;
|
pascal@4996
|
697 esac
|
pascal@4996
|
698 done
|
pascal@4996
|
699 done
|
pascal@4996
|
700 [ -n "$dep" ] || dep="UNKNOWN"
|
pascal@4996
|
701 all_depends="$all_depends $dep"
|
pascal@4996
|
702 if [ -n "$VERBOSE" ]; then
|
pascal@4996
|
703 echo "${file#*fs} depends on package $dep for the shared library $lib" 1>&2
|
pascal@4996
|
704 fi
|
pascal@4996
|
705 echo -n "$dep "
|
pascal@4996
|
706 done
|
pascal@4996
|
707 }
|
pascal@4996
|
708
|
pascal@4996
|
709 DEFAULT_DEPENDS="glibc-base"
|
pascal@4996
|
710
|
pascal@4996
|
711 # scan a package for shared libraries and display missing package in DEPENDS
|
pascal@4996
|
712 check_depends_pkg()
|
pascal@4996
|
713 {
|
pascal@4996
|
714 pkg=$1
|
pascal@4996
|
715 echo "(checking depends for $pkg)" > $DB_DIR/running
|
pascal@4996
|
716 tmp=/tmp/tazbb$$
|
pascal@4996
|
717 mkdir $tmp
|
pascal@4996
|
718 package=$(basename $pkg)
|
pascal@4996
|
719 if ! cd ${package%%-*}*/taz/${package%.tazpkg}/.. 2> /dev/null; then
|
pascal@4996
|
720 cd $tmp
|
pascal@4996
|
721 tazpkg extract $pkg > /dev/null 2>&1
|
pascal@4996
|
722 fi
|
pascal@4996
|
723 . */receipt
|
pascal@4996
|
724 all_depends="$DEFAULT_DEPENDS "
|
pascal@4996
|
725 scan_dep
|
pascal@4996
|
726 toadd=$(find */fs -type f | while read file ; do
|
pascal@4996
|
727 check_depends_file $file
|
pascal@4996
|
728 done)
|
pascal@4996
|
729 . */receipt
|
pascal@4996
|
730 rm -rf */
|
pascal@4996
|
731 cd - > /dev/null
|
pascal@4996
|
732 rm -rf $tmp
|
pascal@4996
|
733 show_missing_depends "$toadd" "$DEPENDS $SUGGESTED"
|
pascal@4996
|
734 }
|
pascal@4996
|
735
|
pascal@4996
|
736 check_depends_this_file()
|
pascal@4996
|
737 {
|
pascal@4996
|
738 file=$1
|
pascal@4996
|
739 all_depends="$DEFAULT_DEPENDS "
|
pascal@4996
|
740 scan_dep
|
pascal@4996
|
741 check_depends_file $file
|
pascal@4996
|
742 }
|
pascal@4996
|
743
|
pankso@3512
|
744 # Remove old packages in the build wok and clean pkgs repository. The
|
pankso@3512
|
745 # Hg wok is copied into the build wok so packages removed by hg must be
|
pankso@3512
|
746 # removed. To remove old packages in the repository we look into the
|
pankso@3537
|
747 # build wok and dont remove unbuilt packages. Clean-up will also remove
|
pankso@3512
|
748 # all corrupted packages.
|
pankso@3512
|
749 clean_up()
|
pankso@3512
|
750 {
|
pankso@3512
|
751 touch $DB_DIR/removed
|
pankso@3512
|
752 echo -e "\nCleaning the build wok, old and corrupted packages...\n"
|
pankso@3512
|
753 echo "(cleaning)" > $DB_DIR/running
|
pankso@4208
|
754 for pkg in `ls $BUILD_WOK`
|
pankso@3512
|
755 do
|
pankso@4208
|
756 if [ ! -d $HG_WOK/$pkg ]; then
|
pankso@3512
|
757 case $2 in
|
pankso@3512
|
758 --dry-run)
|
pankso@3512
|
759 echo "Removing directory : $pkg" ;;
|
pankso@3512
|
760 --verbose)
|
pankso@3512
|
761 echo "Removing directory : $pkg"
|
pankso@3512
|
762 rm -rf $BUILD_WOK/$pkg ;;
|
pankso@3512
|
763 *)
|
pankso@3512
|
764 rm -rf $BUILD_WOK/$pkg ;;
|
pankso@3512
|
765 esac
|
pankso@3512
|
766 fi
|
pankso@3512
|
767 done
|
pankso@3512
|
768 # Build a packages list with EXTRAVERSION so we can grep into it.
|
pankso@3512
|
769 rm -f $DB_DIR/packaged && touch $DB_DIR/packaged
|
pankso@3512
|
770 for receipt in $BUILD_WOK/*/taz/*/receipt
|
pankso@3512
|
771 do
|
pankso@3512
|
772 EXTRAVERSION=""
|
pankso@3512
|
773 . $receipt
|
pankso@3512
|
774 echo "$PACKAGE-${VERSION}$EXTRAVERSION.tazpkg" >> $DB_DIR/packaged
|
pankso@3512
|
775 done
|
pankso@3512
|
776 for pkg in `cd $PACKAGES_REPOSITORY && ls *.tazpkg`
|
pankso@3512
|
777 do
|
pankso@3512
|
778 if ! grep -q "^$pkg$" $DB_DIR/packaged; then
|
pankso@3512
|
779 case $2 in
|
pankso@3512
|
780 --dry-run)
|
pankso@3512
|
781 echo "Removing package : $pkg" ;;
|
pankso@3512
|
782 --verbose)
|
pankso@3512
|
783 echo "Removing package : $pkg"
|
pankso@3512
|
784 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
785 rm -f $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
786 *)
|
pankso@3512
|
787 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
788 rm -f $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
789 esac
|
pankso@3512
|
790 fi
|
pankso@3512
|
791 done
|
pankso@3512
|
792 # Remove all corrupted packages
|
pankso@3512
|
793 for pkg in `cat $DB_DIR/corrupted | awk '{ print $3 }'`
|
pankso@3512
|
794 do
|
pankso@3512
|
795 case $2 in
|
pankso@3512
|
796 --dry-run)
|
pankso@3512
|
797 echo "Removing corrupted: $pkg" ;;
|
pankso@3512
|
798 --verbose)
|
pankso@3512
|
799 echo "Removing corrupted: $pkg"
|
pankso@3512
|
800 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
801 rm -rf $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
802 *)
|
pankso@3512
|
803 echo "$pkg" >> $DB_DIR/removed
|
pankso@3512
|
804 rm -rf $PACKAGES_REPOSITORY/$pkg ;;
|
pankso@3512
|
805 esac
|
pankso@3512
|
806 done
|
pankso@3512
|
807 echo ""
|
pankso@3512
|
808 # Keep the 20 last removed packages list.
|
pankso@3512
|
809 cat $DB_DIR/removed | tail -n 20 > /tmp/removed.tail
|
pankso@3512
|
810 mv -f /tmp/removed.tail $DB_DIR/removed
|
pankso@5132
|
811 # Clean packages stuff/ directory
|
pankso@5132
|
812 echo -e "\nCleaning the build wok stuff/ directories...\n"
|
pankso@5132
|
813 for pkg in `ls $BUILD_WOK`
|
pankso@5132
|
814 do
|
pankso@5132
|
815 if [ -d "$BUILD_WOK/$pkg/stuff" ]; then
|
pankso@5132
|
816 cd $BUILD_WOK/$pkg
|
pankso@5132
|
817 for file in `find stuff -type f`
|
pankso@5132
|
818 do
|
pankso@5132
|
819 if [ ! -f "$HG_WOK/$pkg/$file" ]; then
|
pankso@5132
|
820 echo "Removing: $pkg/$file"
|
pankso@5132
|
821 rm $file
|
pankso@5132
|
822 fi
|
pankso@5132
|
823 done
|
pankso@5132
|
824 fi
|
pankso@5132
|
825 done
|
pankso@3512
|
826 }
|
pankso@3512
|
827
|
pankso@3512
|
828 blocked_urls()
|
pankso@3512
|
829 {
|
pankso@3512
|
830 rm -f $DB_DIR/blocked.urls
|
pankso@3512
|
831 for pkg in `cat $DB_DIR/blocked`
|
pankso@3512
|
832 do
|
pankso@3512
|
833 if [ -f $LOG_DIR/$pkg.log ]; then
|
pascal@5823
|
834 echo "<a href=\"log.php?package=$(escape $pkg)$LOG_SUFFIX\">$pkg</a>" >> \
|
pankso@3512
|
835 $DB_DIR/blocked.urls
|
pankso@3512
|
836 else
|
pankso@3512
|
837 echo "$pkg" >> $DB_DIR/blocked.urls
|
pankso@3512
|
838 fi
|
pankso@3512
|
839 done
|
pankso@3512
|
840 }
|
pankso@3512
|
841
|
pankso@3512
|
842 # 4k, not a meta or a get-* package and no files = buggy package
|
pankso@3512
|
843 test_packages()
|
pankso@3512
|
844 {
|
pankso@3512
|
845 echo -e "\nTesting all packages in: $PACKAGES_REPOSITORY"
|
pankso@3512
|
846 echo "================================================================================"
|
pankso@3512
|
847 echo "(testing packages)" > $DB_DIR/running
|
pankso@3512
|
848 rm -f $DB_DIR/corrupted && touch $DB_DIR/corrupted
|
pankso@3512
|
849 for pkg in $PACKAGES_REPOSITORY/*.tazpkg
|
pankso@3512
|
850 do
|
pankso@3512
|
851 tmp=/tmp/bb-test.$$
|
pankso@3512
|
852 CATEGORY=""
|
pankso@3512
|
853 if du $pkg | grep -qw '^4' && ! echo `basename $pkg` | grep -q '^get-'; then
|
pankso@3512
|
854 mkdir -p $tmp && cd $tmp
|
pascal@4700
|
855 cpio -i receipt >/dev/null 2>&1 < $pkg
|
pankso@3512
|
856 . ./receipt
|
pankso@3512
|
857 if [ "$CATEGORY" != "meta" ]; then
|
pankso@3512
|
858 [ "$2" = "--verbose" ] && echo "Testing: $PACKAGE"
|
pascal@5882
|
859 cpio -i fs.cpio.gz >/dev/null 2>&1 < $pkg
|
pascal@5882
|
860 cpio -i fs.cpio.lzma >/dev/null 2>&1 < $pkg
|
pascal@4850
|
861 if [ ! -f fs.cpio.gz -a ! -f fs.cpio.lzma ]; then
|
pankso@3516
|
862 echo "Missing filesystem `basename $pkg`"
|
pankso@3512
|
863 if [ -f $LOG_DIR/$PACKAGE.log ];then
|
pascal@5823
|
864 echo "Missing filesystem `basename $pkg` <a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">Log</a>" \
|
pankso@3512
|
865 >> $DB_DIR/corrupted
|
pankso@3512
|
866 else
|
pankso@3516
|
867 echo "Missing filesystem `basename $pkg`" \
|
pankso@3512
|
868 >> $DB_DIR/corrupted
|
pankso@3512
|
869 fi
|
pankso@3512
|
870 else
|
pascal@4850
|
871 ( zcat fs.cpio.gz 2> /dev/null || \
|
pascal@4850
|
872 unlzma -c fs.cpio.lzma ) | \
|
pascal@4850
|
873 cpio -id >/dev/null 2>&1
|
pascal@4395
|
874 files=`find fs -type f -o -type l`
|
pankso@3512
|
875 if [ -z "$files" ]; then
|
pankso@3516
|
876 echo "Empty filesystem `basename $pkg`"
|
pankso@3512
|
877 if [ -f $LOG_DIR/$PACKAGE.log ]; then
|
pascal@5823
|
878 echo "Empty filesystem `basename $pkg` <a href=\"log.php?package=$(escape $PACKAGE)$LOG_SUFFIX\">Log</a>" \
|
pankso@3512
|
879 >> $DB_DIR/corrupted
|
pankso@3512
|
880 else
|
pankso@3516
|
881 echo "Empty filesystem `basename $pkg`" \
|
pankso@3512
|
882 >> $DB_DIR/corrupted
|
pankso@3512
|
883 fi
|
pankso@3512
|
884 fi
|
pankso@3512
|
885 fi
|
pankso@3512
|
886 fi
|
pankso@3512
|
887 cd .. && rm -rf $tmp
|
pankso@3512
|
888 fi
|
pankso@3512
|
889 done
|
pankso@3512
|
890 packages_summary_update
|
pankso@3512
|
891 echo ""
|
pankso@3512
|
892 }
|
pankso@3512
|
893
|
pascal@4447
|
894 # Generate flavor list
|
pascal@4447
|
895 gen_flavor_list()
|
pascal@4447
|
896 {
|
pascal@4447
|
897 cd $PACKAGES_REPOSITORY
|
pascal@4447
|
898 noheader=""
|
pascal@4447
|
899 for i in *.flavor; do
|
pascal@4447
|
900 tazlito show-flavor $i --brief $noheader
|
pascal@4447
|
901 noheader="--noheader"
|
pascal@4447
|
902 done > flavors.list
|
pascal@4447
|
903 cd - > /dev/null
|
pascal@4447
|
904 }
|
pascal@4447
|
905
|
pankso@3512
|
906 case "$1" in
|
pankso@3512
|
907 list-pkgs)
|
pankso@3512
|
908 # List last cooked packages.
|
pankso@3512
|
909 list_packages ;;
|
pankso@3512
|
910 report)
|
pankso@3512
|
911 # Run in report mode. If an update is done we must cook-all to
|
pankso@3512
|
912 # rebuild all updated packages.
|
pankso@3512
|
913 [ "$2" == "--update" ] && update_wok $@ || echo ""
|
pankso@3512
|
914 check_wok $@
|
pascal@4447
|
915 check_flavors $@
|
pankso@3512
|
916 test_packages $@
|
pankso@3512
|
917 show_report ;;
|
pankso@4110
|
918 cook)
|
pankso@4110
|
919 # Cook, install and log a single package build.
|
pankso@4110
|
920 if [ -z $2 ]; then
|
pankso@4110
|
921 echo "Please specify a package on the command line."
|
pankso@4110
|
922 rm -f $LOCK_FILE && exit 0
|
pankso@4110
|
923 fi
|
pankso@4110
|
924 pkg=$2
|
pankso@4110
|
925 echo "Starting to cook and install: $pkg"
|
pascal@4174
|
926 if ! cook_package $pkg; then
|
pankso@4110
|
927 echo "Unable to install: $pkg"
|
pankso@4110
|
928 fi ;;
|
pankso@3512
|
929 cook-all)
|
pankso@3512
|
930 # Update wok, gen report (with cooklist), cook all packages, test,
|
pankso@3512
|
931 # clean, gen new report and lists.
|
pankso@3512
|
932 update_wok $@
|
pankso@3512
|
933 check_wok $@
|
pankso@3512
|
934 cook_install
|
pankso@3512
|
935 test_packages $@
|
pascal@5034
|
936 check_flavors $@
|
pascal@5034
|
937 pack_flavors
|
pankso@3512
|
938 clean_up $@
|
pankso@3512
|
939 check_wok $@
|
pankso@3512
|
940 echo "(generating lists)" > $DB_DIR/running
|
pankso@3512
|
941 tazwok gen-list --text
|
pascal@4447
|
942 check_flavors $@
|
pascal@4447
|
943 gen_flavor_list
|
pankso@3512
|
944 echo "" ;;
|
pankso@3512
|
945 cook-commit)
|
pankso@3512
|
946 # Cook all packages affected by the last commits in the wok.
|
pankso@3529
|
947 # Clean up is done only by cook-all to avoid rebuild of corrupted
|
pankso@3529
|
948 # packages on each commit.
|
pankso@3512
|
949 update_wok $@
|
pankso@3512
|
950 check_commit
|
pankso@3512
|
951 cook_install
|
pankso@3512
|
952 test_packages $@
|
pascal@5034
|
953 check_flavors $@
|
pascal@5034
|
954 pack_flavors
|
pankso@3512
|
955 check_wok $@
|
pascal@5034
|
956 check_flavors $@
|
pankso@3512
|
957 echo "(generating lists)" > $DB_DIR/running
|
pankso@3512
|
958 tazwok gen-list --text
|
pascal@4447
|
959 gen_flavor_list
|
pankso@3512
|
960 echo "" ;;
|
pankso@3512
|
961 block)
|
pankso@3512
|
962 # Add a pkg name to the list of blocked packages.
|
pankso@3512
|
963 echo ""
|
pankso@3512
|
964 if grep -qs "^$2$" $DB_DIR/blocked; then
|
pankso@3512
|
965 echo -e "$2 is already in the blocked packages list."
|
pankso@3512
|
966 else
|
pankso@3512
|
967 echo -n "Adding $2 to : $DB_DIR/blocked... "
|
pankso@3512
|
968 echo "$2" >> $DB_DIR/blocked && echo "Done"
|
pankso@3512
|
969 if grep -q "^$2$" $DB_DIR/cooklist; then
|
pankso@3512
|
970 echo -n "Removing $2 from : $DB_DIR/cooklist... "
|
pankso@3512
|
971 sed -i /"^$2$"/d $DB_DIR/cooklist && echo "Done"
|
pankso@3512
|
972 packages_summary_update
|
pankso@3512
|
973 fi
|
pankso@3512
|
974 fi
|
pankso@3512
|
975 blocked_urls
|
pankso@3512
|
976 echo "" ;;
|
pankso@3512
|
977 unblock)
|
pankso@3512
|
978 # Remove a pkg name from the list of blocked packages.
|
pankso@3512
|
979 echo ""
|
pankso@3512
|
980 if grep -qs "^$2$" $DB_DIR/blocked; then
|
pankso@3512
|
981 echo -n "Removing $2 from : $DB_DIR/blocked... "
|
pankso@3512
|
982 sed -i /"^$2$"/d $DB_DIR/blocked
|
pankso@3512
|
983 sed -i '/^$/d' $DB_DIR/blocked && echo "Done"
|
pankso@3512
|
984 echo -n "Adding $2 to : $DB_DIR/cooklist... "
|
pankso@3512
|
985 echo "$2" >> $DB_DIR/cooklist && echo "Done"
|
pankso@3512
|
986 packages_summary_update
|
pankso@3512
|
987 else
|
pankso@3512
|
988 echo -e "$2 is not in the blocked packages list."
|
pankso@3512
|
989 fi
|
pankso@3512
|
990 blocked_urls
|
pankso@3512
|
991 echo "" ;;
|
pankso@3512
|
992 test-pkgs)
|
pankso@3537
|
993 # Start a test suite on all builded packages.
|
pankso@3512
|
994 test_packages $@ ;;
|
pankso@3512
|
995 test-suite)
|
pankso@3537
|
996 # Start a test suite on all builded package and the wok using
|
pankso@3512
|
997 # the great 'tazwok check'.
|
pankso@3512
|
998 #
|
pankso@3512
|
999 # test_packages > $LOG_DIR/test-suite.log
|
pankso@3512
|
1000 # tazwok check >> $LOG_DIR/test-suite.log
|
pankso@3512
|
1001 #
|
pankso@3512
|
1002 test_packages $@
|
pankso@3512
|
1003 script -c "tazwok check" $LOG_DIR/test-suite.log ;;
|
pankso@3590
|
1004 mail)
|
pankso@3590
|
1005 # Tazbbmail Pythom script wrapper.
|
pankso@3590
|
1006 PACKAGE=$2
|
pankso@3590
|
1007 tazbbmail $PACKAGE ;;
|
pankso@3512
|
1008 clean-up)
|
pankso@3512
|
1009 # Remove old packages and generate new packages lists.
|
pankso@3512
|
1010 update_wok $@
|
pankso@3512
|
1011 clean_up $@
|
pankso@3512
|
1012 packages_summary_update
|
pankso@3512
|
1013 [ "$2" != "--dry-run" ] && tazwok gen-list --text ;;
|
pankso@3512
|
1014 clean-log)
|
pankso@3512
|
1015 logs=`ls $LOG_DIR | wc -l`
|
pankso@3512
|
1016 echo -n "Cleaning: $LOG_DIR... "
|
pankso@3512
|
1017 rm -rf $LOG_DIR/*
|
pankso@3512
|
1018 echo "$logs log removed" ;;
|
pascal@6111
|
1019 check-receipt)
|
pascal@6111
|
1020 check_variables $2 &&
|
pascal@6111
|
1021 check_wanted_version $2 &&
|
pascal@6111
|
1022 check_build_depends $2 ""
|
pascal@6122
|
1023 return $? ;;
|
pascal@4996
|
1024 check-depends)
|
pascal@4996
|
1025 case "$2" in
|
pascal@4996
|
1026 wok)
|
pascal@4996
|
1027 for pkg in $PACKAGES_REPOSITORY/*.tazpkg ; do
|
pascal@4996
|
1028 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
1029 [ -n "$missing_depends" ] &&
|
pascal@4996
|
1030 echo "The package $pkg depends on $missing_depends."
|
pascal@4996
|
1031 done ;;
|
pascal@4996
|
1032 package)
|
pascal@4996
|
1033 pkg=$3
|
pascal@4996
|
1034 VERBOSE=$4
|
pascal@4996
|
1035 missing_depends="$(check_depends_pkg $pkg)"
|
pascal@4996
|
1036 [ -n "$missing_depends" ] &&
|
pascal@4996
|
1037 echo "The package $pkg depends on $missing_depends."
|
pascal@4996
|
1038 ;;
|
pascal@4996
|
1039 file)
|
pascal@4996
|
1040 file=3
|
pascal@4996
|
1041 VERBOSE=$4
|
pascal@4996
|
1042 missing_depends="$(check_depends_this_file $file)"
|
pascal@4996
|
1043 [ -n "$missing_depends" ] &&
|
pascal@4996
|
1044 echo "The file $file depends on $missing_depends."
|
pascal@4996
|
1045 ;;
|
pascal@4996
|
1046 *) cat <<EOT
|
pascal@4996
|
1047 check-depends wok check every package in wok.
|
pascal@4996
|
1048 check-depends package <pkg> check one package.
|
pascal@4996
|
1049 check-depends file <filename> check one file only.
|
pascal@4996
|
1050 EOT
|
pascal@4996
|
1051 ;;
|
pascal@4996
|
1052 esac ;;
|
pankso@3512
|
1053 *)
|
pankso@3512
|
1054 usage ;;
|
pankso@3512
|
1055 esac
|
pankso@3512
|
1056
|
pankso@3512
|
1057 echo "" > $DB_DIR/running
|
pascal@4996
|
1058 rm -f $LOCK_FILE /tmp/files.list.tazbb$$
|
pankso@3512
|
1059
|
pascal@6122
|
1060 exit 0
|