cookutils annotate cook @ rev 1134

cook: copy-paste typo
author Aleksej Bobylev <al.bobylev@gmail.com>
date Fri Jan 18 11:07:18 2019 +0200 (2019-01-18)
parents b6def327b90a
children 3c6c68093522
rev   line source
pankso@1 1 #!/bin/sh
pankso@1 2 #
pankso@1 3 # Cook - A tool to cook and generate SliTaz packages. Read the README
paul@647 4 # before adding or modifying any code in cook!
pankso@1 5 #
al@899 6 # Copyright (C) SliTaz GNU/Linux - GNU GPL v3
pankso@1 7 # Author: Christophe Lincoln <pankso@slitaz.org>
pankso@1 8 #
al@728 9
pankso@422 10 . /usr/lib/slitaz/libcook.sh
pankso@1 11
pankso@633 12 VERSION="3.2"
al@779 13 export output=raw
al@1051 14 prev_ts="/home/slitaz/cache/prev_ts"; touch $prev_ts
al@596 15
al@728 16
al@596 17 # Internationalization.
al@596 18
al@728 19 export TEXTDOMAIN='cook'
al@596 20
al@596 21
pankso@1 22 #
pankso@1 23 # Functions
pankso@1 24 #
pankso@1 25
pankso@1 26 usage() {
al@728 27 cat <<EOT
pankso@1 28
al@728 29 $(boldify "$(_ 'Usage:')") $(_ 'cook [package|command] [list|--option]')
pankso@1 30
al@728 31 $(boldify "$(_ 'Commands:')")
al@728 32 usage|help $(_ 'Display this short usage.')
al@728 33 setup $(_ 'Setup your build environment.')
al@728 34 *-setup $(_ 'Setup a cross environment.')
al@728 35 * = {arm|armv6hf|armv7|x86_64}
al@728 36 test $(_ 'Test environment and cook a package.')
al@728 37 list-wok $(_ 'List packages in the wok.')
al@728 38 search $(_ 'Simple packages search function.')
al@728 39 new $(_ 'Create a new package with a receipt.')
al@728 40 list $(_ 'Cook a list of packages.')
al@728 41 clean-wok $(_ 'Clean-up all packages files.')
al@728 42 clean-src $(_ 'Clean-up all packages sources.')
al@728 43 uncook $(_ 'Check for uncooked packages')
al@728 44 pkgdb $(_ 'Create packages DB lists and flavors.')
pankso@1 45
al@728 46 $(boldify "$(_ 'Options:')")
al@728 47 cook <pkg>
al@728 48 --clean -c $(_ 'clean the package in the wok.')
al@728 49 --getsrc -gs $(_ 'get the package source tarball.')
al@728 50 --block -b $(_ 'block a package so cook will skip it.')
al@728 51 --unblock -ub $(_ 'unblock a blocked package.')
al@728 52 --cdeps $(_ 'check dependencies of cooked package.')
al@728 53 --pack $(_ 'repack an already built package.')
al@728 54 --debug $(_ 'display debugging messages.')
al@728 55 --continue $(_ 'continue running compile_rules.')
al@728 56 cook new <pkg>
al@728 57 --interactive -x $(_ 'create a receipt interactively.')
al@728 58 cook setup
al@728 59 --wok $(_ 'clone the cooking wok from Hg repo.')
al@728 60 --stable $(_ 'clone the stable wok from Hg repo.')
al@728 61 --undigest $(_ 'clone the undigest wok from Hg repo.')
al@728 62 --tiny $(_ 'clone the tiny SliTaz wok from Hg repo.')
al@728 63 --forced $(_ 'force reinstall of chroot packages.')
al@728 64 cook pkgdb
al@728 65 --flavors $(_ 'create up-to-date flavors files.')
al@932 66 cook splitdb $(_ 'create up-to-date split.db file.')
pankso@1 67
pankso@1 68 EOT
pankso@1 69 exit 0
pankso@1 70 }
pankso@1 71
al@728 72
paul@62 73 # We don't want these escapes in web interface.
al@728 74
pankso@1 75 clean_log() {
al@931 76 sed -i -e 's|\[70G\[ \[1;32m| |' \
al@931 77 -e 's|\[0;39m \]||' $LOGS/${1:-$pkg}.log
pankso@1 78 }
pankso@1 79
al@728 80
paul@62 81 # Be sure package exists in wok.
al@728 82
pankso@1 83 check_pkg_in_wok() {
al@890 84 [ -d "$WOK/$pkg" ] || die 'Unable to find package "%s" in the wok' "$pkg"
pankso@1 85 }
pankso@1 86
al@728 87
al@1079 88 # Find the package, return the receipt name where it was found
al@1079 89 # for example, libpcreposix -> pcre
al@1079 90
al@1079 91 find_pkg_in_wok() {
al@1115 92 awk -F$'\t' -vi=" $1 " '{
al@1079 93 if (index(" " $2 " ", i)) {print $1; exit}
al@1079 94 }' $cache/split.db
al@1079 95 }
al@1079 96
al@1079 97
paul@62 98 # Initialize files used in $CACHE
al@728 99
pankso@52 100 init_db_files() {
al@728 101 _ 'Creating directories structure in "%s"' "$SLITAZ"
xfred222@559 102 mkdir -p $WOK $PKGS $SRC $CACHE $LOGS $FEEDS
al@728 103 _ 'Creating DB files in "%s"' "$CACHE"
al@933 104 touch $activity $command $broken $blocked $CACHE/webstat
al@933 105 chown www:www $cache/webstat
pankso@52 106 }
pankso@52 107
al@728 108
paul@62 109 # Paths used in receipt and by cook itself.
al@728 110
pankso@1 111 set_paths() {
al@1003 112 # Kernel version is set from wok/linux or installed/linux-api-headers(wok-undigest)
al@1003 113 if [ -f "$WOK/linux/receipt" ]; then
al@1003 114 kvers=$(. $WOK/linux/receipt; echo $VERSION)
al@1003 115 kbasevers=$(echo $kvers | cut -d. -f1,2)
al@1003 116 elif [ -f "$INSTALLED/linux-api-headers/receipt" ]; then
al@1003 117 kvers=$(. $INSTALLED/linux-api-headers/receipt; echo $VERSION)
al@1003 118 kbasevers=$(echo $kvers | cut -d. -f1,2)
al@1003 119 fi
al@1003 120
al@1003 121 # Python version
al@1003 122 [ -f "$WOK/python/receipt" ] && pyvers=$(. $WOK/python/receipt; echo $VERSION)
al@1003 123 # Perl version for some packages needed it
al@1003 124 [ -f "$WOK/perl/receipt" ] && perlvers=$(. $WOK/perl/receipt; echo $VERSION)
al@1003 125
al@904 126 pkgdir="$WOK/$pkg"
al@841 127 . "$pkgdir/receipt"
al@728 128 basesrc="$pkgdir/source"
al@728 129 tmpsrc="$basesrc/tmp"
al@728 130 src="$basesrc/$PACKAGE-$VERSION"
al@728 131 taz="$pkgdir/taz"
al@904 132 pack="$taz/${1:-$PACKAGE}-$VERSION$EXTRAVERSION" # v2: multiple taz/* folders
al@728 133 fs="$pack/fs"
al@728 134 stuff="$pkgdir/stuff"
al@728 135 install="$pkgdir/install"
al@904 136
slaxemulator@492 137 pkgsrc="${SOURCE:-$PACKAGE}-${KBASEVER:-$VERSION}"
slaxemulator@492 138 lzma_tarball="$pkgsrc.tar.lzma"
al@904 139
al@904 140 [ -n "$PATCH" -a -z "$PTARBALL" ] && PTARBALL="$(basename $PATCH)"
al@904 141
al@728 142 if [ -n "$WANTED" ]; then
al@728 143 basesrc="$WOK/$WANTED/source"
al@728 144 src="$basesrc/$WANTED-$VERSION"
al@728 145 install="$WOK/$WANTED/install"
al@728 146 wanted_stuff="$WOK/$WANTED/stuff"
pankso@1 147 fi
al@904 148
al@904 149 [ -n "$SOURCE" ] && source_stuff="$WOK/$SOURCE/stuff"
al@904 150
pankso@9 151 # Old way compatibility.
al@728 152 _pkg="$install"
pankso@1 153 }
pankso@1 154
al@728 155
pankso@144 156 # Create source tarball when URL is a SCM.
al@728 157
pankso@144 158 create_tarball() {
slaxemulator@498 159 local tarball
al@728 160 tarball="$pkgsrc.tar.bz2"
al@728 161 [ -n "$LZMA_SRC" ] && tarball="$lzma_tarball"
al@728 162 _ 'Creating tarball "%s"' "$tarball"
al@728 163 if [ -n "$LZMA_SRC" ]; then
slaxemulator@498 164 tar -c $pkgsrc | lzma e $SRC/$tarball -si $LZMA_SET_DIR || exit 1
al@728 165 LZMA_SRC=''
pankso@162 166 else
al@728 167 tar -cjf $tarball $pkgsrc || exit 1
al@728 168 mv $tarball $SRC; rm -rf $pkgsrc
pankso@162 169 fi
al@728 170 TARBALL="$tarball"
pankso@144 171 }
pankso@144 172
al@728 173
pankso@145 174 # Get package source. For SCM we are in cache so clone here and create a
pankso@145 175 # tarball here.
al@728 176
pankso@1 177 get_source() {
pascal@610 178 local url
al@890 179 url=${WGET_URL#*|}
ernia@571 180 set_paths
pankso@115 181 pwd=$(pwd)
pankso@9 182 case "$WGET_URL" in
al@890 183 http://*|ftp://*|https://*)
al@890 184 url="$MIRROR_URL/sources/packages/${TARBALL:0:1}/$TARBALL"
al@890 185 wget -T 60 -c -O $SRC/$TARBALL $WGET_URL ||
al@890 186 wget -T 60 -c -O $SRC/$TARBALL $url ||
al@890 187 die 'ERROR: %s' "wget $WGET_URL"
al@890 188 ;;
al@728 189
pankso@9 190 hg*|mercurial*)
al@728 191 _ 'Getting source from %s...' 'Hg'
al@728 192 _ 'URL: %s' "$url"
al@728 193 _ 'Cloning to "%s"' "$pwd/$pkgsrc"
al@728 194 if [ -n "$BRANCH" ]; then
al@728 195 _ 'Hg branch: %s' "$BRANCH"
al@890 196 hg clone $url --rev $BRANCH $pkgsrc ||
al@890 197 die 'ERROR: %s' "hg clone $url --rev $BRANCH"
pankso@246 198 else
al@890 199 hg clone $url $pkgsrc || die 'ERROR: %s' "hg clone $url"
pankso@246 200 fi
pankso@255 201 rm -rf $pkgsrc/.hg
al@890 202 create_tarball
al@890 203 ;;
al@728 204
pankso@9 205 git*)
al@728 206 _ 'Getting source from %s...' 'Git'
al@728 207 _ 'URL: %s' "$url"
al@688 208 cd $SRC
al@890 209 git clone $url $pkgsrc || die 'ERROR: %s' "git clone $url"
al@728 210 if [ -n "$BRANCH" ]; then
al@728 211 _ 'Git branch: %s' "$BRANCH"
al@728 212 cd $pkgsrc; git checkout $BRANCH; cd ..
pankso@63 213 fi
al@688 214 cd $SRC
al@890 215 create_tarball
al@890 216 ;;
al@728 217
pankso@144 218 cvs*)
pankso@144 219 mod=$PACKAGE
al@728 220 [ -n "$CVS_MODULE" ] && mod=$CVS_MODULE
al@728 221 _ 'Getting source from %s...' 'CVS'
al@728 222 _ 'URL: %s' "$url"
al@728 223 [ -n "$CVS_MODULE" ] && _ 'CVS module: %s' "$mod"
al@728 224 _ 'Cloning to "%s"' "$pwd/$mod"
pankso@144 225 cvs -d:$url co $mod && mv $mod $pkgsrc
al@890 226 create_tarball
al@890 227 ;;
al@728 228
pankso@69 229 svn*|subversion*)
al@728 230 _ 'Getting source from %s...' 'SVN'
al@728 231 _ 'URL: %s' "$url"
al@728 232 if [ -n "$BRANCH" ]; then
pankso@161 233 echo t | svn co $url -r $BRANCH $pkgsrc
pankso@161 234 else
pankso@161 235 echo t | svn co $url $pkgsrc
pankso@161 236 fi
al@890 237 create_tarball
al@890 238 ;;
al@728 239
al@590 240 bzr*)
al@728 241 _ 'Getting source from %s...' 'bazaar'
al@590 242 cd $SRC
al@590 243 pkgsrc=${url#*:}
al@728 244 if [ -n "$BRANCH" ]; then
al@590 245 echo "bzr -Ossl.cert_reqs=none branch $url -r $BRANCH"
al@590 246 bzr -Ossl.cert_reqs=none branch $url -r $BRANCH
al@590 247 else
al@590 248 echo "bzr -Ossl.cert_reqs=none branch $url"
al@590 249 bzr -Ossl.cert_reqs=none branch $url
al@728 250 cd $pkgsrc; BRANCH=$(bzr revno); cd ..
al@596 251 _ "Don't forget to add to receipt:"
al@728 252 echo -e "BRANCH=\"$BRANCH\"\n"
al@590 253 fi
al@590 254 mv $pkgsrc $pkgsrc-$BRANCH
al@728 255 pkgsrc="$pkgsrc-$BRANCH"
al@899 256 create_tarball
al@899 257 ;;
al@728 258
pankso@9 259 *)
al@899 260 broken; die 'ERROR: Unable to handle "%s"' "$WGET_URL"
al@899 261 ;;
pankso@9 262 esac
pankso@1 263 }
pankso@1 264
al@728 265
pankso@9 266 # Extract source package.
al@728 267
pankso@1 268 extract_source() {
pankso@177 269 if [ ! -s "$SRC/$TARBALL" ]; then
pankso@177 270 local url
slaxemulator@458 271 url="$MIRROR_URL/sources/packages"
al@728 272 url="$url/${TARBALL:0:1}/$TARBALL"
al@728 273 _ 'Getting source from %s...' 'mirror'
al@728 274 _ 'URL: %s' "$url"
al@728 275 busybox wget -c -P $SRC $url || _ 'ERROR: %s' "wget $url"
pankso@177 276 fi
al@728 277 _ 'Extracting source archive "%s"' "$TARBALL"
pankso@1 278 case "$TARBALL" in
al@728 279 *.tar.gz|*.tgz) tar -xzf $SRC/$TARBALL 2>/dev/null ;;
al@728 280 *.tar.bz2|*.tbz|*.tbz2) tar -xjf $SRC/$TARBALL 2>/dev/null ;;
al@728 281 *.tar.lzma) tar -xaf $SRC/$TARBALL ;;
al@728 282 *.tar.lz|*.tlz) lzip -d < $SRC/$TARBALL | tar -xf - 2>/dev/null ;;
al@728 283 *.tar) tar -xf $SRC/$TARBALL ;;
al@912 284 *.zip|*.xpi) unzip -o $SRC/$TARBALL 2>/dev/null >&2;;
al@728 285 *.xz) unxz -c $SRC/$TARBALL | tar -xf - || \
al@728 286 tar -xf $SRC/$TARBALL 2>/dev/null;;
psychomaniak@827 287 *.7z) 7zr x $SRC/$TARBALL 2>/dev/null >&2 ;;
al@728 288 *.Z|*.z) uncompress -c $SRC/$TARBALL | tar -xf - ;;
al@728 289 *.rpm) rpm2cpio $SRC/$TARBALL | cpio -idm --quiet ;;
al@728 290 *.run) /bin/sh $SRC/$TARBALL $RUN_OPTS ;;
al@728 291 *) cp $SRC/$TARBALL $(pwd) ;;
pankso@1 292 esac
pankso@1 293 }
pankso@1 294
al@728 295
al@834 296 # Display time.
al@834 297
al@1090 298 disp_time_old() {
al@834 299 local sec div min
al@834 300 sec="$1"
al@834 301 div=$(( ($1 + 30) / 60))
al@834 302 case $div in
al@834 303 0) min='';;
al@834 304 # L10n: 'm' is for minutes (approximate cooking time)
al@834 305 *) min=$(_n ' ~ %dm' "$div");;
al@834 306 esac
al@834 307
al@834 308 # L10n: 's' is for seconds (cooking time)
al@834 309 _ '%ds%s' "$sec" "$min"
al@834 310 }
al@834 311
al@834 312
al@1090 313 # Display time.
al@1090 314
al@1090 315 disp_time() {
al@1090 316 local sec="$1" day hour min out=''
al@1090 317
al@1090 318 day=$(( sec / 86400 )); sec=$(( sec % 86400 ))
al@1090 319 hour=$(( sec / 3600 )); sec=$(( sec % 3600 ))
al@1090 320 min=$(( sec / 60 )); sec=$(( sec % 60 ))
al@1090 321
al@1090 322 [ $day -gt 0 ] && out="${day}d "
al@1090 323 [ -n "$out" -o $hour -gt 0 ] && out="$out$(printf '%02dh ' $hour)"
al@1090 324 [ -n "$out" -o $min -gt 0 ] && out="$out$(printf '%02dm ' $min)"
al@1090 325 [ -n "$out" ] && out=" ~ $out$(printf '%02ds' $sec)"
al@1090 326
al@1090 327 echo "${1}s$out"
al@1090 328 }
al@1090 329
al@1090 330
pankso@9 331 # Display cooked package summary.
al@728 332
pankso@1 333 summary() {
al@1090 334 # local arch=''
al@1090 335 # case "$ARCH" in
al@1090 336 # arm*|x86_64) arch="-$ARCH" ;;
al@1090 337 # esac
al@1024 338
al@841 339 set_paths
pankso@1 340 cd $WOK/$pkg
slaxemulator@499 341 [ -d $WOK/$pkg/install ] && prod=$(du -sh $WOK/$pkg/install | awk '{print $1}' 2>/dev/null)
slaxemulator@499 342 [ -d $WOK/$pkg/source ] && srcdir=$(du -sh $WOK/$pkg/source | awk '{print $1}' 2>/dev/null)
al@728 343 [ -n "$TARBALL" ] && srcsize=$(du -sh $SRC/$TARBALL | awk '{print $1}')
al@728 344
al@1090 345 title 'Summary for: %s' "$PACKAGE $VERSION$EXTRAVERSION"
al@728 346
al@596 347 # L10n: keep the same width of translations to get a consistent view
al@728 348 [ -n "$TARBALL" ] && _ 'Src file : %s' "$TARBALL"
al@728 349 [ -n "$srcsize" ] && _ 'Src size : %s' "$srcsize"
al@904 350 [ -n "$srcdir" ] && _ 'Source dir : %s' "$srcdir"
al@728 351 [ -n "$prod" ] && _ 'Produced : %s' "$prod"
al@834 352 _ 'Cook time : %s' "$(disp_time "$time")"
al@728 353 _ 'Cook date : %s' "$(date "$(_ '+%%F %%R')")"
al@1090 354 _ 'Target arch : %s' "$(cut -d$'\t' -f2 $pkgdir/.arch | sort -u | tr '\n' ' ' | sed 's| $||; s| |, |g')"
al@904 355
al@904 356 separator -
al@912 357 _ ' # : Packed : Compressed : Files : Package name'
al@904 358 separator -
al@904 359 pkgi=1
al@916 360 for i in $(all_names); do
al@1057 361 version=$(awk -F$'\t' -vpkg="$i" '{
al@1057 362 if ($1 == pkg) {print $2; exit}
al@1090 363 }' "$PKGS/packages-$ARCH.info")
al@1116 364 [ -n "$version" ] || continue
al@1003 365 fs=$(du -sh $WOK/$pkg/taz/$i-$VERSION$EXTRAVERSION | awk '{print $1}')
al@1090 366 arch=$(awk -F$'\t' -vi="$i" '{if ($1 == i) print $2}' $pkgdir/.arch)
al@1090 367 pkgname="$i-$version-$arch.tazpkg"
al@904 368 size=$(ls -lh $PKGS/$pkgname | awk '{print $5}')
al@1003 369 files=$(wc -l < $WOK/$pkg/taz/$i-$VERSION$EXTRAVERSION/files.list)
al@912 370 printf "%2d : %7s : %10s : %5s : %s\n" "$pkgi" "$fs" "$size" "$files" "$pkgname"
al@904 371 pkgi=$((pkgi + 1))
al@904 372 done
al@596 373 separator
pankso@1 374 }
pankso@1 375
al@728 376
paul@62 377 # Display debugging error info.
al@728 378
pankso@15 379 debug_info() {
al@1090 380 title 'Debug information %s.' "$1"
al@596 381 # L10n: specify your format of date and time (to help: man date)
al@596 382 # L10n: not bad one is '+%x %R'
al@728 383 _ 'Cook date: %s' "$(date "$(_ '+%%F %%R')")"
al@890 384 if [ -n "$time" ]; then
al@890 385 times="$(($(date +%s) - $time))"
al@904 386 _ 'Wasted time : %s' "$(disp_time "$times")"
al@890 387 fi
pankso@76 388 for error in \
al@890 389 ERROR 'No package' "cp: can't" "can't open" "can't cd" \
al@728 390 'error:' 'fatal error:' 'undefined reference to' \
al@728 391 'Unable to connect to' 'link: cannot find the library' \
pascal@797 392 'CMake Error' ': No such file or directory' \
paul@798 393 'Could not read symbols: File in wrong format'
pankso@34 394 do
al@890 395 # format "line number:line content"
al@890 396 fgrep -n "$error" $LOGS/$pkg.log
pascal@625 397 done > $LOGS/$pkg.log.debug_info 2>&1
al@890 398 # sort by line number, remove duplicates
al@890 399 sort -gk1,1 -t: -u $LOGS/$pkg.log.debug_info
pascal@625 400 rm -f $LOGS/$pkg.log.debug_info
al@779 401 footer
pankso@15 402 }
pankso@15 403
al@728 404
al@887 405 # A bit smarter function than the classic `cp` command
al@887 406
al@899 407 scopy() {
al@899 408 if [ "$(stat -c %h -- "$1")" -eq 1 ]; then
al@899 409 cp -a "$1" "$2" # copy generic files
al@894 410 else
al@887 411 cp -al "$1" "$2" # copy hardlinks
al@887 412 fi
al@887 413 }
al@887 414
al@887 415
al@912 416 # Copy all generic files (locale, pixmaps, .desktop) from $install to $fs.
al@912 417 # We use standard paths, so some packages need to copy these files with the
al@912 418 # receipt and genpkg_rules.
al@912 419 # This function executes inside the packaging process, before compressor call.
al@728 420
al@728 421 copy_generic_files() {
al@912 422 # Proceed only for "main" package (for v2), and for any packages (v1)
al@912 423 [ "$pkg" == "$PACKAGE" ] || return 0
al@912 424
pankso@1 425 # $LOCALE is set in cook.conf
al@728 426 if [ -n "$LOCALE" -a -z "$WANTED" ]; then
pankso@260 427 if [ -d "$install/usr/share/locale" ]; then
al@912 428 mkdir -p "$fs/usr/share/locale"
al@728 429 for i in $LOCALE; do
al@899 430 if [ -d "$install/usr/share/locale/$i" ]; then
al@973 431 cp -r $install/usr/share/locale/$i $fs/usr/share/locale
pankso@1 432 fi
pankso@1 433 done
pankso@1 434 fi
pankso@1 435 fi
pankso@1 436
al@834 437 # Generic pixmaps copy can be disabled with COOKOPTS="!pixmaps" (or GENERIC_PIXMAPS="no")
al@834 438 if [ "${COOKOPTS/!pixmaps/}" == "$COOKOPTS" -a "$GENERIC_PIXMAPS" != 'no' ]; then
pankso@260 439 if [ -d "$install/usr/share/pixmaps" ]; then
al@912 440 mkdir -p "$fs/usr/share/pixmaps"
al@890 441 for i in png xpm; do
al@913 442 [ -f "$install/usr/share/pixmaps/$PACKAGE.$i" -a ! -f "$fs/usr/share/pixmaps/$PACKAGE.$i" ] &&
al@973 443 cp -r $install/usr/share/pixmaps/$PACKAGE.$i $fs/usr/share/pixmaps
al@890 444 done
pankso@1 445 fi
pankso@1 446 fi
pankso@1 447
pankso@1 448 # Desktop entry (.desktop).
al@834 449 # Generic desktop entry copy can be disabled with COOKOPTS="!menus" (or GENERIC_MENUS="no")
al@834 450 if [ "${COOKOPTS/!menus/}" == "$COOKOPTS" -a "$GENERIC_MENUS" != 'no' ]; then
al@912 451 if [ -d "$install/usr/share/applications" -a -z "$WANTED" ]; then
al@912 452 mkdir -p "$fs/usr/share"
al@973 453 cp -r $install/usr/share/applications $fs/usr/share
erjo@284 454 fi
pankso@1 455 fi
al@912 456 }
al@912 457
al@912 458
al@912 459 # Copy pixmaps, desktop files and licenses from $stuff to $install.
al@912 460 # This function executes after the main compile_rules() is done.
al@912 461
al@912 462 copy_generic_stuff() {
al@912 463 # Custom or homemade PNG pixmap can be in stuff.
al@912 464 if [ -f "$stuff/$PACKAGE.png" ]; then
al@912 465 mkdir -p $install/usr/share/pixmaps
al@912 466 cp $stuff/$PACKAGE.png $install/usr/share/pixmaps
al@912 467 fi
pankso@1 468
pankso@1 469 # Homemade desktop file(s) can be in stuff.
pankso@1 470 if [ -d "$stuff/applications" ]; then
al@912 471 mkdir -p $install/usr/share
al@973 472 cp -r $stuff/applications $install/usr/share
pankso@1 473 fi
pankso@1 474 if [ -f "$stuff/$PACKAGE.desktop" ]; then
al@912 475 mkdir -p $install/usr/share/applications
al@912 476 cp $stuff/$PACKAGE.desktop $install/usr/share/applications
pankso@1 477 fi
pankso@662 478
slaxemulator@500 479 # Add custom licenses
slaxemulator@500 480 if [ -d "$stuff/licenses" ]; then
al@912 481 mkdir -p $install/usr/share/licenses
al@973 482 cp -r $stuff/licenses $install/usr/share/licenses/$PACKAGE
slaxemulator@500 483 fi
pankso@1 484 }
pankso@1 485
al@728 486
al@769 487 # Update installed.cook.diff
al@769 488
al@769 489 update_installed_cook_diff() {
al@769 490 # If a cook failed deps are removed.
al@769 491 cd $root$INSTALLED; ls -1 > $CACHE/installed.cook
al@769 492 cd $CACHE
al@769 493 [ "$1" == 'force' -o ! -s '/tmp/installed.cook.diff' ] && \
al@769 494 busybox diff installed.list installed.cook > /tmp/installed.cook.diff
al@931 495 deps=$(grep ^+[a-zA-Z0-9] /tmp/installed.cook.diff | wc -l)
al@769 496 }
al@769 497
al@769 498
pankso@8 499 # Remove installed deps.
al@728 500
pankso@8 501 remove_deps() {
pankso@8 502 # Now remove installed build deps.
al@728 503 diff='/tmp/installed.cook.diff'
al@899 504 [ -s "$diff" ] || return
al@899 505
al@931 506 deps=$(grep ^+[a-zA-Z0-9] $diff | sed 's|^+||')
al@931 507 nb=$(grep ^+[a-zA-Z0-9] $diff | wc -l)
al@899 508 newline
al@899 509 _n 'Build dependencies to remove:'; echo " $nb"
al@899 510 [ -n "$root" ] && echo "root=\"$root\""
al@1090 511
al@728 512 _n 'Removing:'
al@728 513 for dep in $deps; do
pankso@8 514 echo -n " $dep"
al@982 515 # Do not waste time uninstalling the packages if we are inside
al@982 516 # aufs chroot - unmounting chroot will "uninstall" all packages.
al@982 517 [ -s /aufs-umount.sh ] ||
pankso@426 518 echo 'y' | tazpkg remove $dep --root=$root >/dev/null
pankso@8 519 done
al@1090 520
al@982 521 newline; newline
al@982 522 # Keep the last diff for debug and info.
al@982 523 mv -f $diff $CACHE/installed.diff
al@899 524 }
al@899 525
al@899 526
paul@900 527 # Automatically patch the sources.
al@899 528
al@899 529 patchit() {
al@899 530 [ -f "$stuff/patches/series" ] || return
al@1129 531 # Empty lines and comments (started with "#") are ignored
al@1129 532 # Up to three fields (no spaces inside allowed) separated by "|":
al@1129 533 # 1. patch options like "-p0" (optional);
al@1129 534 # 2. patch file name or URL (mandatory);
al@1129 535 # 3. patch checksum in form "sha1=..." or other *sum (optional).
al@899 536
al@1129 537 local done="$pkgdir/.patch.done" var1 var2 var3
al@1129 538 local patchname patchopts patchfile patchsum patchsum_type patchsum_sum
al@938 539 IFS=$'\n'
al@899 540 while read i; do
al@940 541 patchname=$(echo ${i%%#*} | cut -d' ' -f1) # allow comments (anything after the # or space)
al@1129 542 [ -n "$patchname" ] || continue # skip empty lines
al@1129 543
al@1129 544 var1=$(echo "$patchname||" | cut -d'|' -f1) # options or name
al@1129 545 var2=$(echo "$patchname||" | cut -d'|' -f2) # name or checksum or empty
al@1129 546 var3=$(echo "$patchname||" | cut -d'|' -f3) # checksum or empty
al@1129 547
al@1129 548 if [ -n "$var3" ]; then
al@1129 549 patchopts="$var1"; patchname="$var2"; patchsum="$var3"
al@1129 550 elif [ -n "$var2" ]; then
al@1129 551 case $var2 in
al@1129 552 *=*) patchopts='-Np1'; patchname="$var1"; patchsum="$var2";;
al@1129 553 *) patchopts="$var1"; patchname="$var2"; patchsum='';;
al@1129 554 esac
al@1129 555 else
al@1129 556 patchopts='-Np1'; patchname="$var1"; patchsum=''
al@1129 557 fi
al@1129 558
al@1129 559 case $patchname in
al@1129 560 ftp://*|http://*|https://*)
al@1129 561 patchfile="$SRC/$(basename $patchname)"
al@1129 562 [ -e "$patchfile" ] || wget -q -T 60 -O $patchfile $patchname ||
al@1129 563 die 'ERROR: %s' "can't get $patchname"
al@1129 564 ;;
al@1129 565 *)
al@1129 566 patchfile="$stuff/patches/$patchname"
al@1129 567 ;;
al@984 568 esac
al@1129 569
al@1129 570 if [ -n "$patchsum" ]; then
al@1129 571 patchsum_type=${patchsum%=*}
al@1129 572 patchsum_sum=${patchsum#*=}
al@1129 573 echo "$patchsum_sum $patchfile" | ${patchsum_type}sum -cs ||
al@1129 574 die 'ERROR: %s' "wrong ${patchsum_type}sum for $patchfile"
al@1130 575 else
al@1130 576 case $patchfile in
al@1130 577 $SRC/*) echo "warning: no checksum for external patch!";;
al@1130 578 esac
al@1129 579 fi
al@1129 580
al@1090 581 touch $done
al@1090 582 grep -q "^${patchname}$" $done && continue # already applied (useful with `cook --continue`)
al@1129 583
al@912 584 newline
al@938 585 _ 'Applying patch %s' "$patchname"
al@1129 586 patch $patchopts -i $patchfile | sed 's|^| |'
al@1129 587
al@1090 588 echo $patchname >> $done
al@899 589 done < $stuff/patches/series
al@912 590 newline
al@938 591 unset IFS
pankso@1 592 }
pankso@1 593
al@834 594
al@907 595 # Check source tarball integrity.
al@907 596
al@907 597 check_integrity() {
al@909 598 for i in sha1 sha3 sha256 sha512 md5; do
al@909 599 I=$(echo $i | tr 'a-z' 'A-Z')
al@909 600 eval sum=\$TARBALL_$I
al@909 601 if [ -n "$sum" ]; then
al@909 602 newline
al@909 603 _ 'Checking %ssum of source tarball...' "$i"
al@909 604 echo "$sum $SRC/$TARBALL" | ${i}sum -c || exit 1
al@909 605 fi
al@909 606 done
al@909 607 newline
al@907 608 }
al@907 609
al@907 610
al@1019 611 # Misc fix functions
al@1019 612
al@1019 613 fix() {
al@1019 614 case $1 in
al@1019 615 # https://bugzilla.gnome.org/show_bug.cgi?id=655517
al@1019 616 # https://wiki.gentoo.org/wiki/Project:Quality_Assurance/As-needed
al@1019 617 ld)
al@1019 618 export LDFLAGS="$LDFLAGS -Wl,-Os,--as-needed"
al@1019 619 ;;
al@1019 620 libtool)
al@1019 621 if [ -e 'libtool' ]; then
al@1019 622 sed -i 's| -shared | -Wl,-Os,--as-needed\0|g' libtool
al@1090 623 echo "fix.libtool" >> $pkgdir/.patch.done
al@1019 624 else
al@1019 625 echo "fix libtool: warning: libtool absent, nothing to fix."
al@1019 626 fi
al@1019 627 ;;
al@1039 628 math)
al@1039 629 # fix C++ math issue introduced in Glibc 2.26:
al@1039 630 # error: '__builtin_isnan' is not a member of 'std'
al@1039 631 # if (std::isnan(N)) {
al@1039 632 # ^
al@1039 633 find $src -type f -exec sed -i '
al@1039 634 s|std::signbit|__builtin_signbit|g;
al@1039 635 s|std::isnan|__builtin_isnan|g;
al@1039 636 s|std::isinf|__builtin_isinf_sign|g;
al@1039 637 s|std::isfinite|__builtin_isfinite|g;
al@1039 638 s|std::isnormal|__builtin_isnormal|g
al@1039 639 ' '{}' \;
al@1039 640 ;;
al@1050 641 symlinks)
al@1050 642 # make absolute symlinks relative
al@1050 643 echo "fix symlinks"
al@1050 644 local ifs="$IFS" link target
al@1050 645 IFS=$'\n'
al@1050 646 # step 1: fast job, prefix all the absolute symlinks with "$install"
al@1050 647 for link in $(find $install -type l); do
al@1050 648 target="$(readlink $link)"
al@1050 649 case "$target" in
al@1050 650 /*) ln -sfv "$install$target" "$link";;
al@1050 651 esac
al@1050 652 done
al@1050 653 IFS="$ifs"
al@1050 654 # step 2: fine tuning, make symlinks relative
al@1050 655 tazpkg -gi --quiet --local --cookmode symlinks
al@1050 656 symlinks -cr $install
al@1050 657 ;;
al@1088 658 gem)
al@1088 659 # some useful operations while Ruby gems cooking
al@1088 660 _gems="$(ruby -e'puts Gem.default_dir')"
al@1088 661
al@1088 662 # remove unwanted empty folders
al@1088 663 rmdir --ignore-fail-on-non-empty \
al@1088 664 $install/$_gems/build_info/ \
al@1088 665 $install/$_gems/cache/ \
al@1088 666 $install/$_gems/doc/ \
al@1088 667 $install/$_gems/extensions/
al@1088 668
al@1088 669 # move files to docdir
al@1088 670 docdir=$install/usr/share/doc/$PACKAGE-$VERSION
al@1088 671 for i in $(ls -ap $install/$_gems/gems/${PACKAGE#*-}-$VERSION/ | sed '
al@1088 672 /\/$/d; /^\./d; /gemspec$/d; /Rakefile*/d; /Gemfile*/d; /Makefile/d;
al@1088 673 /\.c$/d; /\.h$/d; /\.o$/d; /\.rb$/d; /\.so$/d; /\.yml$/d;
al@1088 674 /Manifest/d; /\.inc$/d; /depend/d;
al@1088 675 '); do
al@1088 676 mkdir -p $docdir # docdir will not be created when nothing to move
al@1088 677 mv $install/$_gems/gems/${PACKAGE#*-}-$VERSION/$i $docdir
al@1088 678 done
al@1088 679 if [ -d $install/$_gems/gems/${PACKAGE#*-}-$VERSION/doc/ ]; then
al@1088 680 mkdir -p $docdir
al@1088 681 mv $install/$_gems/gems/${PACKAGE#*-}-$VERSION/doc/ $docdir
al@1088 682 fi
al@1088 683
al@1088 684 if [ -d $docdir ]; then
al@1088 685 # move man pages
al@1088 686 unset man_to_copy
al@1088 687 for i in $(seq 1 8); do
al@1088 688 for j in $(find $docdir -type f -name "*.$i" | sed '/LGPL-2\.1/d'); do
al@1088 689 man_to_copy="$man_to_copy $j"
al@1088 690 done
al@1088 691 done
al@1088 692 if [ -n "$man_to_copy" ]; then
al@1088 693 cook_pick_manpages $man_to_copy
al@1088 694 rm $man_to_copy
al@1088 695 fi
al@1088 696
al@1088 697 # convert rdoc to markdown (thanks https://gist.github.com/teeparham/8a99e308884e1c32735a)
al@1088 698 for i in $(find $docdir -type f -name '*.rdoc'); do
al@1088 699 fix utf-8
al@1088 700 LC_ALL=en_US.UTF-8 ruby -r rdoc -e 'puts RDoc::Markup::ToMarkdown.new.convert File.read(ARGV[0] || "'$i'")' >$i.md && rm $i || rm $i.md
al@1088 701 done
al@1088 702 fi
al@1088 703
al@1088 704 # move man pages (from the different place)
al@1088 705 rubyman=$install/$_gems/gems/${PACKAGE#*-}-$VERSION/man
al@1088 706 if [ -d $rubyman ]; then
al@1088 707 unset man_to_copy
al@1088 708 for i in $(seq 1 8); do
al@1088 709 for j in $(find $rubyman -type f -name "*.$i" | sed '/LGPL-2\.1/d'); do
al@1088 710 man_to_copy="$man_to_copy $j"
al@1088 711 done
al@1088 712 done
al@1088 713 if [ -n "$man_to_copy" ]; then
al@1088 714 cook_pick_manpages $man_to_copy
al@1088 715 fi
al@1088 716 rm -r $rubyman
al@1088 717 fi
al@1088 718 ;;
al@1088 719 utf-8)
al@1088 720 # Install UTF-8 locale
al@1088 721 tazpkg -gi --quiet --local --cookmode locale-en-base
al@1088 722 mkdir -p /usr/lib/locale
al@1088 723 localedef -i 'en_US' -c -f 'UTF-8' /usr/lib/locale/en_US.UTF-8
al@1088 724 ;;
al@1019 725 esac
al@1019 726 }
al@1019 727
al@1019 728
al@1115 729 # Typical function used in compile_rules() to make perl modules packages
al@1115 730
al@1115 731 cook_perl() {
al@1115 732 if [ -e "Makefile.PL" ]; then
al@1115 733 # Up to 3 optional parameters supported
al@1115 734 PERL_MM_USE_DEFAULT=1 perl Makefile.PL INSTALLDIRS=vendor $1 &&
al@1115 735 make $2 &&
al@1115 736 make $3 PERL_MM_USE_DEFAULT=1 DESTDIR=$install install &&
al@1115 737 chmod -R u+w $install
al@1115 738 elif [ -e "Build.PL" ]; then
al@1115 739 echo "Not implemented yet"
al@1115 740 return 1
al@1115 741 else
al@1115 742 echo "Unable to cook Perl module"
al@1115 743 return 1
al@1115 744 fi
al@1115 745 }
al@1115 746
al@1115 747
al@1051 748 # Store timestamps, log jobs length
al@1051 749
al@1051 750 timestamp() {
al@1051 751 local ts_file="$WOK/$pkg/.ts"
al@1051 752 local curr_ts=$(date '+%s')
al@1051 753 case $1 in
al@1051 754 init)
al@1051 755 rm $ts_file 2>/dev/null
al@1051 756 echo $curr_ts > $prev_ts
al@1051 757 ;;
al@1051 758 job*)
al@1051 759 # calculate time from the last timestamp
al@1051 760 echo "$1='$(( $curr_ts - $(cat $prev_ts) ))'" >> $ts_file
al@1051 761 echo $curr_ts > $prev_ts
al@1051 762 ;;
al@1051 763 sets)
al@1051 764 echo "sets='$2'" >> $ts_file
al@1051 765 ;;
al@1051 766 esac
al@1051 767 }
al@1051 768
al@1051 769
al@1051 770 # Store time statsistics to the cache
al@1051 771
al@1051 772 store_timestats() {
al@1051 773 # see doc/timestats.txt for file format
al@1051 774 temp=$(mktemp)
al@1051 775 {
al@1051 776 for i in $(seq 1 30); do echo "job$i=0"; done
al@1051 777 cat $WOK/$pkg/.ts
al@1051 778 echo -n 'total=$(( 0'
al@1051 779 for i in $(seq 1 30); do echo -n " + job$i"; done
al@1051 780 echo ' ))'
al@1051 781 } > $temp
al@1051 782 . $temp
al@1051 783 {
al@1051 784 echo -n "$pkg $sets "
al@1051 785 for i in $(seq 1 30); do echo -n "$((job$i)) "; done
al@1051 786 echo "$total"
al@1051 787 } >> /home/slitaz/cache/timestats
al@1051 788 rm $temp $WOK/$pkg/.ts # clean
al@1051 789 }
al@1051 790
al@1051 791
al@1079 792 # Internal function to cook specified SET
al@1079 793
al@1079 794 cook_set() {
al@1079 795 # Switch to the specified source set
al@1079 796 set_paths
al@1079 797 local suffix=''
al@1079 798 [ -n "$SET" ] && suffix="-$SET"
al@1079 799 export src="$WOK/$pkg/source/$PACKAGE-$VERSION$suffix"
al@1079 800 export install="$WOK/$pkg/install$suffix"
al@1079 801 export DESTDIR="$install"
al@1079 802
al@1079 803 if [ -n "$SETS" ]; then
al@1079 804 if [ -n "$SET" ]; then
al@1079 805 title "Switching to the set '$SET'"
al@1079 806 else
al@1079 807 title "Switching to the default set"
al@1079 808 fi
al@1079 809 echo "src : $src"
al@1079 810 echo "install: $install"
al@1079 811 fi
al@1079 812 [ -d "$src" ] && cd $src # packages without sources exists
al@1079 813 echo
al@1079 814
al@1079 815 [ -d "$install" ] && rm -r $install
al@1079 816 #mkdir -p $install
al@1079 817
al@1079 818 compile_rules $@ || { broken; exit 1; }
al@1079 819
al@1079 820 # Stay compatible with _pkg
al@1079 821 [ -d "$src/_pkg" ] && mv $src/_pkg $install
al@1079 822
al@1079 823 copy_generic_stuff
al@1079 824
al@1079 825 timestamp job$job_counter # compiling (set '$SET')
al@1079 826
al@1079 827 # Actions to do after compiling the package
al@1079 828 # Skip all for split packages (already done in main package)
al@1079 829 if [ -z "$WANTED" ]; then
al@1079 830 footer
al@1079 831 export COOKOPTS ARCH install
al@1079 832 @@PREFIX@@/libexec/cookutils/compressor install
al@1079 833 timestamp job$(($job_counter + 1)) # compressing (set '$SET')
al@1079 834 fi
al@1079 835
al@1079 836 # Activate "instant-pack" mode
al@1079 837 if [ "${COOKOPTS/instant-pack/}" != "$COOKOPTS" ]; then
al@1079 838 echo " $SPLIT " | fgrep -q " $PACKAGE " || SPLIT="$PACKAGE $SPLIT"
al@1090 839 export PACKAGE
al@1079 840 # determine the list of the packages belongs to the current SET...
al@1079 841 echo -n $SPLIT \
al@1079 842 | awk -vset="$SET" '
al@1079 843 BEGIN { RS = " "; FS = ":"; }
al@1079 844 { if ($2 == set) print $1; }' \
al@1090 845 | xargs -n1 @@PREFIX@@/libexec/cookutils/pack # ... and then pack them
al@1079 846 fi
al@1079 847
al@1079 848 job_counter=$(($job_counter + 2))
al@1079 849 }
al@1079 850
al@1079 851
pankso@1 852 # The main cook function.
al@728 853
pankso@1 854 cookit() {
al@899 855 if [ -n "$SETUP_MD5" -a "$SETUP_MD5" != "$(ls $root$INSTALLED | md5sum | cut -c1-32)" ]; then
pascal@883 856 _ 'ERROR: Broken setup. Abort.'
pascal@883 857 return
pascal@882 858 fi
pascal@882 859
al@779 860 title 'Cook: %s' "$PACKAGE $VERSION"
pankso@1 861 set_paths
al@1051 862 timestamp init # the very start
pankso@359 863
pankso@377 864 # Handle cross-tools.
al@1024 865 [ "$BUILD_SYSTEM" != "$HOST_SYSTEM" ] &&
pankso@359 866 case "$ARCH" in
pankso@675 867 arm*|x86_64)
paul@387 868 # CROSS_COMPILE is used by at least Busybox and the kernel to set
al@596 869 # the cross-tools prefix. Sysroot is the root of our target arch
al@728 870 sysroot="$CROSS_TREE/sysroot"
al@728 871 tools="$CROSS_TREE/tools"
pankso@443 872 # Set root path when cross compiling. ARM tested but not x86_64
pankso@443 873 # When cross compiling we must install build deps in $sysroot.
al@737 874 arch="-$ARCH"
al@728 875 root="$sysroot"
al@728 876 _ '%s sysroot: %s' "$ARCH" "$sysroot"
al@728 877 _ 'Adding "%s" to PATH' "$tools/bin"
al@728 878 export PATH="$PATH:$tools/bin"
al@728 879 export PKG_CONFIG_PATH="$sysroot/usr/lib/pkgconfig"
al@737 880 export CROSS_COMPILE="$HOST_SYSTEM-"
al@728 881 _ 'Using cross-tools: %s' "$CROSS_COMPILE"
al@728 882 if [ "$ARCH" == 'x86_64' ]; then
al@737 883 export CC="$HOST_SYSTEM-gcc -m64"
al@737 884 export CXX="$HOST_SYSTEM-g++ -m64"
pankso@438 885 else
al@737 886 export CC="$HOST_SYSTEM-gcc"
al@737 887 export CXX="$HOST_SYSTEM-g++"
pankso@438 888 fi
al@737 889 export AR="$HOST_SYSTEM-ar"
al@737 890 export AS="$HOST_SYSTEM-as"
al@737 891 export RANLIB="$HOST_SYSTEM-ranlib"
al@737 892 export LD="$HOST_SYSTEM-ld"
al@737 893 export STRIP="$HOST_SYSTEM-strip"
al@899 894 export LIBTOOL="$HOST_SYSTEM-libtool"
al@899 895 ;;
pankso@359 896 esac
pankso@359 897
al@1019 898 @@PREFIX@@/libexec/cookutils/precheck $receipt || exit 1 # former receipt_quality()
al@904 899
pankso@44 900 cd $pkgdir
al@1090 901 if [ -z "$continue" ]; then
al@1090 902 rm -rf source 2>/dev/null
al@1090 903 rm .patch.done 2>/dev/null
al@1090 904 fi
al@728 905 rm -rf install taz 2>/dev/null
pankso@1 906
al@860 907 # Disable -pipe if less than 512 MB free RAM.
al@860 908 free=$(awk '/^MemFree|^Buffers|^Cached/{s+=$2}END{print int(s/1024)}' /proc/meminfo)
al@860 909 if [ "$free" -lt 512 ] && [ "$CFLAGS" != "${CFLAGS/-pipe}" ]; then
al@860 910 _ 'Disabling -pipe compile flag: %d MB RAM free' "$free"
al@728 911 CFLAGS="${CFLAGS/-pipe}"; CFLAGS=$(echo "$CFLAGS" | tr -s ' ')
al@728 912 CXXFLAGS="${CXXFLAGS/-pipe}"; CXXFLAGS=$(echo "$CXXFLAGS" | tr -s ' ')
pankso@1 913 fi
pankso@1 914 unset free
pankso@1 915
pankso@232 916 # Export flags and path to be used by make and receipt.
al@728 917 DESTDIR="$pkgdir/install"
al@596 918 # FIXME: L10n: Is this the right time for 'LC_ALL=C LANG=C'?
al@1039 919 export DESTDIR MAKEFLAGS CFLAGS CXXFLAGS CONFIG_SITE LC_ALL=C LANG=C \
al@1039 920 LDFLAGS
pankso@1 921
al@1051 922 timestamp job1 # pre-checks
al@1051 923
al@904 924 # BUILD_DEPENDS may vary depending on the ARCH
al@904 925 case "$ARCH" in
al@904 926 arm*) [ -n "$BUILD_DEPENDS_arm" ] && BUILD_DEPENDS=$BUILD_DEPENDS_arm ;;
al@904 927 x86_64) [ -n "$BUILD_DEPENDS_x86_64" ] && BUILD_DEPENDS=$BUILD_DEPENDS_x86_64 ;;
al@904 928 esac
al@904 929
pankso@126 930 # Check for build deps and handle implicit depends of *-dev packages
pankso@126 931 # (ex: libusb-dev :: libusb).
al@728 932 [ -n "$BUILD_DEPENDS" ] && _ 'Checking build dependencies...'
al@728 933 [ -n "$root" ] && _ 'Using packages DB: %s' "$root$DB"
al@899 934
al@935 935 # Get the list of installed packages
al@935 936 cd $root$INSTALLED; ls > $CACHE/installed.list
al@935 937
al@912 938 for action in check install; do
al@912 939 for dep in $BUILD_DEPENDS; do
al@912 940 implicit="${dep%-dev}"; [ "$implicit" == "$dep" ] && implicit=''
al@912 941 for i in $dep $implicit; do
al@912 942 # Skip if package already installed
al@912 943 [ -f "$root$INSTALLED/$i/receipt" ] && continue
al@899 944
al@912 945 case $action in
al@912 946 check)
al@912 947 # Search for local package or local provided-package
al@912 948 name=$(awk -F$'\t' -vpkg="$i" '{
al@912 949 if (index(" " $1 " " $10 " ", " " pkg " ")) {print $1; exit}
al@1090 950 }' "$PKGS/packages-$ARCH.info")
al@912 951 if [ -z "$name" ]; then
al@912 952 # Search for package in mirror
al@912 953 name="$(awk -F$'\t' -vi="$i" '$1==i{print $1; exit}' "$root$DB/packages.info")"
al@912 954 [ -z "$name" -a "$i" == "$dep" ] && die 'ERROR: unknown dep "%s"' "$i"
al@912 955 fi
al@912 956 ;;
al@912 957 install)
al@912 958 tazpkg get-install $i --root=$root --local --quiet --cookmode || { broken; exit 1; }
al@912 959 ;;
al@912 960 esac
al@912 961 done
pankso@126 962 done
pankso@1 963 done
pankso@225 964
al@769 965 update_installed_cook_diff
pankso@202 966
al@1051 967 timestamp job2 # installing bdeps
al@1051 968
pankso@1 969 # Get source tarball and make sure we have source dir named:
paul@62 970 # $PACKAGE-$VERSION to be standard in receipts. Here we use tar.lzma
paul@62 971 # tarball if it exists.
al@909 972 if [ -n "$WGET_URL" -a ! -f "$SRC/$TARBALL" ]; then
pankso@1 973 if [ -f "$SRC/${SOURCE:-$PACKAGE}-$VERSION.tar.lzma" ]; then
al@728 974 TARBALL="${SOURCE:-$PACKAGE}-$VERSION.tar.lzma"
al@728 975 LZMA_SRC=''
pankso@1 976 else
al@899 977 get_source || { broken; exit 1; }
pankso@1 978 fi
pankso@1 979 fi
al@909 980 if [ -z "$WANTED" -a -n "$TARBALL" -a ! -d "$src" ]; then
al@728 981 mkdir -p $pkgdir/source/tmp; cd $pkgdir/source/tmp
pascal@268 982 if ! extract_source ; then
pascal@268 983 get_source
al@899 984 extract_source || { broken; exit 1; }
pascal@268 985 fi
al@728 986 if [ -n "$LZMA_SRC" ]; then
pankso@190 987 cd $pkgdir/source
al@909 988 if [ "$(ls -A tmp | wc -l)" -gl 1 -o -f "$(echo tmp/*)" ]; then
al@728 989 mv tmp tmp-1; mkdir tmp
pankso@190 990 mv tmp-1 tmp/${SOURCE:-$PACKAGE}-$VERSION
pankso@190 991 fi
pankso@190 992 if [ -d "tmp/${SOURCE:-$PACKAGE}-$VERSION" ]; then
al@728 993 cd tmp; tar -c * | lzma e $SRC/$TARBALL -si
pankso@190 994 fi
pankso@190 995 fi
al@1008 996
pankso@190 997 cd $pkgdir/source/tmp
paul@62 998 # Some archives are not well done and don't extract to one dir (ex lzma).
pankso@57 999 files=$(ls | wc -l)
al@1008 1000 [ "$files" -eq 1 -a -d "$(ls)" ] &&
al@1008 1001 mv * ../$PACKAGE-$VERSION
al@1008 1002 [ "$files" -eq 1 -a -f "$(ls)" ] &&
al@1008 1003 mkdir -p ../$PACKAGE-$VERSION &&
al@1008 1004 mv * ../$PACKAGE-$VERSION/$TARBALL
al@1008 1005 [ "$files" -gt 1 ] &&
al@1008 1006 mkdir -p ../$PACKAGE-$VERSION &&
al@1008 1007 mv * ../$PACKAGE-$VERSION
al@728 1008 cd ..; rm -rf tmp
pankso@1 1009 fi
pankso@662 1010
al@1008 1011 # Check md5sum (or similar) for sources tarball
al@909 1012 check_integrity
al@909 1013
pankso@658 1014 # Libtool shared libs path hack.
pankso@658 1015 case "$ARCH" in
pankso@658 1016 arm*) cross libhack ;;
pankso@658 1017 esac
pankso@1 1018
al@1051 1019 timestamp job3 # get/unpack src tarball
al@1051 1020
al@1008 1021 # Compiling all the sets
pankso@44 1022 if grep -q ^compile_rules $receipt; then
al@728 1023 _ 'Executing: %s' 'compile_rules'
pankso@352 1024 echo "CFLAGS : $CFLAGS"
al@1087 1025 echo "CXXLAGS : $CXXFLAGS"
al@1087 1026 echo "CPPFLAGS : $CPPFLAGS"
al@1039 1027 echo "LDFLAGS : $LDFLAGS"
pankso@55 1028 [ -d "$src" ] && cd $src
al@899 1029 patchit
al@809 1030
al@1051 1031 timestamp job4 # patching
al@1051 1032
al@1008 1033 # Get set names from $SPLIT variable, format ex. 'pkg1 pkg2:set1 pkg3:set2'
al@1079 1034 # Keep natural order of the sets, don't sort them alphabetically
al@1079 1035 SETS=$(echo -n $SPLIT \
al@1008 1036 | awk '
al@1008 1037 BEGIN { RS = " "; FS = ":"; }
al@1079 1038 {
al@1079 1039 if ($2 && ! set[$2]) { printf("%s ", $2); set[$2] = "1"; }
al@1079 1040 }' \
al@1079 1041 | sed 's| $||')
al@1008 1042 # Prepare specified source sets using patched sources
al@1078 1043 [ -n "$SETS" -a -d "$src" ] &&
al@1008 1044 for set in $SETS; do
al@1008 1045 echo "Preparing set $set" # debug
al@1008 1046 cp -a $src $src-$set
al@1008 1047 done
al@912 1048
al@1051 1049 timestamp job5 # preparing sets
al@1051 1050 timestamp sets "$SETS"
al@1051 1051
al@1051 1052 job_counter='6'
al@1008 1053
al@1079 1054 SET='' cook_set # first run for empty SET
al@1008 1055
al@1079 1056 # Allow to change SETS after the first run, follow the changes
al@1079 1057 SETS=$(. $receipt; echo -n $SPLIT \
al@1079 1058 | awk '
al@1079 1059 BEGIN { RS = " "; FS = ":"; }
al@1079 1060 {
al@1079 1061 if ($2 && ! set[$2]) { printf("%s ", $2); set[$2] = "1"; }
al@1079 1062 }' \
al@1079 1063 | sed 's| $||')
al@1079 1064 for SET in $SETS; do
al@1079 1065 cook_set
al@1008 1066 done
al@1013 1067 else
al@1013 1068 mkdir -p $install # allow receipts without `compile_rules()`
al@837 1069 fi
al@779 1070 footer
pankso@360 1071
al@1051 1072 timestamp job # reset counter
al@1051 1073
pankso@360 1074 # Execute testsuite.
pankso@360 1075 if grep -q ^testsuite $receipt; then
al@779 1076 title 'Running testsuite'
al@899 1077 testsuite $@ || { broken; exit 1; }
al@779 1078 footer
pankso@360 1079 fi
al@769 1080
al@1051 1081 timestamp job26 # test suite
al@1051 1082
al@769 1083 update_installed_cook_diff force
pankso@1 1084 }
pankso@1 1085
al@728 1086
pankso@1 1087 # Cook quality assurance.
al@728 1088
pankso@1 1089 cookit_quality() {
al@989 1090 while true; do
al@989 1091 [ ! -d "$WOK/$pkg/install" -a -z "$WANTED" ] || break
al@728 1092 _ 'ERROR: cook failed' | tee -a $LOGS/$pkg.log
al@989 1093 [ "$trials" == 'yes' ] || break
al@989 1094 title "Interactive mode"
al@989 1095 # TODO: allow commands:
al@989 1096 # q - quit; v - edit receipt here using vi;
al@989 1097 # s - search for package containing package;
al@989 1098 # <package name> - install package; [Enter] - retry
al@989 1099 _ 'You may install the packages here and/or edit the receipt there.'
al@989 1100 newline
al@989 1101 while true; do
al@989 1102 _n 'Install the package? [name/N] '; read answer
al@989 1103 [ -n "$answer" ] || break
al@989 1104 tazpkg -gi $answer --root=$root --local --quiet --cookmode
al@989 1105 done
al@989 1106 newline
al@989 1107 _n 'Try again? [Y/n] '; read answer
al@989 1108 [ "$answer" == 'n' ] && break
paul@993 1109 # here you may append log if you want (">>" instead of last ">")
al@989 1110 cookit $@ 2>&1 | loglimit 50 > $LOGS/$pkg.log
al@989 1111 done
al@962 1112
al@962 1113 [ "${COOKOPTS/skip-log-errors/}" != "$COOKOPTS" ] && return 0
al@962 1114
pankso@9 1115 # ERROR can be echoed any time in cookit()
pascal@618 1116 if grep -Ev "(conftest|configtest)" $LOGS/$pkg.log | \
al@962 1117 grep -Eq "(^ERROR|undefined reference to)" ; then
al@1090 1118 debug_info "cookit_quality" | tee -a $LOGS/$pkg.log
al@992 1119 put_status $pkg Failed
al@1090 1120 # rm -f $command
al@1090 1121 # broken; exit 1
pankso@1 1122 fi
pankso@1 1123 }
pankso@1 1124
al@728 1125
al@916 1126 # Return all the names of packages bundled in this receipt
al@916 1127
al@916 1128 all_names() {
al@1008 1129 # Get package names from $SPLIT variable
al@1079 1130 local split=$(echo -n $SPLIT \
al@1008 1131 | awk '
al@1008 1132 BEGIN { RS = " "; FS = ":"; }
al@1008 1133 { print $1; }' \
al@1008 1134 | tr '\n' ' ')
al@1008 1135 local split_space=" $split "
al@940 1136 if ! head -n1 $WOK/$pkg/receipt | fgrep -q 'v2'; then
al@940 1137 # For receipts v1: $SPLIT may present in the $WANTED package,
al@940 1138 # but split packages have their own receipts
al@940 1139 echo $PACKAGE
al@1008 1140 elif [ "${split_space/ $PACKAGE /}" != "$split_space" ]; then
al@916 1141 # $PACKAGE included somewhere in $SPLIT (probably in the end).
al@916 1142 # We should build packages in the order defined in the $SPLIT.
al@1008 1143 echo $split
al@916 1144 else
al@916 1145 # We'll build the $PACKAGE, then all defined in the $SPLIT.
al@1008 1146 echo $PACKAGE $split
al@916 1147 fi
al@916 1148 }
al@916 1149
al@916 1150
al@904 1151 # v2: pack all packages using compiled files
al@904 1152
al@904 1153 packall() {
al@904 1154 set_paths
al@1090 1155 [ -e $pkgdir/.arch ] && rm $pkgdir/.arch
al@1090 1156
al@904 1157 if head -n1 "$pkgdir/receipt" | fgrep -q 'v2'; then
al@916 1158 for i in $(all_names); do
al@913 1159 unset TAGS DEPENDS CAT CONFIG_FILES PROVIDE SUGGESTED DATABASE_FILES TAZPANEL_DAEMON
al@1090 1160 export PACKAGE; @@PREFIX@@/libexec/cookutils/pack $i
al@904 1161 done
al@904 1162 else
al@1090 1163 export PACKAGE; @@PREFIX@@/libexec/cookutils/pack $PACKAGE
al@904 1164 fi
al@904 1165 }
al@904 1166
al@904 1167
al@728 1168 # Reverse "cat" command: prints input lines in the reverse order
al@728 1169
pankso@421 1170 tac() {
pascal@285 1171 sed '1!G;h;$!d' $1
pascal@285 1172 }
pascal@285 1173
al@728 1174
al@1090 1175 # Install package: update the chroot with freshly rebuilt package: keep env up-to-date.
al@728 1176
pankso@428 1177 install_package() {
al@953 1178 set_paths
pankso@428 1179 case "$ARCH" in
al@1090 1180 arm*) root="$CROSS_TREE/sysroot";;
pankso@428 1181 esac
al@1090 1182
al@1090 1183 # Process all the package names built by this receipt (defined in $SPLIT)
al@1090 1184 for i in $(PACKAGE="$pkg" all_names); do
al@1090 1185 if [ -d "$root$INSTALLED/$i" ]; then
al@1090 1186 pkg_file=$(awk -F$'\t' -vpkg="$i" -varch="$ARCH" '{
al@1090 1187 if ($1 == pkg) {
al@1090 1188 pkgarch = ($11 == "0") ? "any" : arch;
al@1090 1189 printf("%s-%s-%s.tazpkg", $1, $2, pkgarch);
al@1090 1190 exit
al@1090 1191 }
al@1090 1192 }' $PKGS/packages-$ARCH.info)
al@1090 1193 if [ -e "$PKGS/$pkg_file" ]; then
al@1090 1194 _ 'Updating %s chroot environment...' "$ARCH"
al@1090 1195 _ 'Updating chroot: %s' "${pkg_file%.tazpkg}" | log
al@1090 1196 tazpkg -i "$PKGS/$pkg_file" --forced --root=$root
al@1090 1197 fi
pankso@428 1198 fi
al@1090 1199 done
pankso@428 1200 }
pankso@428 1201
al@728 1202
pascal@696 1203 # remove chroot jail
al@728 1204
pascal@696 1205 umount_aufs() {
pascal@696 1206 tac ${1}rw/aufs-umount.sh | sh
pascal@696 1207 rm -rf ${1}rw
pascal@696 1208 umount ${1}root
pascal@697 1209 rmdir ${1}r*
pascal@696 1210 }
pascal@696 1211
al@728 1212
pascal@285 1213 # Launch the cook command into a chroot jail protected by aufs.
pascal@285 1214 # The current filesystems are used read-only and updates are
pascal@285 1215 # stored in a separate branch.
al@728 1216
pascal@285 1217 try_aufs_chroot() {
pascal@285 1218
al@728 1219 base="/dev/shm/aufsmnt$$"
pascal@286 1220
al@596 1221 # Can we setup the chroot? Is it already done?
pascal@292 1222 grep -q ^AUFS_NOT_SUPPORTED $receipt && return
al@728 1223 grep -q ^AUFS_NOT_RAMFS $receipt && base="/mnt/aufsmnt$$"
pascal@285 1224 [ -n "$AUFS_MOUNTS" -a ! -f /aufs-umount.sh ] || return
al@1031 1225 grep -q ^aufs /proc/modules || modprobe aufs 2>/dev/null || return
pascal@286 1226 mkdir ${base}root ${base}rw || return
pascal@285 1227
al@728 1228 _ 'Setup aufs chroot...'
pascal@285 1229
pascal@285 1230 # Sanity check
al@1031 1231 for i in / /proc /sys /dev /dev/shm /home; do
pascal@285 1232 case " $AUFS_MOUNTS " in
al@1031 1233 *\ $i\ *) ;;
al@1031 1234 *) AUFS_MOUNTS="$AUFS_MOUNTS $i" ;;
pascal@285 1235 esac
pascal@285 1236 done
pascal@691 1237 for mnt in $(ls -d $AUFS_MOUNTS | sort | uniq); do
al@1031 1238 mkdir -p ${base}root$mnt # for `mount -o bind`
al@1031 1239 mount -o bind $mnt ${base}root$mnt # use `-o bind` instead of `--bind`
pascal@285 1240 if [ $mnt == / ] && ! mount -t aufs -o br=${base}rw:/ none ${base}root; then
al@728 1241 _ 'Aufs mount failure'
slaxemulator@519 1242 umount ${base}root
pascal@628 1243 rm -rf ${base}r*
slaxemulator@519 1244 return
pascal@285 1245 fi
pascal@285 1246 echo "umount ${base}root$mnt" >> ${base}rw/aufs-umount.sh
pascal@285 1247 done
pascal@696 1248 trap "umount_aufs ${base}" INT
pascal@285 1249
pascal@285 1250 chroot ${base}root $(cd $(dirname $0); pwd)/$(basename $0) "$@"
pascal@285 1251 status=$?
pascal@285 1252
al@728 1253 _ 'Leaving aufs chroot...'
al@737 1254 umount_aufs $base
pascal@683 1255 # Install package outside the aufs jail
pascal@683 1256 install_package
pankso@358 1257 exit $status
pascal@285 1258 }
pascal@285 1259
al@728 1260
al@705 1261 # Encode predefined XML entities
al@728 1262
al@705 1263 xml_ent() {
al@705 1264 sed -e 's|&|\&amp;|g; s|<|\&lt;|g; s|>|\&gt;|g; s|"|\&quot;|g' -e "s|'|\&apos;|g"
al@705 1265 }
al@705 1266
al@728 1267
paul@387 1268 # Create a XML feed for freshly built packages.
al@728 1269
pankso@310 1270 gen_rss() {
al@1090 1271 if [ -e "$WOK/$PACKAGE/.icon.png" ]; then
al@1090 1272 icon="$COOKER_URL$PACKAGE/browse/.icon.png"
al@1090 1273 else
al@1090 1274 icon="http://cook.slitaz.org/tazpkg.png"
al@1090 1275 fi
al@1090 1276
al@728 1277 cat > $FEEDS/$pkg.xml <<EOT
pankso@310 1278 <item>
al@737 1279 <title>$PACKAGE $VERSION$EXTRAVERSION</title>
al@1090 1280 <link>$COOKER_URL${PACKAGE//+/%2B}</link>
al@1090 1281 <guid isPermaLink="false">$PACKAGE-$VERSION$EXTRAVERSION</guid>
al@1090 1282 <pubDate>$(date '+%a, %d %b %Y %X GMT')</pubDate>
al@1090 1283 <description><![CDATA[
al@1090 1284 <table>
al@1090 1285 <tr>
al@1090 1286 <td vertical-align="top"><img src="$icon" alt=""/></td>
al@1090 1287 <td>$(echo -n "$SHORT_DESC" | xml_ent)</td>
al@1090 1288 </tr>
al@1090 1289 </table>
al@1090 1290 ]]></description>
pankso@310 1291 </item>
pankso@310 1292 EOT
pankso@310 1293 }
pankso@310 1294
al@728 1295
pankso@662 1296 # Truncate stdout log file to $1 Mb.
al@728 1297
al@728 1298 loglimit() {
pascal@593 1299 if [ -n "$DEFAULT_LOG_LIMIT" ]; then
pascal@621 1300 tee /dev/stderr | head -qc ${1:-$DEFAULT_LOG_LIMIT}m
pascal@593 1301 else
pascal@593 1302 tee /dev/stderr
pascal@593 1303 fi
pascal@576 1304 }
pascal@576 1305
al@728 1306
pankso@1 1307 #
pankso@671 1308 # Receipt functions to ease packaging
pankso@671 1309 #
pankso@671 1310
pankso@671 1311 get_dev_files() {
al@779 1312 action 'Getting standard devel files...'
pankso@671 1313 mkdir -p $fs/usr/lib
pankso@671 1314 cp -a $install/usr/lib/pkgconfig $fs/usr/lib
pascal@750 1315 cp -a $install/usr/lib/*a $fs/usr/lib
pankso@671 1316 cp -a $install/usr/include $fs/usr
pankso@671 1317 status
pankso@671 1318 }
pankso@671 1319
al@807 1320
al@809 1321 # Function to use in compile_rules() to copy man page from $src to $install
al@807 1322
al@809 1323 cook_pick_manpages() {
al@809 1324 local name section
al@809 1325 action 'Copying man pages...'
al@802 1326
al@809 1327 for i in $@; do
al@809 1328 name=$(echo $i | sed 's|\.[gbx]z2*$||')
al@809 1329 section=${name##*/}; section=${section##*.}
al@809 1330 mkdir -p $install/usr/share/man/man$section
al@899 1331 scopy $i $install/usr/share/man/man$section
al@802 1332 done
al@802 1333 status
al@802 1334 }
al@802 1335
al@807 1336
al@962 1337 # Function to use in compile_rules() to copy documentation from $src to $install
al@962 1338
al@962 1339 cook_pick_docs() {
al@962 1340 local docdir="$install/usr/share/doc/$PACKAGE-$VERSION"
al@962 1341 action 'Copying documentation...'
al@962 1342 mkdir -p $docdir
al@962 1343 cp -r $@ $docdir
al@962 1344 chmod -R a+r $docdir
al@962 1345 status
al@962 1346 }
al@962 1347
al@962 1348
al@932 1349 # Update split.db once for receipt
al@932 1350
al@932 1351 update_split_db() {
al@932 1352 local db="$cache/split.db"
al@932 1353 touch $db
al@932 1354 sed -i "/^$pkg\t/d" $db
al@932 1355 echo -e "$pkg\t$(all_names)" >> $db
al@932 1356 }
al@932 1357
al@932 1358
al@932 1359 # Recreate whole split.db from scratch
al@932 1360
al@932 1361 recreate_split_db() {
al@932 1362 # Clean
al@932 1363 local db="$cache/split.db"
al@932 1364
al@932 1365 cd $WOK
al@940 1366 for pkg in *; do
al@940 1367 [ -f "$WOK/$pkg/receipt" ] || continue
al@932 1368 unset PACKAGE SPLIT
al@940 1369 . $WOK/$pkg/receipt
al@1081 1370 echo -e "$PACKAGE\t$(all_names)"
al@1081 1371 done > $db
al@1081 1372 }
al@1081 1373
al@1081 1374
al@1081 1375 # Recreate whole maint.db from scratch
al@1081 1376
al@1081 1377 recreate_maint_db() {
al@1081 1378 # Clean
al@1081 1379 local db="$cache/maint.db"
al@1081 1380
al@1081 1381 cd $WOK
al@1081 1382 for pkg in *; do
al@1081 1383 [ -f "$WOK/$pkg/receipt" ] || continue
al@1081 1384 unset PACKAGE MAINTAINER
al@1081 1385 . $WOK/$pkg/receipt
al@1082 1386 MAINTAINER=$(echo $MAINTAINER | sed 's|.*<||; s|>.*||')
al@1081 1387 echo -e "$MAINTAINER\t$PACKAGE"
al@1081 1388 done | sort > $db
al@899 1389 }
al@899 1390
al@899 1391
al@992 1392 # Put the status to the activity log
al@992 1393
al@992 1394 put_status() {
al@992 1395 # $1: package, $2: status, one of 'Done', 'Failed'
al@992 1396 sed -i "s|>$1</a>$|& [ $2 ]|" $activity
al@1027 1397 if [ "$2" == 'Done' ]; then
al@1027 1398 # overstrike all previous 'Failed' to indicate package is OK now
al@1027 1399 sed -i "/>$1<\/a>/ s|\[ Failed \]|[ -Failed ]|" $activity
al@1027 1400 fi
al@992 1401 }
al@992 1402
al@992 1403
al@742 1404
al@728 1405
pankso@671 1406 #
pankso@1 1407 # Commands
pankso@1 1408 #
pankso@1 1409
al@932 1410 # cook <package> --deps
al@933 1411 [ -n "$deps" ] && {
al@933 1412 @@PREFIX@@/libexec/cookutils/deps $1
al@933 1413 exit 0
al@933 1414 }
al@933 1415
al@933 1416 # cook <package> --clean
al@933 1417 # cook <package> -c
al@933 1418 [ -n "$clean" -o "$2" == '-c' ] && {
al@933 1419 action 'Cleaning "%s"' "$1"
al@933 1420 cd $WOK/$1; rm -rf install taz source
al@933 1421 status; newline
al@933 1422 touch $activity # update $activity -> something changed -> update webstat
al@933 1423 exit 0
al@933 1424 }
al@933 1425
al@933 1426 # cook <package> --getsrc
al@933 1427 # cook <package> -gs
al@933 1428 [ -n "$getsrc" -o "$2" == '-gs' ] && {
al@1129 1429 pkg="$1"
al@1129 1430 title 'Getting source for "%s"' "$pkg"
al@933 1431 receipt="$WOK/$pkg/receipt"
al@933 1432 check_pkg_in_wok
al@933 1433 unset_receipt
al@933 1434 . $receipt
al@933 1435 get_source
al@933 1436 _ 'Tarball: %s' "$SRC/$TARBALL"; newline
al@933 1437 exit 0
al@933 1438 }
al@933 1439
al@933 1440 # cook <package> --block
al@933 1441 # cook <package> -b
al@933 1442 [ -n "$block" -o "$2" == '-b' ] && {
al@933 1443 action 'Blocking package "%s"' "$1"
al@933 1444 [ $(grep "^$1$" $blocked) ] || echo "$1" >> $blocked
al@933 1445 status; newline
al@933 1446 touch $activity
al@933 1447 exit 0
al@933 1448 }
al@933 1449
al@933 1450 # cook <package> --unblock
al@933 1451 # cook <package> -ub
al@933 1452 [ -n "$unblock" -o "$2" == '-ub' ] && {
al@933 1453 action 'Unblocking package "%s"' "$1"
al@933 1454 sed -i "/^$1$/d" $blocked
al@933 1455 status; newline
al@933 1456 touch $activity
al@933 1457 exit 0
al@933 1458 }
al@933 1459
al@933 1460
al@932 1461
al@932 1462
pankso@1 1463 case "$1" in
pankso@32 1464 usage|help|-u|-h)
pankso@1 1465 usage ;;
al@728 1466
pankso@1 1467 list-wok)
al@779 1468 title 'List of %s packages in "%s"' "$ARCH" "$WOK"
pankso@642 1469 cd $WOK
al@728 1470 if [ "$ARCH" != 'i486' ]; then
pankso@643 1471 count=0
al@728 1472 for pkg in $(fgrep 'HOST_ARCH=' */receipt | egrep "$ARCH|any" | cut -d: -f1)
pankso@643 1473 do
pankso@643 1474 unset HOST_ARCH
al@951 1475 . ./$pkg
pankso@643 1476 count=$(($count + 1))
pankso@643 1477 colorize 34 "$PACKAGE"
pankso@643 1478 done
pankso@642 1479 else
pankso@643 1480 count=$(ls | wc -l)
pankso@643 1481 ls -1
pankso@642 1482 fi
al@779 1483 footer "$(_p '%s package' '%s packages' "$count" "$(colorize 32 "$count")")"
al@779 1484 ;;
al@728 1485
pankso@378 1486 activity)
pankso@378 1487 cat $activity ;;
al@728 1488
pankso@69 1489 search)
al@931 1490 # Just a simple search function, we don't need more actually.
pankso@69 1491 query="$2"
al@779 1492 title 'Search results for "%s"' "$query"
al@728 1493 cd $WOK; ls -1 | grep "$query"
al@779 1494 footer ;;
al@728 1495
pankso@1 1496 setup)
pankso@1 1497 # Setup a build environment
pankso@1 1498 check_root
al@728 1499 _ 'Cook: setup environment' | log
al@779 1500 title 'Setting up your environment'
psychomaniak@821 1501 [ -d $SLITAZ ] || mkdir -p $SLITAZ
al@596 1502 cd $SLITAZ
pankso@52 1503 init_db_files
al@728 1504 _ 'Checking for packages to install...'
pankso@397 1505 # Use setup pkgs from cross.conf or cook.conf. When cross compiling
pankso@645 1506 # ARCH-setup or 'cross check' should be used before: cook setup
pankso@397 1507 case "$ARCH" in
pankso@676 1508 arm*|x86_64)
al@899 1509 [ -x '/usr/bin/cross' ] || die 'ERROR: %s is not installed' 'cross'
al@728 1510 _ 'Using config file: %s' '/etc/slitaz/cross.conf'
pankso@397 1511 . /etc/slitaz/cross.conf ;;
pankso@397 1512 esac
pankso@397 1513 for pkg in $SETUP_PKGS; do
al@728 1514 if [ -n "$forced" ]; then
pankso@421 1515 tazpkg -gi $pkg --forced
pankso@397 1516 else
al@728 1517 [ ! -d "$INSTALLED/$pkg" ] && tazpkg get-install $pkg
pankso@397 1518 fi
pankso@397 1519 done
pankso@1 1520
pankso@1 1521 # Handle --options
pankso@1 1522 case "$2" in
al@728 1523 --wok) hg clone $WOK_URL wok || exit 1 ;;
al@728 1524 --stable) hg clone $WOK_URL-stable wok || exit 1 ;;
al@728 1525 --undigest) hg clone $WOK_URL-undigest wok || exit 1 ;;
al@728 1526 --tiny) hg clone $WOK_URL-tiny wok || exit 1 ;;
pankso@1 1527 esac
pankso@1 1528
pankso@1 1529 # SliTaz group and permissions
pankso@1 1530 if ! grep -q ^slitaz /etc/group; then
al@728 1531 _ 'Adding group "%s"' 'slitaz'
pankso@1 1532 addgroup slitaz
pankso@1 1533 fi
al@728 1534 _ 'Setting permissions for group "%s"...' 'slitaz'
pascal@277 1535 find $SLITAZ -maxdepth 2 -exec chown root.slitaz {} \;
pascal@277 1536 find $SLITAZ -maxdepth 2 -exec chmod g+w {} \;
al@779 1537 footer "$(_ 'All done, ready to cook packages :-)')" ;;
al@728 1538
pankso@395 1539 *-setup)
pankso@395 1540 # Setup for cross compiling.
al@728 1541 arch="${1%-setup}"
pankso@397 1542 check_root
pankso@644 1543 . /etc/slitaz/cook.conf
pankso@644 1544 for pkg in $CROSS_SETUP; do
al@728 1545 if [ -n "$forced" ]; then
pankso@644 1546 tazpkg -gi $pkg --forced
pankso@644 1547 else
al@728 1548 [ ! -d "$INSTALLED/$pkg" ] && tazpkg -gi $pkg
pankso@644 1549 fi
pankso@644 1550 done
al@728 1551
al@728 1552 _ 'Cook: setup %s cross environment' "$arch" | log
al@779 1553 title 'Setting up your %s cross environment' "$arch"
pankso@397 1554 init_db_files
pankso@359 1555 sed -i \
al@931 1556 -e "s|ARCH=.*|ARCH=\"$arch\"|" \
al@931 1557 -e "s|CROSS_TREE=.*|CROSS_TREE=\"/cross/$arch\"|" \
al@931 1558 -e 's|BUILD_SYSTEM=.*|BUILD_SYSTEM=i486-slitaz-linux|' \
pankso@395 1559 /etc/slitaz/cook.conf
pankso@395 1560 case "$arch" in
pankso@395 1561 arm)
al@728 1562 flags='-O2 -march=armv6'
pankso@650 1563 host="$ARCH-slitaz-linux-gnueabi" ;;
pankso@650 1564 armv6hf)
al@728 1565 flags='-O2 -march=armv6j -mfpu=vfp -mfloat-abi=hard'
pankso@650 1566 host="$ARCH-slitaz-linux-gnueabi" ;;
pankso@650 1567 armv7)
al@728 1568 flags='-Os -march=armv7-a -mfpu=vfpv3-d16 -mfloat-abi=softfp -pipe'
pankso@650 1569 host="$ARCH-slitaz-linux-gnueabi" ;;
pankso@395 1570 x86_64)
al@728 1571 flags='-O2 -mtune=generic -pipe'
pankso@650 1572 host="$ARCH-slitaz-linux" ;;
pankso@395 1573 esac
pankso@650 1574 sed -i \
al@931 1575 -e "s|CFLAGS=.*|CFLAGS=\"$flags\"|" \
al@931 1576 -e "s|HOST_SYSTEM=.*|HOST_SYSTEM=$host|" /etc/slitaz/cook.conf
pankso@359 1577 . /etc/slitaz/cook.conf
al@728 1578 sysroot="$CROSS_TREE/sysroot"
al@728 1579 tools="/cross/$arch/tools"
al@728 1580 root="$sysroot"
al@596 1581 # L10n: keep the same width of translations to get a consistent view
al@728 1582 _ 'Target arch : %s' "$ARCH"
al@728 1583 _ 'Configure args : %s' "$CONFIGURE_ARGS"
al@728 1584 _ 'Build flags : %s' "$flags"
al@728 1585 _ 'Arch sysroot : %s' "$sysroot"
al@728 1586 _ 'Tools prefix : %s' "$tools/bin"
paul@455 1587 # Tell the packages manager where to find packages.
al@728 1588 _ 'Packages DB : %s' "$root$DB"
al@728 1589 mkdir -p $root$INSTALLED
al@728 1590 cd $root$DB; rm -f *.bak
al@728 1591 for list in packages.list packages.desc packages.equiv packages.md5; do
al@728 1592 rm -f $list
al@728 1593 ln -s $SLITAZ/packages/$list $list
pankso@426 1594 done
pankso@429 1595 # We must have the cross compiled glibc-base installed or default
pankso@429 1596 # i486 package will be used as dep by tazpkg and then break the
pankso@429 1597 # cross environment
al@728 1598 if [ ! -f "$root$INSTALLED/glibc-base/receipt" ]; then
al@728 1599 colorize 36 $(_ 'WARNING: %s is not installed in sysroot' '(e)glibc-base')
pankso@429 1600 fi
pankso@426 1601 # Show GCC version or warn if not yet compiled.
al@737 1602 if [ -x "$tools/bin/$HOST_SYSTEM-gcc" ]; then
al@728 1603 _ 'Cross compiler : %s' "$HOST_SYSTEM-gcc"
pankso@359 1604 else
al@728 1605 colorize 36 $(_ 'C compiler "%s" is missing' "$HOST_SYSTEM-gcc")
al@728 1606 _ 'Run "%s" to cook a toolchain' 'cross compile'
pankso@397 1607 fi
al@779 1608 footer ;;
al@728 1609
pankso@9 1610 test)
pankso@9 1611 # Test a cook environment.
al@728 1612 _ 'Cook test: testing the cook environment' | log
pankso@9 1613 [ ! -d "$WOK" ] && exit 1
pankso@9 1614 [ ! -d "$WOK/cooktest" ] && cp -r $DATA/cooktest $WOK
pankso@9 1615 cook cooktest ;;
al@728 1616
pankso@1 1617 new)
pankso@1 1618 # Create the package folder and an empty receipt.
pankso@1 1619 pkg="$2"
al@728 1620 [ -z "$pkg" ] && usage
pankso@427 1621 newline
al@899 1622 [ -d "$WOK/$pkg" ] && die 'Package "%s" already exists.' "$pkg"
al@728 1623
al@779 1624 action 'Creating folder "%s"' "$WOK/$pkg"
al@728 1625 mkdir $WOK/$pkg; cd $WOK/$pkg; status
al@728 1626
al@779 1627 action 'Preparing the package receipt...'
pankso@1 1628 cp $DATA/receipt .
al@931 1629 sed -i "s|^PACKAGE=.*|PACKAGE=\"$pkg\"|" receipt
al@728 1630 status; newline
pankso@358 1631
pankso@196 1632 # Interactive mode, asking and seding.
pankso@196 1633 case "$3" in
paul@214 1634 --interactive|-x)
al@728 1635 _ 'Entering interactive mode...'
paul@211 1636 separator
al@728 1637 _ 'Package : %s' "$pkg"
al@728 1638
al@728 1639 _n 'Version : ' ; read answer
al@931 1640 sed -i "s|^VERSION=.*|VERSION=\"$answer\"|" receipt
al@728 1641
al@728 1642 _n 'Category : ' ; read answer
al@931 1643 sed -i "s|^CATEGORY=.*|CATEGORY=\"$answer\"|" receipt
al@728 1644
al@596 1645 # L10n: Short description
al@728 1646 _n 'Short desc : ' ; read answer
al@931 1647 sed -i "s|^SHORT_DESC=.*|SHORT_DESC=\"$answer\"|" receipt
al@728 1648
al@728 1649 _n 'Maintainer : ' ; read answer
al@931 1650 sed -i "s|^MAINTAINER=.*|MAINTAINER=\"$answer\"|" receipt
al@728 1651
al@728 1652 _n 'License : ' ; read answer
al@931 1653 sed -i "s|^LICENSE=.*|LICENSE=\"$answer\"|" receipt
al@728 1654
al@728 1655 _n 'Web site : ' ; read answer
al@931 1656 sed -i "s|^WEB_SITE=.*|WEB_SITE=\"$answer\"|" receipt
pankso@427 1657 newline
al@728 1658
pankso@196 1659 # Wget URL.
al@728 1660 _ 'Wget URL to download source tarball.'
al@728 1661 _n 'Example : ' ; echo '$GNU_MIRROR/$PACKAGE/$TARBALL'
al@728 1662 _n 'Wget url : ' ; read answer
al@931 1663 sed -i "s|^WGET_URL=.*|WGET_URL=\"$answer\"|" receipt
al@728 1664
pankso@196 1665 # Ask for a stuff dir.
al@728 1666 confirm "$(_n 'Do you need a stuff directory? (y/N)')"
al@779 1667 if [ "$?" -eq 0 ]; then
al@779 1668 action 'Creating the stuff directory...'
al@728 1669 mkdir $WOK/$pkg/stuff; status
pankso@196 1670 fi
al@728 1671
pankso@196 1672 # Ask for a description file.
al@728 1673 confirm "$(_n 'Are you going to write a description? (y/N)')"
al@779 1674 if [ "$?" -eq 0 ]; then
al@779 1675 action 'Creating the "%s" file...' 'description.txt'
al@728 1676 touch $WOK/$pkg/description.txt; status
pankso@196 1677 fi
al@728 1678
al@779 1679 footer "$(_ 'Receipt is ready to use.')" ;;
pankso@196 1680 esac ;;
al@728 1681
pankso@1 1682 list)
pankso@1 1683 # Cook a list of packages (better use the Cooker since it will order
pankso@1 1684 # packages before executing cook).
pankso@1 1685 check_root
al@899 1686 [ -z "$2" ] && die 'No list in argument.'
al@899 1687 [ -f "$2" ] || die 'List "%s" not found.' "$2"
al@728 1688
al@728 1689 _ 'Starting cooking the list "%s"' "$2" | log
al@728 1690
al@931 1691 while read pkg; do
pankso@1 1692 cook $pkg || broken
al@931 1693 done < $2
al@931 1694 ;;
al@728 1695
pankso@1 1696 clean-wok)
pankso@1 1697 check_root
al@779 1698 newline; action 'Cleaning all packages files...'
pankso@1 1699 rm -rf $WOK/*/taz $WOK/*/install $WOK/*/source
al@596 1700 status; newline ;;
al@728 1701
pankso@1 1702 clean-src)
pankso@1 1703 check_root
al@779 1704 newline; action 'Cleaning all packages sources...'
pankso@1 1705 rm -rf $WOK/*/source
al@596 1706 status; newline ;;
al@728 1707
pankso@662 1708 uncook)
pankso@662 1709 cd $WOK
pankso@662 1710 count=0
al@779 1711 title 'Checking for uncooked packages'
al@728 1712
al@951 1713 for i in *; do
pankso@664 1714 unset HOST_ARCH EXTRAVERSION
al@951 1715 [ ! -e $i/receipt ] && continue
al@951 1716 . ./$i/receipt
pankso@662 1717 # Source cooked pkg receipt to get EXTRAVERSION
al@951 1718 if [ -d "$WOK/$i/taz" ]; then
al@951 1719 cd $WOK/$i/taz/$(ls $WOK/$i/taz/ | head -n1)
pascal@950 1720 . ./receipt; cd $WOK
pankso@662 1721 fi
pankso@662 1722 case "$ARCH" in
pankso@662 1723 i486)
al@728 1724 debug "$(_ 'Package "%s"' "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg")"
al@728 1725 if [ ! -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" ]; then
pankso@662 1726 count=$(($count + 1))
al@951 1727 colorize 34 "$i"
pankso@662 1728 fi ;;
pankso@676 1729 arm*)
paul@665 1730 # Check only packages included in arch
pascal@669 1731 if echo "$HOST_ARCH" | egrep -q "$ARCH|any"; then
pankso@662 1732 # *.tazpkg
al@728 1733 if [ ! -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION-$ARCH.tazpkg" ]; then
pankso@662 1734 count=$(($count + 1))
al@951 1735 colorize 34 "$i"
pankso@662 1736 fi
pankso@662 1737 fi ;;
pankso@662 1738 esac
pankso@662 1739 done
al@728 1740
al@899 1741 if [ "$count" -gt 0 ]; then
al@779 1742 footer "$(_p '%s uncooked package' '%s uncooked packages' "$count" "$(colorize 31 "$count")")"
pankso@662 1743 else
al@728 1744 _ 'All packages are cooked :-)'
al@779 1745 newline
pankso@662 1746 fi
al@779 1747 ;;
al@728 1748
pankso@235 1749 pkgdb)
al@857 1750 # Create suitable packages list for TazPkg and only for built packages
al@857 1751 # as well as flavors files for TazLiTo. We don't need logs since we do it
paul@243 1752 # manually to ensure everything is fine before syncing the mirror.
al@987 1753 recreate_split_db
al@1081 1754 recreate_maint_db
al@857 1755 @@PREFIX@@/libexec/cookutils/pkgdb "$2"
al@742 1756 ;;
al@728 1757
al@932 1758 splitdb)
al@932 1759 # File split.db is useful for searching for split packages.
al@932 1760 recreate_split_db
al@932 1761 ;;
al@932 1762
al@1081 1763 maintdb)
al@1081 1764 # File maint.db is useful for searching maintainer's packages.
al@1081 1765 recreate_maint_db
al@1081 1766 ;;
al@1081 1767
pankso@1 1768 *)
pankso@1 1769 # Just cook and generate a package.
pankso@1 1770 check_root
pankso@1 1771 time=$(date +%s)
pankso@1 1772 pkg="$1"
pankso@1 1773 [ -z "$pkg" ] && usage
al@899 1774
al@924 1775 # Search last successful cook time in all logs from newer to older
al@924 1776 for i in '' $(seq 0 9 | sed 's|^|.|'); do
al@924 1777 [ -f "$LOGS/$pkg.log$i" ] || break
al@924 1778 lastcooktime=$(sed '/^Cook time/!d; s|.*: *\([0-9]*\)s.*|\1|' \
al@924 1779 $LOGS/$pkg.log$i 2>/dev/null | sed '$!d')
al@924 1780 [ -n "$lastcooktime" ] && break
al@924 1781 done
al@924 1782
pankso@44 1783 receipt="$WOK/$pkg/receipt"
al@728 1784 check_pkg_in_wok
al@728 1785 newline
pankso@47 1786
pankso@377 1787 unset inst
pankso@377 1788 unset_receipt
pankso@377 1789 . $receipt
al@728 1790
pankso@377 1791 # Handle cross compilation.
pankso@377 1792 case "$ARCH" in
pankso@676 1793 arm*)
al@728 1794 if [ -z "$HOST_ARCH" ]; then
al@728 1795 _ 'cook: HOST_ARCH is not set in "%s" receipt' "$pkg"
al@728 1796 error="$(_ 'package "%s" is not included in %s' "$pkg" "$ARCH")"
al@728 1797 _ 'cook: %s' "$error"
al@728 1798 [ -n "$CROSS_BUGS" ] && _ 'bugs: %s' "$CROSS_BUGS"
al@728 1799 _ 'Cook skip: %s' "$error" | log
al@728 1800 newline
al@899 1801 broken; exit 1
pankso@377 1802 fi ;;
pankso@377 1803 esac
pankso@377 1804
paul@387 1805 # Some packages are not included in some arch or fail to cross compile.
al@1024 1806 : ${HOST_ARCH=$ARCH}
al@728 1807 debug "$(_ 'Host arch %s' "$HOST_ARCH")"
pankso@675 1808 # Handle arm{v6hf,v7,..}
pankso@675 1809 if ! $(echo "$HOST_ARCH" | egrep -q "${ARCH%v[0-9]*}|any"); then
al@728 1810 _ 'cook: %s' "HOST_ARCH=$HOST_ARCH"
al@728 1811 error="$(_ "package \"%s\" doesn't cook or is not included in %s" "$pkg" "$ARCH")"
al@728 1812 _ 'cook: %s' "error"
al@728 1813 [ -n "$CROSS_BUGS" ] && _ 'bugs: %s' "$CROSS_BUGS"
al@728 1814 _ 'Cook skip: %s' "$error" | log
al@931 1815 sed -i "/^${pkg}$/d" $broken
al@728 1816 newline
al@728 1817 exit 0
pankso@377 1818 fi
pankso@377 1819
al@1090 1820 # Remove package from broken list before cooking
al@1090 1821 sed -i "/^${pkg}$/d" $broken
al@1090 1822
pankso@47 1823 # Skip blocked, 3 lines also for the Cooker.
al@899 1824 grep -q "^$pkg$" $blocked && [ "$2" != '--unblock' ] &&
al@899 1825 die 'Package "%s" is blocked' "$pkg"
pankso@47 1826
pascal@289 1827 try_aufs_chroot "$@"
pascal@289 1828
pankso@47 1829 # Log and source receipt.
pankso@16 1830 echo "cook:$pkg" > $command
al@899 1831
al@899 1832 [ -n "$lastcooktime" ] && echo "cook:$pkg $lastcooktime $(date +%s)" >> $cooktime
al@899 1833
pascal@824 1834 while read cmd duration start; do
pascal@824 1835 [ $(($start + $duration)) -lt $(date +%s) ] &&
pascal@824 1836 echo "sed -i '/^$cmd $duration/d' $cooktime"
pascal@824 1837 done < $cooktime | sh
pascal@285 1838
pascal@285 1839 # Display and log info if cook process stopped.
paul@647 1840 # FIXME: gettext not working (in single quotes) here!
al@596 1841 trap '_ "\n\nCook stopped: control-C\n\n" | \
pascal@285 1842 tee -a $LOGS/$pkg.log' INT
pascal@285 1843
al@932 1844 update_split_db
al@932 1845
pankso@1 1846 # Handle --options
pankso@1 1847 case "$2" in
slaxemulator@501 1848 --pack)
al@1090 1849 _ 'Packing %s' "<a href='cooker.cgi?pkg=${pkg//+/%2B}'>$pkg</a>" | log
al@924 1850 [ -d "$WOK/$pkg/install" ] || die 'Need to build "%s"' "$pkg"
al@924 1851 [ ! -d "$WOK/$pkg/taz" ] || rm -rf "$WOK/$pkg/taz"
al@1078 1852 [ ! -f "$LOGS/$pkg-pack.log" ] || rm -f $LOGS/$pkg-pack.log
al@912 1853 packall 2>&1 | tee -a $LOGS/$pkg-pack.log
al@1134 1854 @@PREFIX@@/libexec/cookutils/postcheck $pkg | tee -a $LOGS/$pkg-pack.log
al@924 1855 clean_log "$pkg-pack"
al@924 1856 time=$(($(date +%s) - $time))
al@924 1857 summary | sed 's|^Cook |Pack |' | tee -a $LOGS/$pkg-pack.log
al@1090 1858 gen_rss
al@992 1859 put_status $pkg Done
al@899 1860 rm -f $command
slaxemulator@501 1861 exit 0 ;;
al@989 1862
al@989 1863 --trials|-t)
al@989 1864 trials='yes' ;;
pankso@1 1865 esac
pankso@1 1866
al@1090 1867 _ 'Making %s' "<a href='cooker.cgi?pkg=${pkg//+/%2B}'>$pkg</a>" | log
al@1090 1868
pascal@793 1869 # Rotate log
pascal@793 1870 for i in $(seq 9 -1 1); do
pascal@793 1871 j=$(($i - 1))
al@837 1872 [ -e $LOGS/$pkg.log.$j ] && mv -f $LOGS/$pkg.log.$j $LOGS/$pkg.log.$i
pascal@793 1873 done
al@837 1874 [ -e $LOGS/$pkg.log ] && mv $LOGS/$pkg.log $LOGS/$pkg.log.0
al@837 1875
paul@62 1876 # Check if wanted is built now so we have separate log files.
pankso@295 1877 for wanted in $WANTED ; do
pascal@291 1878 if grep -q "^$wanted$" $blocked; then
al@899 1879 broken
al@728 1880 rm -f $command
al@899 1881 die 'WANTED package "%s" is blocked' "$wanted"
pankso@217 1882 fi
pascal@291 1883 if grep -q "^$wanted$" $broken; then
al@899 1884 broken
al@728 1885 rm -f $command
al@899 1886 die 'WANTED package "%s" is broken' "$wanted"
pankso@218 1887 fi
pascal@291 1888 if [ ! -d "$WOK/$wanted/install" ]; then
al@899 1889 cook "$wanted" || { broken; exit 1; }
pankso@137 1890 fi
pascal@291 1891 done
pankso@1 1892
pankso@1 1893 # Cook and pack or exit on error and log everything.
al@1090 1894 ( ( ( (cookit $@ 2>&1; echo $? >&3) | loglimit 50 > $LOGS/$pkg.log) 3>&1) | (read rq; exit $rq) )
al@1010 1895 rq=$? # the return code of `cookit $@` above command
al@1010 1896
al@1090 1897 if [ $rq -eq 1 ]; then
al@1090 1898 broken
al@1090 1899 fi
al@1090 1900
al@1010 1901 # Remove build dependencies both when `cookit` done or fail
pankso@15 1902 remove_deps | tee -a $LOGS/$pkg.log
al@1051 1903 timestamp job27 # removing bdeps
al@1090 1904 # cookit_quality
al@1051 1905 timestamp job28 # checking quality
al@1010 1906
al@1010 1907 # Log and stop if `cookit` fails
al@1010 1908 if [ $rq -eq 1 ]; then
al@1090 1909 debug_info "ret1" | tee -a $LOGS/$pkg.log
al@1090 1910 @@PREFIX@@/libexec/cookutils/postcheck $pkg | tee -a $LOGS/$pkg.log
al@1010 1911 put_status $pkg Failed
al@1010 1912 rm -f $command
al@1090 1913 broken
al@1090 1914 exit 1
al@1010 1915 fi
al@1010 1916
al@1010 1917 # Proceed only if `cookit` return code is zero-OK
al@1079 1918 # If instant-pack if specified, then packages already packed in the cookit()
al@1079 1919 [ "${COOKOPTS/instant-pack/}" == "$COOKOPTS" ] &&
al@904 1920 packall 2>&1 | loglimit 5 >> $LOGS/$pkg.log
al@1051 1921 timestamp job29 # packing
al@1010 1922
al@1090 1923 @@PREFIX@@/libexec/cookutils/postcheck $pkg | tee -a $LOGS/$pkg.log
al@1090 1924
pankso@1 1925 clean_log
pankso@33 1926
pankso@33 1927 # Exit if any error in packing.
al@962 1928 if [ "${COOKOPTS/skip-log-errors/}" == "$COOKOPTS" ] &&
al@962 1929 grep -Ev "(/root/.cvspass|conftest|df: /|rm: can't remove)" $LOGS/$pkg.log | \
al@962 1930 grep -Eq "(^ERROR|: No such file or directory|not remade because of errors|ake: \*\*\* .* Error)"; then
al@1090 1931 debug_info "packerr" | tee -a $LOGS/$pkg.log
al@992 1932 put_status $pkg Failed
al@728 1933 rm -f $command
al@899 1934 broken; exit 1
pankso@33 1935 fi
pankso@358 1936
pankso@310 1937 # Create an XML feed
pankso@310 1938 gen_rss
pankso@358 1939
pankso@1 1940 # Time and summary
pankso@1 1941 time=$(($(date +%s) - $time))
pankso@1 1942 summary | tee -a $LOGS/$pkg.log
pankso@427 1943 newline
pankso@1 1944
al@899 1945 # We may want to install/update (outside aufs jail!).
al@899 1946 [ -s /aufs-umount.sh ] || install_package
al@899 1947
al@992 1948 put_status $pkg Done
pankso@358 1949
al@850 1950 # Finally we DON'T WANT to build the *-dev or packages with WANTED="$pkg"
al@899 1951 # If you want automation, use the Cooker Build Bot.
al@899 1952 rm -f $command
al@1051 1953 timestamp job30 # misc. final operations
al@1051 1954 store_timestats
al@1051 1955
al@1051 1956 sed -n '/^Build dependencies to remove:/,/^$/p' $LOGS/$pkg.log \
al@1051 1957 | sed '/^Build/d; s|Removing: ||' \
al@1051 1958 | tr ' ' '\n' \
al@1051 1959 | sed '/^$/d' \
al@1051 1960 > $WOK/$pkg/.bdeps
al@1051 1961
al@899 1962 ;;
pankso@1 1963 esac
pankso@1 1964
pankso@1 1965 exit 0