]> git.pld-linux.org Git - projects/cleanbuild.git/blame - cleanbuild
add --network option
[projects/cleanbuild.git] / cleanbuild
CommitLineData
82208ca0 1#!/usr/bin/sudo /bin/sh
2
82208ca0 3RPMS_FROM="$HOME/rpm/cleanRPMS.repo"
4DEST="th"
11aa2a39 5SRC="-n th-x86_64-test"
82208ca0 6SUFFIX=""
7CACHEDIR="$PWD/poldekcache"
08b388ad 8RPMMACROS=""
9BUILDERRC=""
febc90ba 10IGNORE=""
5cff6047 11CHROOTSIZE="4G"
3cb48d43 12ignore() { IGNORE="$IGNORE $*"; }
311d51c7 13NODEBUG=true
5e0e7403 14CLEANAFTER=false
15FORCE_UMOUNT=false
c8aae0a1 16NOREBUILDDB=true
738a0524 17MULTILIB=false
646fa345
ER
18# Whatever you set here as value, consider that it may not be shorter than
19# /usr/lib/debug (or /usr/src/debug) for debuginfo to work.
20# You get "Only dest dir longer than base dir not supported" error otherwise.
21BUILDDIR=/usr/src/BUILD
82208ca0 22
cca1186a 23[ -r .cleanbuildrc ] && . ./.cleanbuildrc
24
25[ -z "$USER" ] && echo "USER not defined" && exit 1
e02fff67 26[ "$USER" = "root" ] && echo "USER must not be root" && exit 1
82208ca0 27
28export LC_ALL=C
29unset LANGUAGE
30unset LANG
31
32usage() {
33 [ $# -gt 0 ] && echo "$*"
34 echo "Usage:"
35 echo " ./cleanbuild [cleanbuild options] specname [builder options]"
36 echo " ./build [cleanbuild options] specname [builder options]"
37 echo " ./clean [cleanbuild options]"
febc90ba 38 echo " ./create [cleanbuild options]"
82208ca0 39 echo " ./install [cleanbuild options] packages"
40 echo ""
41 echo "cleanbuild options:"
42 echo " -32, -64, -th-i486 - select architecture"
91d5d67b 43 echo " --cleanafter | -ca - clean after build"
5e0e7403 44 echo " --forceumount | -fu - force umount tmpfs"
91d5d67b 45 echo " --debug - enable debug"
a958d6ce 46 echo " --network - allow build to use networking"
3cc55bb0 47 echo " -a, -b, -c, -d, -e - select alternative chroot directory"
82208ca0 48 exit 1
49}
50
51FETCH=false
52CLEAN=false
febc90ba 53CREATE=false
82208ca0 54BUILD=false
a958d6ce 55NETWORK=false
82208ca0 56INSTALL=false
82208ca0 57
58case "$0" in
febc90ba 59 *clean)
60 CLEAN=exit_after
61 ;;
82208ca0 62 *cleanbuild)
63 FETCH=true
64 CLEAN=true
febc90ba 65 CREATE=true
82208ca0 66 BUILD=true
67 ;;
82208ca0 68 *build)
febc90ba 69 CREATE=true
82208ca0 70 BUILD=true
71 ;;
febc90ba 72 *create)
82208ca0 73 CLEAN=true
febc90ba 74 CREATE=exit_after
82208ca0 75 ;;
76 *install)
febc90ba 77 CREATE=true
78 INSTALL=exit_after
82208ca0 79 ;;
80 *)
81 usage
82 ;;
83esac
84
85while [ $# -gt 0 ]; do
86 OPT="${1}"
87 case "$OPT" in
88 -32) OPT="-th-i686" ;;
89 -64) OPT="-th-x86_64" ;;
90 -th-32) OPT="-th-i686" ;;
91 -th-64) OPT="-th-x86_64" ;;
560aa27b 92 -ti-32) OPT="-ti-i686" ;;
93 -ti-64) OPT="-ti-x86_64" ;;
82208ca0 94 -ac) OPT="-ac-amd64" ;;
95 -ac-32) OPT="-ac-i586" ;;
96 -ac-64) OPT="-ac-amd64" ;;
97 esac
98
99 V="${OPT#-}"
100 case "$OPT" in
101 -th-i[46]86 | -th-x86_64)
102 DEST="$V"
11aa2a39 103 SRC="-n $V-ready"
82208ca0 104 ;;
560aa27b 105 -th-i[46]86-test | -th-x86_64-test)
106 DEST="$V"
107 SRC="-n $V"
108 ;;
109 -ti-i[56]86 | -ti-x86_64)
110 DEST="$V"
111 SRC="-n $V-ready"
112 ;;
113 -ti-i[56]86-test | -ti-x86_64-test)
114 DEST="$V"
115 SRC="-n $V"
116 ;;
82208ca0 117 -ac-amd64 | -ac-i[356]86 | -ac-athlon)
118 DEST="$V"
11aa2a39 119 SRC="-n $V-ready"
82208ca0 120 ;;
5cff6047 121 -[1-9]G | -[1-9][0-9]G )
122 CHROOTSIZE="$V"
123 ;;
febc90ba 124 --cleanafter | -ca)
82208ca0 125 CLEANAFTER=true
126 ;;
311d51c7 127 --debug)
128 NODEBUG=false
129 ;;
a958d6ce
ER
130 --network)
131 NETWORK=true
132 ;;
5e0e7403 133 --forceumount | -fu)
134 FORCE_UMOUNT=true
c6fcd6a8 135 ;;
3cc55bb0 136 -[a-e])
82208ca0 137 SUFFIX="$OPT"
138 ;;
139 -~*)
140 SUFFIX="$V"
141 ;;
142 *)
143 break
144 ;;
145 esac
146 shift
147done
148
149if $BUILD; then
150 [ $# -ne 0 ] || usage
151 build_pkg="${1}"
6361ea4c 152 build_pkg="${build_pkg%/}"
153 build_pkg="${build_pkg%.spec}"
154 build_pkg="${build_pkg#*/}"
82208ca0 155 shift
156
157 builder_options="$*"
158fi
159
311d51c7 160$NODEBUG || set -x
161
febc90ba 162CHNAME="chroot-$DEST$SUFFIX"
163CHDIR="$PWD/$CHNAME"
164CHHOME="/home/users/$USER"
165
166warn()
167{
82208ca0 168 echo -n -e "\033[31;1m" >&2
169 echo -n "$*" >&2
170 echo -e "\033[0m" >&2
171}
febc90ba 172
173die()
174{
82208ca0 175 code=$1
176 shift
177 warn "$*"
178 exit $code
179}
febc90ba 180
181info()
182{
82208ca0 183 echo -n -e "\033[32m"
184 echo -n "$*"
185 echo -e "\033[0m"
186}
febc90ba 187
188title()
189{
82208ca0 190 [ -t 1 ] || return 0
191 local msg="$CHNAME: $build_pkg: $*"
192 case "$TERM" in
193 cygwin|xterm*)
194 echo -ne "\033]1;$msg\007\033]2;$msg\007" >&2
195 ;;
196 screen*)
197 echo -ne "\033]0;$msg\007" >&2
198 ;;
199 esac
200 return 0
201}
202
febc90ba 203exit_after()
204{
205 return 0;
206}
82208ca0 207
febc90ba 208check_running()
209{
82208ca0 210 [ -r "$CHDIR/.pid" ] || return
211 PID=$(< "$CHDIR/.pid")
212 if [ -d /proc/$PID ]; then
213 die 10 "Another process ($PID) already running in $CHNAME"
214 fi
215}
216
82208ca0 217for D in installed buildlogs $CACHEDIR; do
218 if [ ! -d "$D" ]; then
febc90ba 219 info "mkdir $D"
82208ca0 220 su $USER -c "mkdir -p $D" || die 13 "Cannot create work directories"
221 fi
222done
223
82208ca0 224ignore \
82208ca0 225 upstart\* \
18ef31a8 226 upstart \
aa0c3fdf
ER
227 compat-\* \
228 systemd-init \
18ef31a8
ER
229 hhvm \
230 vserver-packages \
82208ca0 231 xorg-driver-video-fglrx\* xorg-driver-video-nvidia\* xorg-xserver-xgl-libGL \
18ef31a8 232 xorg-driver-video-vboxvideo \
82208ca0 233 xorg-data-xbitmaps \
234 compat-gcc\* \
235 libpng1\* \
b66f1de3 236 libjpeg libjpeg-devel \
932132fc 237 freetype1-devel-* \
82208ca0 238 anacron fcron hc-cron \
239 masqmail msmtp-sendmail omta postfix sendmail ssmtp nail-mail nullmailer \
240 ghostscript-esp \
b66f1de3 241 perl-Scalar-List-Utils \
a395dfc5 242 perl-ExtUtils-Install \
87f3e718 243 phonon-backend-mplayer phonon-backend-vlc \
dafe58a6 244 icedtea6-jre icedtea6-jdk \
23ed9a43 245 java-sun-jre java5-sun-jre oracle-java7-jre \
87f3e718 246 gnome-menus \
3cb48d43 247 gnome-speech-driver-festival gnome-speech-driver-speech-dispatcher
82208ca0 248
738a0524
ER
249if ! $MULTILIB; then
250 ignore '*-multilib-*'
251fi
252
febc90ba 253rebuilddb()
254{
c8aae0a1 255 $NOREBUILDDB || rpm --root=$CHDIR --rebuilddb
82208ca0 256}
257
febc90ba 258poldek()
259{
311d51c7 260 $NODEBUG || set -x
82208ca0 261 rebuilddb
11aa2a39 262 /usr/bin/poldek $SRC -s "$RPMS_FROM" -r "$CHDIR" "--cachedir=$CACHEDIR" --conf=$PWD/poldekconf/poldek.conf "$@"
82208ca0 263}
264
265
febc90ba 266build_umount()
267{
82208ca0 268 for DIR in $CHHOME/rpm $CHHOME dev proc sys; do
269 [ -d $CHDIR/$DIR ] && umount $CHDIR/$DIR
270 done
271}
272
febc90ba 273build_remove_root()
274{
714fcf38 275 $NODEBUG || set -x
5e0e7403 276 if $FORCE_UMOUNT; then
c6fcd6a8 277 # safety checks.
278 [ "$CHDIR" ] || exit 1
279 [ -d "$CHDIR" ] || exit 1
280 rm -rf $CHDIR/*
281 umount -l $CHDIR
282 else
283 umount $CHDIR
284 fi
82208ca0 285 rmdir $CHDIR
286}
287
febc90ba 288clean()
289{
82208ca0 290 info "Cleaning $CHNAME"
7bf0c1e6 291 title "cleaning chroot"
82208ca0 292 build_umount
293 build_remove_root
82208ca0 294}
295
febc90ba 296build_prepare_root()
297{
7bf0c1e6 298 title "preparing chroot"
82208ca0 299 set -e
311d51c7 300 $NODEBUG || set -x
82208ca0 301 mkdir $CHDIR
5cff6047 302 mount -t tmpfs -o size=$CHROOTSIZE,relatime /dev/null $CHDIR
82208ca0 303 echo $$ > $CHDIR/.pid
304
ef4e7e6c
ER
305 rpmversion=$(rpm -E '%(v=%{_rpmversion}; IFS=.; set -- $v; echo $1)')
306 rpmversion=${rpmversion:-4}
307
308 if [ "$rpmversion" -ge 5 ]; then
309 rpm --root=$CHDIR -qa
310 else
311 rpm --root=$CHDIR --initdb
312 fi
82208ca0 313 poldek --up || :
bcc829a4 314 poldek -O "ignore=$IGNORE" -u rpm-build pwdutils coreutils time util-linux git-core gawk
abb791ce 315 echo Poldek exit: $?
82208ca0 316
317 for DIR in dev proc sys; do
49e71696 318 # We need to create these directories manually, because they are marked
319 # as netsharedpath in cleanbuild poldek.conf
320 mkdir $CHDIR/$DIR
82208ca0 321 mount -o bind /$DIR $CHDIR/$DIR
322 done
323
13fa0606
ER
324 # group 'users' may already exist, so ignore errors
325 chroot $CHDIR groupadd $(id $USER -gn) -g$(id $USER -g) || :
750858a5 326 chroot $CHDIR useradd -m $USER -u$(id $USER -u) -g $(id $USER -gn)
b259c625 327
328 # replicate files which already belong to $USER
329 # so they will have correct owner and permissions
82208ca0 330 cp -a $CHDIR/$CHHOME/{tmp,rpm}
646fa345 331 cp -a $CHDIR/$CHHOME/tmp $CHDIR$BUILDDIR
b259c625 332
82208ca0 333 cp -a $CHDIR/$CHHOME/{.bashrc,.rpmmacros}
646fa345
ER
334 cat <<-EOM > $CHDIR/$CHHOME/.rpmmacros
335 %_builddir $BUILDDIR
82208ca0 336 %buildroot %{_builddir}/%{name}-%{version}-root-%(id -u -n)
11aa2a39 337 %_rpmdirname cleanRPMS
338 %_rpmdir %{expand:%%global _rpmdir %([ -d %{_topdir}/../%{_rpmdirname} ] && (cd %{_topdir}/../%{_rpmdirname}; pwd) || echo %{_topdir}/%{_rpmdirname})}%_rpmdir
82208ca0 339 %distribution CleanPLD
340 %_binary_payload w1.gzdio
341EOM
08b388ad 342 [ -z "$RPMMACROS" ] || echo "$RPMMACROS" >> $CHDIR/$CHHOME/.rpmmacros
b259c625 343
344 cp -a $CHDIR/$CHHOME/{.bashrc,.builderrc}
82208ca0 345 cat <<-'EORC' > $CHDIR/$CHHOME/.builderrc
346 TITLECHANGE=no
347EORC
08b388ad 348 [ -z "$BUILDERRC" ] || echo "$BUILDERRC" >> $CHDIR/$CHHOME/.builderrc
349
82208ca0 350 set +e
351}
352
febc90ba 353build_mount_home()
354{
311d51c7 355 $NODEBUG || set -x
82208ca0 356 mount -o bind $HOME/rpm $CHDIR/$CHHOME/rpm
357}
358
82208ca0 359
febc90ba 360print_installed()
361{
82208ca0 362 echo=$1
363 if [ -r installed/$build_pkg ]; then
364 $echo "$(cat installed/$build_pkg | awk '{print $1}' | sort -u \
365 | awk '{br=br ", " $1} END{gsub(/^, /, "- BR: ", br ); print br}')"
366 cat installed/$build_pkg
367 fi
368}
369
febc90ba 370addlist()
371{
82208ca0 372 LIST="$1"
373
374 print_installed info
11aa2a39 375
376 return
82208ca0 377 echo "*** $build_pkg $(date --rfc-3339=seconds) ***" >> $LIST
378 print_installed echo >> $LIST
379}
380
febc90ba 381builddie()
382{
82208ca0 383 LIST="$1"; shift
384 CODE="$1"; shift
385 MSG="$*"
386
febc90ba 387 rm -f $CHDIR/.pid
388
82208ca0 389 $CLEANAFTER && clean
390 title "failed !"
391
392 addlist "ERROR_$LIST"
393 die $CODE "$MSG"
394}
395
396LAST_INSTALL=""
febc90ba 397poldek_install()
398{
18ef31a8 399 local I="$1" ret
82208ca0 400 # Nothing to install
401 [ -n "$I" ] || return 1
402 # Installing same packets second time
403 [ "$LAST_INSTALL" != "$I" ] || return 1
404 LAST_INSTALL="$I"
405
406 info "Installing" $I
407 poldek -O "ignore=$IGNORE" -u $I | tee $$.poldek_install
408 ret=
409 if grep -q "Preparing... ##################################################" $$.poldek_install \
410 && ! grep -q "file .* from install of .* conflicts with file from package" $$.poldek_install
411 then
412 info "Poldek:" $I "installed"
413 ret=0
414 elif grep -q "Nothing to do" $$.poldek_install; then
415 warn "Poldek:" $I "installed already"
416 ret=1
417 fi
418 rm $$.poldek_install
419 [ -n "$ret" ] && return $ret
420
421 # try harder
18ef31a8 422 info "Poldek install failed, retry without ignore"
82208ca0 423 poldek -u $I && return 0
18ef31a8 424 info "Poldek install failed, retry once more without ignore"
82208ca0 425 poldek -u $I && return 0
426 warn "Poldek:" "Could not install" $I
427 return 1
428}
429
febc90ba 430maybe_call()
431{
432 local cond="$1"; shift
433 local func="$1"; shift
434
e02fff67 435 [ $cond = "false" ] && return
a958d6ce 436 "$func" "$@"
e02fff67 437 [ $cond = "exit_after" ] && exit
febc90ba 438}
439
440fetch()
441{
442 info "Fetching $build_pkg"
443 title "fetch"
311d51c7 444 $NODEBUG || set -x
febc90ba 445 su $USER -c "$HOME/rpm/packages/builder -g $build_pkg $builder_options" \
446 || die 11 "Fetch failed"
447}
448
449create()
450{
311d51c7 451 $NODEBUG || set -x
febc90ba 452 su $USER -c "poldek -s $RPMS_FROM --mkidx"
453
454 if [ ! -d $CHDIR ]; then
455 info "Preparing $CHNAME"
456 build_prepare_root
457 build_mount_home
458 fi
459}
460
461
abb791ce
ER
462info "Configured Poldek sources"
463poldek -l
464
febc90ba 465maybe_call $FETCH fetch
466
467check_running
468
469maybe_call $CLEAN clean
470
471maybe_call $CREATE create
472
473echo $$ > $CHDIR/.pid
474
475maybe_call $INSTALL poldek_install "$*"
476
a958d6ce
ER
477maybe_call $NETWORK cp -bf /etc/resolv.conf $CHDIR/etc/
478
febc90ba 479$BUILD || exit
480
481if [ -p /tmp/fixfreq ]; then
482 echo $$ > /tmp/fixfreq
82208ca0 483fi
484
485while true; do
486 info "Building $build_pkg in $CHNAME"
487 rebuilddb
71469ba3 488 find $CHDIR/usr/lib{,64} -name "*.la" -print0 | \
1595b5d5 489 xargs -0 -r sed -i -e "s@dependency_libs=.*@dependency_libs=' '@"
82208ca0 490 buildlog="buildlogs/$build_pkg"
491 if [ -r $buildlog ]; then
492 i=1
493 while [ -r $buildlog.$i ]; do
494 i=$((i+1))
495 done
496 info "moving $buildlog to $buildlog.$i"
497 mv $buildlog $buildlog.$i
498 fi
11aa2a39 499 ./findunusedbr -c $CHDIR $HOME/rpm/packages/$build_pkg/$build_pkg.spec
82208ca0 500 title "building"
98efb019 501 ./teeboth $buildlog chroot $CHDIR su $USER -c "$CHHOME/rpm/packages/builder -nn --define '_enable_debug_packages 0' -bb $build_pkg $builder_options"
7bb76476 502 ECODE=$?
82208ca0 503
504 if grep -q "error: Failed build dependencies:" $buildlog; then
505 SEARCH=$(cat $buildlog | awk '/^Error:/ { p = 0 }; { if ( p ) { f="p"; if ( $1 ~ /^\// ) f="f"; printf "search -%c %s; ", f, $1; } }; /error: Failed build dependencies:/ { p = 1 }')
506 INSTALL=$(poldek -O "ignore=$IGNORE" --shcmd="$SEARCH" | awk '{ if ( p ) { print; p = 0; } } / package\(s\) found:$/ { p = 1 }' | sed 's/^\(.*\)-.*-.*$/\1/' | sort -u)
507
508 if poldek_install "$INSTALL"; then
509 info "Deps installed"
510 continue
511 else
512 addlist ERROR_BRINSTALL
513 die 4 "Cannot install BRs"
514 fi
515 fi
516
f34b364a 517 ./findbr $CHDIR/$BUILDDIR $buildlog > $$.installed
82208ca0 518 installed_something=false
519 while read pkg msg; do
520 if poldek_install $pkg; then
521 info "findbr:" $pkg "installed"
522 echo "$pkg $msg" >> installed/$build_pkg
523 ./addbr $build_pkg "$pkg" "$msg"
524 installed_something=true
525 else
526 warn "findbr:" $pkg "not installed"
527 fi
528 done < $$.installed
529 rm -f $$.installed
530 $installed_something && continue
531
532 if [ $ECODE -eq 0 ]; then
533 $CLEANAFTER && clean
534 addlist BUILT_OK
11aa2a39 535 ./findunusedbr $CHDIR $HOME/rpm/packages/$build_pkg/$build_pkg.spec
82208ca0 536 info "$build_pkg built OK !"
537 title "OK !"
538 exit 0
539 else
540 builddie UNKNOWN 1 "Got error but dunno what to do !"
541 fi
542done
543
544
545# vim: ts=4 sw=4 filetype=sh
This page took 0.279144 seconds and 4 git commands to generate.