cookutils annotate cook @ rev 849
cook: with splitted packages (they all should be updated anyway)
Cook all the 22 coreutils* packages at once: `cook coreutils -ws`
Cook all the 22 coreutils* packages at once: `cook coreutils -ws`
author | Aleksej Bobylev <al.bobylev@gmail.com> |
---|---|
date | Mon Dec 19 03:15:08 2016 +0200 (2016-12-19) |
parents | cc73035433ab |
children | 9e21916774fb |
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 # |
pankso@1 | 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@596 | 14 |
al@728 | 15 |
al@596 | 16 # Internationalization. |
al@596 | 17 |
al@728 | 18 export TEXTDOMAIN='cook' |
al@728 | 19 _() { local T="$1"; shift; printf "$(gettext "$T")" "$@"; echo; } |
al@728 | 20 _n() { local T="$1"; shift; printf "$(gettext "$T")" "$@"; } |
al@728 | 21 _p() { |
al@728 | 22 local S="$1" P="$2" N="$3"; shift; shift; shift; |
al@728 | 23 printf "$(ngettext "$S" "$P" "$N")" "$@"; } |
al@596 | 24 |
al@596 | 25 |
pankso@1 | 26 # |
pankso@1 | 27 # Functions |
pankso@1 | 28 # |
pankso@1 | 29 |
pankso@1 | 30 usage() { |
al@728 | 31 cat <<EOT |
pankso@1 | 32 |
al@728 | 33 $(boldify "$(_ 'Usage:')") $(_ 'cook [package|command] [list|--option]') |
pankso@1 | 34 |
al@728 | 35 $(boldify "$(_ 'Commands:')") |
al@728 | 36 usage|help $(_ 'Display this short usage.') |
al@728 | 37 setup $(_ 'Setup your build environment.') |
al@728 | 38 *-setup $(_ 'Setup a cross environment.') |
al@728 | 39 * = {arm|armv6hf|armv7|x86_64} |
al@728 | 40 test $(_ 'Test environment and cook a package.') |
al@728 | 41 list-wok $(_ 'List packages in the wok.') |
al@728 | 42 search $(_ 'Simple packages search function.') |
al@728 | 43 new $(_ 'Create a new package with a receipt.') |
al@728 | 44 list $(_ 'Cook a list of packages.') |
al@728 | 45 clean-wok $(_ 'Clean-up all packages files.') |
al@728 | 46 clean-src $(_ 'Clean-up all packages sources.') |
al@728 | 47 uncook $(_ 'Check for uncooked packages') |
al@728 | 48 pkgdb $(_ 'Create packages DB lists and flavors.') |
pankso@1 | 49 |
al@728 | 50 $(boldify "$(_ 'Options:')") |
al@728 | 51 cook <pkg> |
al@728 | 52 --clean -c $(_ 'clean the package in the wok.') |
al@728 | 53 --install -i $(_ 'cook and install the package.') |
al@849 | 54 --wsplit -ws $(_ 'cook the package and then all the splitted ones.') |
al@728 | 55 --getsrc -gs $(_ 'get the package source tarball.') |
al@728 | 56 --block -b $(_ 'block a package so cook will skip it.') |
al@728 | 57 --unblock -ub $(_ 'unblock a blocked package.') |
al@728 | 58 --cdeps $(_ 'check dependencies of cooked package.') |
al@728 | 59 --pack $(_ 'repack an already built package.') |
al@728 | 60 --debug $(_ 'display debugging messages.') |
al@728 | 61 --continue $(_ 'continue running compile_rules.') |
al@728 | 62 cook new <pkg> |
al@728 | 63 --interactive -x $(_ 'create a receipt interactively.') |
al@728 | 64 cook setup |
al@728 | 65 --wok $(_ 'clone the cooking wok from Hg repo.') |
al@728 | 66 --stable $(_ 'clone the stable wok from Hg repo.') |
al@728 | 67 --undigest $(_ 'clone the undigest wok from Hg repo.') |
al@728 | 68 --tiny $(_ 'clone the tiny SliTaz wok from Hg repo.') |
al@728 | 69 --forced $(_ 'force reinstall of chroot packages.') |
al@728 | 70 cook pkgdb |
al@728 | 71 --flavors $(_ 'create up-to-date flavors files.') |
pankso@1 | 72 |
pankso@1 | 73 EOT |
pankso@1 | 74 exit 0 |
pankso@1 | 75 } |
pankso@1 | 76 |
al@728 | 77 |
paul@62 | 78 # We don't want these escapes in web interface. |
al@728 | 79 |
pankso@1 | 80 clean_log() { |
pankso@1 | 81 sed -i -e s'|\[70G\[ \[1;32m| |' \ |
pankso@1 | 82 -e s'|\[0;39m \]||' $LOGS/$pkg.log |
pankso@1 | 83 } |
pankso@1 | 84 |
al@728 | 85 |
paul@62 | 86 # Be sure package exists in wok. |
al@728 | 87 |
pankso@1 | 88 check_pkg_in_wok() { |
pankso@1 | 89 if [ ! -d "$WOK/$pkg" ]; then |
al@728 | 90 newline; _ 'Unable to find package "%s" in the wok' "$pkg"; newline |
al@596 | 91 exit 1 |
pankso@1 | 92 fi |
pankso@1 | 93 } |
pankso@1 | 94 |
al@728 | 95 |
pankso@9 | 96 if_empty_value() { |
pankso@9 | 97 if [ -z "$value" ]; then |
al@596 | 98 # L10n: QA is quality assurance |
al@728 | 99 _ 'QA: empty variable: %s' "$var=\"\""; newline |
pankso@9 | 100 exit 1 |
pankso@9 | 101 fi |
pankso@9 | 102 } |
pankso@9 | 103 |
al@728 | 104 |
paul@62 | 105 # Initialize files used in $CACHE |
al@728 | 106 |
pankso@52 | 107 init_db_files() { |
al@728 | 108 _ 'Creating directories structure in "%s"' "$SLITAZ" |
xfred222@559 | 109 mkdir -p $WOK $PKGS $SRC $CACHE $LOGS $FEEDS |
al@728 | 110 _ 'Creating DB files in "%s"' "$CACHE" |
al@728 | 111 for f in $activity $command $broken $blocked; do |
pankso@52 | 112 touch $f |
pankso@52 | 113 done |
pankso@52 | 114 } |
pankso@52 | 115 |
al@728 | 116 |
paul@62 | 117 # QA: check a receipt consistency before building. |
al@728 | 118 |
pankso@9 | 119 receipt_quality() { |
al@728 | 120 _ 'QA: checking package receipt...' |
pankso@9 | 121 unset online |
pankso@9 | 122 if ifconfig | grep -q -A 1 "^[a-z]*[0-9]" | fgrep 'addr:'; then |
al@728 | 123 online='online' |
pankso@9 | 124 fi |
al@728 | 125 for var in PACKAGE VERSION CATEGORY SHORT_DESC MAINTAINER WEB_SITE; do |
pankso@9 | 126 unset value |
al@728 | 127 value="$(. $receipt; eval echo \$$var)" |
pankso@9 | 128 case "$var" in |
pankso@9 | 129 PACKAGE|VERSION|SHORT_DESC) |
pankso@9 | 130 if_empty_value ;; |
pankso@9 | 131 CATEGORY) |
al@728 | 132 value="${value:-empty}" |
al@596 | 133 valid="$(echo $PKGS_CATEGORIES)" # avoid newlines |
al@728 | 134 if ! echo " $valid " | grep -q " $value "; then |
al@728 | 135 _ 'QA: unknown category "%s"' "$value" |
al@728 | 136 longline "$(_ 'Please, use one of: %s' "$valid")" |
al@728 | 137 newline |
al@728 | 138 exit 1 |
pankso@9 | 139 fi ;; |
pankso@9 | 140 WEB_SITE) |
paul@62 | 141 # We don't check WGET_URL since if dl is needed it will fail. |
paul@62 | 142 # Break also if we're not online. Here error is not fatal. |
pankso@9 | 143 if_empty_value |
al@728 | 144 [ -z "$online" ] && break |
pankso@199 | 145 if ! busybox wget -T 12 -s $value 2>/dev/null; then |
al@728 | 146 _ 'QA: unable to reach "%s"' "$value" |
pankso@9 | 147 fi ;; |
pankso@9 | 148 esac |
pankso@9 | 149 done |
pankso@9 | 150 } |
pankso@9 | 151 |
al@728 | 152 |
paul@62 | 153 # Paths used in receipt and by cook itself. |
al@728 | 154 |
pankso@1 | 155 set_paths() { |
al@728 | 156 pkgdir="$WOK/$PACKAGE" |
al@841 | 157 . "$pkgdir/receipt" |
al@728 | 158 basesrc="$pkgdir/source" |
al@728 | 159 tmpsrc="$basesrc/tmp" |
al@728 | 160 src="$basesrc/$PACKAGE-$VERSION" |
al@728 | 161 taz="$pkgdir/taz" |
al@728 | 162 pack="$taz/$PACKAGE-$VERSION$EXTRAVERSION" |
al@728 | 163 fs="$pack/fs" |
al@728 | 164 stuff="$pkgdir/stuff" |
al@728 | 165 install="$pkgdir/install" |
slaxemulator@492 | 166 pkgsrc="${SOURCE:-$PACKAGE}-${KBASEVER:-$VERSION}" |
slaxemulator@492 | 167 lzma_tarball="$pkgsrc.tar.lzma" |
al@728 | 168 if [ -n "$PATCH" ]; then |
al@728 | 169 [ -z "$PTARBALL" ] && PTARBALL="$(basename $PATCH)" |
slaxemulator@492 | 170 fi |
al@728 | 171 if [ -n "$WANTED" ]; then |
al@728 | 172 basesrc="$WOK/$WANTED/source" |
al@728 | 173 src="$basesrc/$WANTED-$VERSION" |
al@728 | 174 install="$WOK/$WANTED/install" |
al@728 | 175 wanted_stuff="$WOK/$WANTED/stuff" |
pankso@1 | 176 fi |
al@728 | 177 if [ -n "$SOURCE" ]; then |
al@728 | 178 source_stuff="$WOK/$SOURCE/stuff" |
slaxemulator@456 | 179 fi |
mojo@620 | 180 # Kernel version is set from wok/linux or installed/linux-api-headers(wok-undigest) |
slaxemulator@492 | 181 if [ -f "$WOK/linux/receipt" ]; then |
al@728 | 182 kvers=$(grep ^VERSION= $WOK/linux/receipt | cut -d\" -f2) |
slaxemulator@492 | 183 kbasevers=${kvers:0:3} |
mojo@620 | 184 elif [ -f "$INSTALLED/linux-api-headers/receipt" ]; then |
al@728 | 185 kvers=$(grep ^VERSION= $INSTALLED/linux-api-headers/receipt | cut -d\" -f2) |
mojo@620 | 186 kbasevers=${kvers:0:3} |
pankso@662 | 187 fi |
pankso@662 | 188 # Python version |
slaxemulator@492 | 189 if [ -f "$WOK/python/receipt" ]; then |
al@728 | 190 pyvers=$(grep ^VERSION= $WOK/python/receipt | cut -d\" -f2) |
slaxemulator@492 | 191 fi |
al@728 | 192 # Perl version for some packages needed it |
slaxemulator@492 | 193 if [ -f "$WOK/perl/receipt" ]; then |
al@728 | 194 perlvers=$(grep ^VERSION= $WOK/perl/receipt | cut -d\" -f2) |
pankso@232 | 195 fi |
pankso@9 | 196 # Old way compatibility. |
al@728 | 197 _pkg="$install" |
pankso@1 | 198 } |
pankso@1 | 199 |
al@728 | 200 |
pankso@144 | 201 # Create source tarball when URL is a SCM. |
al@728 | 202 |
pankso@144 | 203 create_tarball() { |
slaxemulator@498 | 204 local tarball |
al@728 | 205 tarball="$pkgsrc.tar.bz2" |
al@728 | 206 [ -n "$LZMA_SRC" ] && tarball="$lzma_tarball" |
al@728 | 207 _ 'Creating tarball "%s"' "$tarball" |
al@728 | 208 if [ -n "$LZMA_SRC" ]; then |
slaxemulator@498 | 209 tar -c $pkgsrc | lzma e $SRC/$tarball -si $LZMA_SET_DIR || exit 1 |
al@728 | 210 LZMA_SRC='' |
pankso@162 | 211 else |
al@728 | 212 tar -cjf $tarball $pkgsrc || exit 1 |
al@728 | 213 mv $tarball $SRC; rm -rf $pkgsrc |
pankso@162 | 214 fi |
al@728 | 215 TARBALL="$tarball" |
pankso@144 | 216 } |
pankso@144 | 217 |
al@728 | 218 |
pankso@145 | 219 # Get package source. For SCM we are in cache so clone here and create a |
pankso@145 | 220 # tarball here. |
al@728 | 221 |
pankso@1 | 222 get_source() { |
pascal@610 | 223 local url |
pascal@610 | 224 url="$MIRROR_URL/sources/packages/${TARBALL:0:1}/$TARBALL" |
ernia@571 | 225 set_paths |
pankso@115 | 226 pwd=$(pwd) |
pankso@9 | 227 case "$WGET_URL" in |
pankso@145 | 228 http://*|ftp://*) |
pankso@9 | 229 # Busybox Wget is better! |
pascal@268 | 230 busybox wget -T 60 -c -O $SRC/$TARBALL $WGET_URL || \ |
pascal@610 | 231 busybox wget -T 60 -c -O $SRC/$TARBALL $url || \ |
al@728 | 232 (_ 'ERROR: %s' "wget $WGET_URL" && exit 1) ;; |
al@728 | 233 |
pankso@145 | 234 https://*) |
pankso@250 | 235 wget -c --no-check-certificate -O $SRC/$TARBALL $WGET_URL || \ |
pascal@610 | 236 busybox wget -T 60 -c -O $SRC/$TARBALL $url || \ |
al@728 | 237 (_ 'ERROR: %s' "wget $WGET_URL" && exit 1) ;; |
al@728 | 238 |
pankso@9 | 239 hg*|mercurial*) |
al@728 | 240 if $(echo "$WGET_URL" | fgrep -q 'hg|'); then |
pankso@9 | 241 url=${WGET_URL#hg|} |
pankso@9 | 242 else |
pankso@9 | 243 url=${WGET_URL#mercurial|} |
pankso@9 | 244 fi |
al@728 | 245 _ 'Getting source from %s...' 'Hg' |
al@728 | 246 _ 'URL: %s' "$url" |
al@728 | 247 _ 'Cloning to "%s"' "$pwd/$pkgsrc" |
al@728 | 248 if [ -n "$BRANCH" ]; then |
al@728 | 249 _ 'Hg branch: %s' "$BRANCH" |
pankso@246 | 250 hg clone $url --rev $BRANCH $pkgsrc || \ |
al@728 | 251 (_ 'ERROR: %s' "hg clone $url --rev $BRANCH" && exit 1) |
pankso@246 | 252 else |
al@728 | 253 hg clone $url $pkgsrc || (_ 'ERROR: %s' "hg clone $url" && exit 1) |
pankso@246 | 254 fi |
pankso@255 | 255 rm -rf $pkgsrc/.hg |
pankso@144 | 256 create_tarball ;; |
al@728 | 257 |
pankso@9 | 258 git*) |
pankso@61 | 259 url=${WGET_URL#git|} |
al@728 | 260 _ 'Getting source from %s...' 'Git' |
al@728 | 261 _ 'URL: %s' "$url" |
al@688 | 262 cd $SRC |
al@728 | 263 git clone $url $pkgsrc || (_ 'ERROR: %s' "git clone $url" && exit 1) |
al@728 | 264 if [ -n "$BRANCH" ]; then |
al@728 | 265 _ 'Git branch: %s' "$BRANCH" |
al@728 | 266 cd $pkgsrc; git checkout $BRANCH; cd .. |
pankso@63 | 267 fi |
al@688 | 268 cd $SRC |
pankso@144 | 269 create_tarball ;; |
al@728 | 270 |
pankso@144 | 271 cvs*) |
pankso@144 | 272 url=${WGET_URL#cvs|} |
pankso@144 | 273 mod=$PACKAGE |
al@728 | 274 [ -n "$CVS_MODULE" ] && mod=$CVS_MODULE |
al@728 | 275 _ 'Getting source from %s...' 'CVS' |
al@728 | 276 _ 'URL: %s' "$url" |
al@728 | 277 [ -n "$CVS_MODULE" ] && _ 'CVS module: %s' "$mod" |
al@728 | 278 _ 'Cloning to "%s"' "$pwd/$mod" |
pankso@144 | 279 cvs -d:$url co $mod && mv $mod $pkgsrc |
pankso@144 | 280 create_tarball ;; |
al@728 | 281 |
pankso@69 | 282 svn*|subversion*) |
pankso@159 | 283 if $(echo "$WGET_URL" | fgrep -q "svn|"); then |
pankso@146 | 284 url=${WGET_URL#svn|} |
pankso@146 | 285 else |
pankso@146 | 286 url=${WGET_URL#subversion|} |
pankso@146 | 287 fi |
al@728 | 288 _ 'Getting source from %s...' 'SVN' |
al@728 | 289 _ 'URL: %s' "$url" |
al@728 | 290 if [ -n "$BRANCH" ]; then |
pankso@161 | 291 echo t | svn co $url -r $BRANCH $pkgsrc |
pankso@161 | 292 else |
pankso@161 | 293 echo t | svn co $url $pkgsrc |
pankso@161 | 294 fi |
pankso@146 | 295 create_tarball ;; |
al@728 | 296 |
al@590 | 297 bzr*) |
al@590 | 298 url=${WGET_URL#bzr|} |
al@728 | 299 _ 'Getting source from %s...' 'bazaar' |
al@590 | 300 cd $SRC |
al@590 | 301 pkgsrc=${url#*:} |
al@728 | 302 if [ -n "$BRANCH" ]; then |
al@590 | 303 echo "bzr -Ossl.cert_reqs=none branch $url -r $BRANCH" |
al@590 | 304 bzr -Ossl.cert_reqs=none branch $url -r $BRANCH |
al@590 | 305 else |
al@590 | 306 echo "bzr -Ossl.cert_reqs=none branch $url" |
al@590 | 307 bzr -Ossl.cert_reqs=none branch $url |
al@728 | 308 cd $pkgsrc; BRANCH=$(bzr revno); cd .. |
al@596 | 309 _ "Don't forget to add to receipt:" |
al@728 | 310 echo -e "BRANCH=\"$BRANCH\"\n" |
al@590 | 311 fi |
al@590 | 312 mv $pkgsrc $pkgsrc-$BRANCH |
al@728 | 313 pkgsrc="$pkgsrc-$BRANCH" |
al@590 | 314 create_tarball ;; |
al@728 | 315 |
pankso@9 | 316 *) |
al@728 | 317 (newline; _ 'ERROR: Unable to handle "%s"' "$WGET_URL"; newline) | \ |
pankso@9 | 318 tee -a $LOGS/$PACKAGE.log |
pankso@9 | 319 exit 1 ;; |
pankso@9 | 320 esac |
pankso@1 | 321 } |
pankso@1 | 322 |
al@728 | 323 |
pankso@9 | 324 # Extract source package. |
al@728 | 325 |
pankso@1 | 326 extract_source() { |
pankso@177 | 327 if [ ! -s "$SRC/$TARBALL" ]; then |
pankso@177 | 328 local url |
slaxemulator@458 | 329 url="$MIRROR_URL/sources/packages" |
al@728 | 330 url="$url/${TARBALL:0:1}/$TARBALL" |
al@728 | 331 _ 'Getting source from %s...' 'mirror' |
al@728 | 332 _ 'URL: %s' "$url" |
al@728 | 333 busybox wget -c -P $SRC $url || _ 'ERROR: %s' "wget $url" |
pankso@177 | 334 fi |
al@728 | 335 _ 'Extracting source archive "%s"' "$TARBALL" |
pankso@1 | 336 case "$TARBALL" in |
al@728 | 337 *.tar.gz|*.tgz) tar -xzf $SRC/$TARBALL 2>/dev/null ;; |
al@728 | 338 *.tar.bz2|*.tbz|*.tbz2) tar -xjf $SRC/$TARBALL 2>/dev/null ;; |
al@728 | 339 *.tar.lzma) tar -xaf $SRC/$TARBALL ;; |
al@728 | 340 *.tar.lz|*.tlz) lzip -d < $SRC/$TARBALL | tar -xf - 2>/dev/null ;; |
al@728 | 341 *.tar) tar -xf $SRC/$TARBALL ;; |
al@728 | 342 *.zip|*.xpi) unzip -o $SRC/$TARBALL ;; |
al@728 | 343 *.xz) unxz -c $SRC/$TARBALL | tar -xf - || \ |
al@728 | 344 tar -xf $SRC/$TARBALL 2>/dev/null;; |
psychomaniak@827 | 345 *.7z) 7zr x $SRC/$TARBALL 2>/dev/null >&2 ;; |
al@728 | 346 *.Z|*.z) uncompress -c $SRC/$TARBALL | tar -xf - ;; |
al@728 | 347 *.rpm) rpm2cpio $SRC/$TARBALL | cpio -idm --quiet ;; |
al@728 | 348 *.run) /bin/sh $SRC/$TARBALL $RUN_OPTS ;; |
al@728 | 349 *) cp $SRC/$TARBALL $(pwd) ;; |
pankso@1 | 350 esac |
pankso@1 | 351 } |
pankso@1 | 352 |
al@728 | 353 |
al@834 | 354 # Display time. |
al@834 | 355 |
al@834 | 356 disp_time() { |
al@834 | 357 local sec div min |
al@834 | 358 sec="$1" |
al@834 | 359 div=$(( ($1 + 30) / 60)) |
al@834 | 360 case $div in |
al@834 | 361 0) min='';; |
al@834 | 362 # L10n: 'm' is for minutes (approximate cooking time) |
al@834 | 363 *) min=$(_n ' ~ %dm' "$div");; |
al@834 | 364 esac |
al@834 | 365 |
al@834 | 366 # L10n: 's' is for seconds (cooking time) |
al@834 | 367 _ '%ds%s' "$sec" "$min" |
al@834 | 368 } |
al@834 | 369 |
al@834 | 370 |
pankso@9 | 371 # Display cooked package summary. |
al@728 | 372 |
pankso@1 | 373 summary() { |
al@841 | 374 set_paths |
pankso@1 | 375 cd $WOK/$pkg |
slaxemulator@499 | 376 [ -d $WOK/$pkg/install ] && prod=$(du -sh $WOK/$pkg/install | awk '{print $1}' 2>/dev/null) |
slaxemulator@499 | 377 [ -d $WOK/$pkg/source ] && srcdir=$(du -sh $WOK/$pkg/source | awk '{print $1}' 2>/dev/null) |
slaxemulator@499 | 378 fs=$(du -sh $WOK/$pkg/taz/* | awk '{print $1}') |
al@836 | 379 size=$(ls -lh $PKGS/$pkg-${VERSION}*.tazpkg | awk '{print $5}') |
slaxemulator@499 | 380 files=$(cat $WOK/$pkg/taz/$pkg-*/files.list | wc -l) |
al@728 | 381 [ -n "$TARBALL" ] && srcsize=$(du -sh $SRC/$TARBALL | awk '{print $1}') |
al@728 | 382 |
al@728 | 383 _ 'Summary for: %s' "$PACKAGE $VERSION" |
pankso@1 | 384 separator |
al@728 | 385 |
al@596 | 386 # L10n: keep the same width of translations to get a consistent view |
al@728 | 387 [ -n "$srcdir" ] && _ 'Source dir : %s' "$srcdir" |
al@728 | 388 [ -n "$TARBALL" ] && _ 'Src file : %s' "$TARBALL" |
al@728 | 389 [ -n "$srcsize" ] && _ 'Src size : %s' "$srcsize" |
al@728 | 390 [ -n "$prod" ] && _ 'Produced : %s' "$prod" |
al@728 | 391 _ 'Packed : %s' "$fs" |
al@728 | 392 _ 'Compressed : %s' "$size" |
al@728 | 393 _ 'Files : %s' "$files" |
al@834 | 394 _ 'Cook time : %s' "$(disp_time "$time")" |
al@728 | 395 _ 'Cook date : %s' "$(date "$(_ '+%%F %%R')")" |
al@728 | 396 _ 'Host arch : %s' "$ARCH" |
al@596 | 397 separator |
pankso@1 | 398 } |
pankso@1 | 399 |
al@728 | 400 |
paul@62 | 401 # Display debugging error info. |
al@728 | 402 |
pankso@15 | 403 debug_info() { |
al@779 | 404 title 'Debug information' |
al@596 | 405 # L10n: specify your format of date and time (to help: man date) |
al@596 | 406 # L10n: not bad one is '+%x %R' |
al@728 | 407 _ 'Cook date: %s' "$(date "$(_ '+%%F %%R')")" |
pascal@757 | 408 [ "$time" ] && _ 'Cook time: %ds' "$(($(date +%s) - $time))" |
al@596 | 409 # L10n: Please, translate all messages beginning with ERROR in a same way |
al@728 | 410 lerror=$(_n 'ERROR') |
pankso@76 | 411 for error in \ |
al@728 | 412 ERROR $lerror 'No package' "cp: can't" "can't open" "can't cd" \ |
al@728 | 413 'error:' 'fatal error:' 'undefined reference to' \ |
al@728 | 414 'Unable to connect to' 'link: cannot find the library' \ |
pascal@797 | 415 'CMake Error' ': No such file or directory' \ |
paul@798 | 416 'Could not read symbols: File in wrong format' |
pankso@34 | 417 do |
pankso@34 | 418 fgrep "$error" $LOGS/$pkg.log |
pascal@625 | 419 done > $LOGS/$pkg.log.debug_info 2>&1 |
pascal@625 | 420 cat $LOGS/$pkg.log.debug_info |
pascal@625 | 421 rm -f $LOGS/$pkg.log.debug_info |
al@779 | 422 footer |
pankso@15 | 423 } |
pankso@15 | 424 |
al@728 | 425 |
pankso@1 | 426 # Copy all generic files (locale, pixmaps, .desktop). We use standard paths, |
pankso@1 | 427 # so some packages need to copy these files with the receipt and genpkg_rules. |
al@728 | 428 |
al@728 | 429 copy_generic_files() { |
pankso@1 | 430 # $LOCALE is set in cook.conf |
al@728 | 431 if [ -n "$LOCALE" -a -z "$WANTED" ]; then |
pankso@260 | 432 if [ -d "$install/usr/share/locale" ]; then |
pankso@1 | 433 mkdir -p $fs/usr/share/locale |
al@728 | 434 for i in $LOCALE; do |
pankso@260 | 435 if [ -d "$install/usr/share/locale/$i" ]; then |
pankso@260 | 436 cp -a $install/usr/share/locale/$i $fs/usr/share/locale |
pankso@1 | 437 fi |
pankso@1 | 438 done |
pankso@1 | 439 fi |
pankso@1 | 440 fi |
pankso@1 | 441 |
al@834 | 442 # Generic pixmaps copy can be disabled with COOKOPTS="!pixmaps" (or GENERIC_PIXMAPS="no") |
al@834 | 443 if [ "${COOKOPTS/!pixmaps/}" == "$COOKOPTS" -a "$GENERIC_PIXMAPS" != 'no' ]; then |
pankso@260 | 444 if [ -d "$install/usr/share/pixmaps" ]; then |
pankso@1 | 445 mkdir -p $fs/usr/share/pixmaps |
slaxemulator@500 | 446 if [ -f "$install/usr/share/pixmaps/$PACKAGE.png" ]; then |
slaxemulator@500 | 447 cp -a $install/usr/share/pixmaps/$PACKAGE.png \ |
slaxemulator@500 | 448 $fs/usr/share/pixmaps |
slaxemulator@500 | 449 elif [ -f "$install/usr/share/pixmaps/$PACKAGE.xpm" ]; then |
slaxemulator@500 | 450 cp -a $install/usr/share/pixmaps/$PACKAGE.xpm \ |
slaxemulator@500 | 451 $fs/usr/share/pixmaps |
slaxemulator@500 | 452 fi |
pankso@1 | 453 fi |
pankso@1 | 454 |
pankso@1 | 455 # Custom or homemade PNG pixmap can be in stuff. |
pankso@1 | 456 if [ -f "$stuff/$PACKAGE.png" ]; then |
pankso@1 | 457 mkdir -p $fs/usr/share/pixmaps |
pankso@1 | 458 cp -a $stuff/$PACKAGE.png $fs/usr/share/pixmaps |
pankso@1 | 459 fi |
pankso@1 | 460 fi |
pankso@1 | 461 |
pankso@1 | 462 # Desktop entry (.desktop). |
al@834 | 463 # Generic desktop entry copy can be disabled with COOKOPTS="!menus" (or GENERIC_MENUS="no") |
al@834 | 464 if [ "${COOKOPTS/!menus/}" == "$COOKOPTS" -a "$GENERIC_MENUS" != 'no' ]; then |
al@728 | 465 if [ -d "$install/usr/share/applications" ] && [ -z "$WANTED" ]; then |
slaxemulator@500 | 466 mkdir -p $fs/usr/share |
erjo@284 | 467 cp -a $install/usr/share/applications $fs/usr/share |
erjo@284 | 468 fi |
pankso@1 | 469 fi |
pankso@1 | 470 |
pankso@1 | 471 # Homemade desktop file(s) can be in stuff. |
pankso@1 | 472 if [ -d "$stuff/applications" ]; then |
pankso@1 | 473 mkdir -p $fs/usr/share |
pankso@1 | 474 cp -a $stuff/applications $fs/usr/share |
pankso@1 | 475 fi |
pankso@1 | 476 if [ -f "$stuff/$PACKAGE.desktop" ]; then |
pankso@1 | 477 mkdir -p $fs/usr/share/applications |
pankso@1 | 478 cp -a $stuff/$PACKAGE.desktop $fs/usr/share/applications |
pankso@1 | 479 fi |
pankso@662 | 480 |
slaxemulator@500 | 481 # Add custom licenses |
slaxemulator@500 | 482 if [ -d "$stuff/licenses" ]; then |
slaxemulator@500 | 483 mkdir -p $fs/usr/share/licenses |
slaxemulator@500 | 484 cp -a $stuff/licenses $fs/usr/share/licenses/$PACKAGE |
slaxemulator@500 | 485 fi |
pankso@1 | 486 } |
pankso@1 | 487 |
al@728 | 488 |
al@838 | 489 # Get list of supported locales... |
al@838 | 490 |
al@838 | 491 get_supported_locales() { |
al@838 | 492 local lpc='/slitaz-i18n/stuff/locale-pack.conf' LOCALE_PACK |
al@838 | 493 if [ -e "$WOK$lpc" ]; then |
al@838 | 494 # ... from package in the local wok |
al@838 | 495 . "$WOK$lpc" |
al@838 | 496 else |
al@838 | 497 # ... from Hg |
al@838 | 498 temp_conf=$(mktemp) |
al@838 | 499 wget -q -O $temp_conf -T 10 "http://hg.slitaz.org/wok/raw-file/tip$lpc" |
al@838 | 500 if [ -s $temp_conf ]; then |
al@838 | 501 . $temp_conf |
al@838 | 502 else |
al@838 | 503 # Give up and use hardcoded list |
al@838 | 504 LOCALE_PACK="ar ca cs da de el en es fi fr hr hu id is it ja nb nl nn pl pt \ |
al@838 | 505 pt_BR ro ru sl sv tr uk zh_CN zh_TW" |
al@838 | 506 fi |
al@838 | 507 rm $temp_conf |
al@838 | 508 fi |
al@838 | 509 echo $LOCALE_PACK |
al@838 | 510 } |
al@838 | 511 |
al@838 | 512 |
al@769 | 513 # Fix common errors and warnings in the .desktop files |
al@834 | 514 # Fixing can be disabled with COOKOPTS="!fixdesktops" |
al@769 | 515 |
al@769 | 516 fix_desktop_files() { |
al@834 | 517 [ "${COOKOPTS/!fixdesktops/}" != "$COOKOPTS" ] && return |
al@833 | 518 [ -z "$(find $install -type f -name '*.desktop')" ] && return |
al@769 | 519 |
al@838 | 520 local size0=$(find $install -type f -name '*.desktop' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@838 | 521 local time0=$(date +%s) |
al@838 | 522 |
al@769 | 523 if [ -n "$QA" -a -z "$(which desktop-file-validate)" ]; then |
al@779 | 524 tazpkg -gi desktop-file-utils-extra --quiet |
al@769 | 525 fi |
al@769 | 526 |
al@838 | 527 # The variable $LOCALE is set in cook.conf and may be overridden in the receipt. |
al@838 | 528 # Default value is "" (empty). That means for us that we'll use the full |
al@838 | 529 # list of supported locales here. |
al@838 | 530 [ -z "$LOCALE" ] && LOCALE=$(get_supported_locales) |
al@838 | 531 |
al@833 | 532 for desktop in $(find $install -type f -name '*.desktop'); do |
al@770 | 533 cp "$desktop" "$desktop.orig" |
al@770 | 534 |
al@769 | 535 # Sort out .desktop file (is prerequisite to correct working of `fix-desktop-file`) |
al@769 | 536 sdft "$desktop" -i |
al@769 | 537 |
al@769 | 538 # Fix common errors in .desktop file |
al@769 | 539 fix-desktop-file "$desktop" |
al@769 | 540 |
al@838 | 541 # Strip unsupported locales from .desktop file |
al@838 | 542 [ "${COOKOPTS/!i18nz/}" == "$COOKOPTS" ] && |
al@838 | 543 sdft "$desktop" -i -k "$LOCALE" |
al@838 | 544 |
al@838 | 545 # Extra-strip |
al@838 | 546 [ "${COOKOPTS/!extradesktops/}" == "$COOKOPTS" ] && |
al@838 | 547 sdft "$desktop" -i -g -x -tf -r 'Keywords*' -o |
al@838 | 548 |
al@769 | 549 if [ -n "$QA" ]; then |
al@769 | 550 # Check the rest of errors, warnings and tips |
al@769 | 551 _ 'QA: Checking %s...' "$(basename $desktop)" |
al@769 | 552 diff "$desktop.orig" "$desktop" |
al@781 | 553 desktop-file-validate "$desktop" | busybox fold -s |
al@769 | 554 echo |
al@769 | 555 fi |
al@769 | 556 |
al@769 | 557 rm "$desktop.orig" |
al@769 | 558 done |
al@838 | 559 |
al@838 | 560 local size1=$(find $install -type f -name '*.desktop' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@838 | 561 local time1=$(date +%s) |
al@838 | 562 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@769 | 563 } |
al@769 | 564 |
al@769 | 565 |
al@834 | 566 # Compressor mini summary |
al@834 | 567 |
al@834 | 568 comp_summary() { |
al@837 | 569 [ "$3" -eq 0 ] && return |
al@834 | 570 local time=$(($2 - $1)) |
al@834 | 571 local saving=$(( ($3 - $4) / 1024 )) |
al@834 | 572 _ ' Time: %s. Size: %s B -> %s B. Save: %s KB' "$(disp_time $time)" "$3" "$4" "$saving" |
al@834 | 573 } |
al@834 | 574 |
al@834 | 575 |
al@596 | 576 # Find and strip: --strip-all (-s) or --strip-debug on static libs as well |
paul@647 | 577 # as removing unneeded files like in Python packages. Cross compiled binaries |
pankso@415 | 578 # must be stripped with cross-tools aka $ARCH-slitaz-*-strip |
al@834 | 579 # Stripping can be disabled with COOKOPTS="!strip" |
al@728 | 580 |
pankso@421 | 581 strip_package() { |
al@834 | 582 [ "${COOKOPTS/!strip/}" != "$COOKOPTS" ] && return |
al@834 | 583 |
pankso@415 | 584 case "$ARCH" in |
al@737 | 585 arm*|x86_64) export STRIP="$HOST_SYSTEM-strip" ;; |
al@728 | 586 *) export STRIP='strip' ;; |
pankso@415 | 587 esac |
al@779 | 588 action 'Executing strip on all files...' |
al@834 | 589 local size0=0 size1=0 oldsize newsize |
al@834 | 590 local time0=$(date +%s) |
al@834 | 591 |
al@834 | 592 # Strip executable files |
al@728 | 593 for dir in $fs/bin $fs/sbin $fs/usr/bin $fs/usr/sbin $fs/usr/games; do |
pankso@1 | 594 if [ -d "$dir" ]; then |
al@834 | 595 oldsize=$(find $dir -type f -exec ls -l '{}' \; | awk '{s+=$5}END{print s}') |
pankso@414 | 596 find $dir -type f -exec $STRIP -s '{}' 2>/dev/null \; |
al@834 | 597 newsize=$(find $dir -type f -exec ls -l '{}' \; | awk '{s+=$5}END{print s}') |
al@834 | 598 size0=$((size0 + oldsize)); size1=$((size1 + newsize)) |
pankso@1 | 599 fi |
pankso@1 | 600 done |
al@834 | 601 |
al@834 | 602 # Strip shared and static libraries |
al@834 | 603 # Remove Python *.pyc and *.pyo, Perl perllocal.pod and .packlist |
al@834 | 604 oldsize=$(find $fs -type f \( \ |
al@834 | 605 -name '*.so*' -o -name '*.a' -o \ |
al@834 | 606 -name '*.pyc' -o -name '*.pyo' -o \ |
al@834 | 607 -name 'perllocal.pod' -o -name '.packlist' \) -exec ls -l '{}' \; | awk '{s+=$5}END{print s}') |
al@834 | 608 |
al@728 | 609 find $fs -name '*.so*' -exec $STRIP -s '{}' 2>/dev/null \; |
al@728 | 610 find $fs -name '*.a' -exec $STRIP --strip-debug '{}' 2>/dev/null \; |
al@834 | 611 find $fs -type f \( -name '*.pyc' -o -name '*.pyo' \) -delete 2>/dev/null |
al@834 | 612 find $fs -type f \( -name 'perllocal.pod' -o -name '.packlist' \) -delete 2>/dev/null |
al@834 | 613 |
al@834 | 614 newsize=$(find $fs -type f \( \ |
al@834 | 615 -name '*.so*' -o -name '*.a' -o \) -exec ls -l '{}' \; | awk '{s+=$5}END{print s}') |
al@834 | 616 |
al@834 | 617 size0=$((size0 + oldsize)); size1=$((size1 + newsize)) |
al@834 | 618 |
al@834 | 619 local time1=$(date +%s) |
pankso@1 | 620 status |
al@834 | 621 comp_summary "$time0" "$time1" "$size0" "$size1" |
pankso@1 | 622 } |
pankso@1 | 623 |
al@728 | 624 |
al@838 | 625 # Strip unsupported locales (.mo files) |
al@838 | 626 |
al@838 | 627 strip_mo_i18n() { |
al@838 | 628 [ "${COOKOPTS/!i18nz/}" != "$COOKOPTS" ] && return |
al@838 | 629 |
al@842 | 630 [ ! -d "$fs/usr/share/locale" ] && return |
al@841 | 631 [ -z "$(find $fs/usr/share/locale -type f -name '*.mo')" ] && return |
al@838 | 632 |
al@846 | 633 action 'Thin out translation files...' |
al@842 | 634 local size0=$(find $fs/usr/share/locale -type f -name '*.mo' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@838 | 635 local time0=$(date +%s) |
al@838 | 636 |
al@838 | 637 # The variable $LOCALE is set in cook.conf and may be overridden in the receipt. |
al@838 | 638 # Default value is "" (empty). That means for us that we'll use the full |
al@838 | 639 # list of supported locales here. |
al@838 | 640 [ -z "$LOCALE" ] && LOCALE=$(get_supported_locales) |
al@838 | 641 |
al@838 | 642 # Existing locales |
al@838 | 643 elocales=" $(ls -1 "$fs/usr/share/locale" | tr '\n' ' ') " |
al@838 | 644 |
al@838 | 645 # Thin out the list of existing locales. At the end there will be only locales that need |
al@838 | 646 # to delete (and the garbage like '_AU', _US', '_BR' leaving from 'en_AU', 'en_US', 'pt_BR'...) |
al@838 | 647 for keep_locale in $LOCALE; do |
al@838 | 648 elocales=${elocales//$keep_locale} |
al@838 | 649 done |
al@838 | 650 |
al@838 | 651 # Remove the unsupported locales |
al@838 | 652 for rem_locale in $elocales; do |
al@838 | 653 [ -d "$fs/usr/share/locale/$rem_locale" ] && |
al@838 | 654 rm -r "$fs/usr/share/locale/$rem_locale" |
al@838 | 655 done |
al@838 | 656 |
al@838 | 657 local size1=$(find $fs -type f -name '*.mo' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@838 | 658 local time1=$(date +%s) |
al@838 | 659 status |
al@838 | 660 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@838 | 661 } |
al@838 | 662 |
al@838 | 663 |
paul@847 | 664 # Normalize all *.mo files: unconditionally convert to UTF-8; remove strings that are not really added |
paul@847 | 665 # to the translation (msgid = msgstr) |
al@846 | 666 # Normalization can be disabled with COOKOPTS="!monorm" |
al@846 | 667 |
al@846 | 668 normalize_mo() { |
al@846 | 669 [ "${COOKOPTS/!monorm/}" != "$COOKOPTS" ] && return |
al@846 | 670 [ -z "$(find $install -type f -name '*.mo')" ] && return |
al@846 | 671 |
al@846 | 672 action 'Normalizing mo files...' |
al@846 | 673 local size0=$(find $install -type f -name '*.mo' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@846 | 674 local time0=$(date +%s) |
al@846 | 675 |
al@846 | 676 # Gettext functions: msgunfmt, msguniq, msgconv, msgfmt |
al@846 | 677 tazpkg -gi gettext --quiet |
al@846 | 678 # Gconv modules (convert to UTF-8) |
al@846 | 679 tazpkg -gi glibc-locale --quiet |
al@846 | 680 |
al@846 | 681 # Process all existing *.mo files |
al@846 | 682 for mo in $(find "$install" -type f -name '*.mo'); do |
al@846 | 683 tmpfile="$(mktemp)" |
al@846 | 684 |
al@846 | 685 msgunfmt "$mo" | msguniq | msgconv -o "$tmpfile" -t 'UTF-8' |
al@846 | 686 # add newline |
al@846 | 687 echo >> "$tmpfile" |
al@846 | 688 |
al@846 | 689 # get Plural-Forms |
al@846 | 690 awk ' |
al@846 | 691 BEGIN { skip = ""; } |
al@846 | 692 { |
al@846 | 693 if (! skip) { |
al@846 | 694 s = $0; |
al@846 | 695 gsub(/^[^\"]*\"/, "", s); |
al@846 | 696 gsub(/\"$/, "", s); |
al@846 | 697 printf("%s", s); |
al@846 | 698 } |
al@846 | 699 if (! $0) skip = "yes"; |
al@846 | 700 } |
al@846 | 701 ' "$tmpfile" | sed 's|\\n|\n|g' | grep "^Plural-Forms:" > "$tmpfile.pf" |
al@846 | 702 |
al@846 | 703 if ! grep -q 'msgid_plural' "$tmpfile"; then |
al@846 | 704 echo > "$tmpfile.pf" |
al@846 | 705 fi |
al@846 | 706 |
al@846 | 707 # main |
al@846 | 708 awk -v pf="$(cat "$tmpfile.pf")" ' |
al@846 | 709 function clean() { |
al@846 | 710 mode = msgctxt = msgid = msgid_plural = msgstr = msgstr0 = msgstr1 = msgstr2 = msgstr3 = msgstr4 = msgstr5 = ""; |
al@846 | 711 } |
al@846 | 712 |
al@846 | 713 function getstring() { |
al@846 | 714 # Skip unquoted words at the beginning (msgid, msgstr...) and get string from inside quotes |
al@846 | 715 s = $0; |
al@846 | 716 gsub(/^[^\"]*\"/, "", s); |
al@846 | 717 gsub(/\"$/, "", s); |
al@846 | 718 return s; |
al@846 | 719 } |
al@846 | 720 |
al@846 | 721 BEGIN { |
al@846 | 722 printf("msgid \"\"\nmsgstr \"\"\n\"Content-Type: text/plain; charset=UTF-8\\n\"\n"); |
al@846 | 723 if (pf) |
al@846 | 724 printf("\"%s\\n\"\n", pf); |
al@846 | 725 printf("\n"); |
al@846 | 726 skip = 1; |
al@846 | 727 clean(); |
al@846 | 728 } |
al@846 | 729 |
al@846 | 730 { |
al@846 | 731 # Skip the entire header |
al@846 | 732 if (!skip) { |
al@846 | 733 if ($1 == "msgctxt" || $1 == "msgid" || $1 == "msgstr" || $1 == "msgid_plural") |
al@846 | 734 mode = $1; |
al@846 | 735 if ($1 == "msgstr[0]") mode = "msgstr0"; |
al@846 | 736 if ($1 == "msgstr[1]") mode = "msgstr1"; |
al@846 | 737 if ($1 == "msgstr[2]") mode = "msgstr2"; |
al@846 | 738 if ($1 == "msgstr[3]") mode = "msgstr3"; |
al@846 | 739 if ($1 == "msgstr[4]") mode = "msgstr4"; |
al@846 | 740 if ($1 == "msgstr[5]") mode = "msgstr5"; |
al@846 | 741 |
al@846 | 742 if (mode == "msgctxt") msgctxt = msgctxt getstring(); |
al@846 | 743 if (mode == "msgid") msgid = msgid getstring(); |
al@846 | 744 if (mode == "msgstr") msgstr = msgstr getstring(); |
al@846 | 745 if (mode == "msgid_plural") msgid_plural = msgid_plural getstring(); |
al@846 | 746 if (mode == "msgstr0") msgstr0 = msgstr0 getstring(); |
al@846 | 747 if (mode == "msgstr1") msgstr1 = msgstr1 getstring(); |
al@846 | 748 if (mode == "msgstr2") msgstr2 = msgstr2 getstring(); |
al@846 | 749 if (mode == "msgstr3") msgstr3 = msgstr3 getstring(); |
al@846 | 750 if (mode == "msgstr4") msgstr4 = msgstr4 getstring(); |
al@846 | 751 if (mode == "msgstr5") msgstr5 = msgstr5 getstring(); |
al@846 | 752 |
al@846 | 753 if (! $0) { |
al@846 | 754 if (msgid != msgstr) { |
al@846 | 755 if (msgctxt) printf("msgctxt \"%s\"\n", msgctxt); |
al@846 | 756 printf("msgid \"%s\"\n", msgid); |
al@846 | 757 if (msgid_plural) printf("msgid_plural \"%s\"\n", msgid_plural); |
al@846 | 758 if (msgstr) printf("msgstr \"%s\"\n", msgstr); |
al@846 | 759 if (msgstr0) printf("msgstr[0] \"%s\"\n", msgstr0); |
al@846 | 760 if (msgstr1) printf("msgstr[1] \"%s\"\n", msgstr1); |
al@846 | 761 if (msgstr2) printf("msgstr[2] \"%s\"\n", msgstr2); |
al@846 | 762 if (msgstr3) printf("msgstr[3] \"%s\"\n", msgstr3); |
al@846 | 763 if (msgstr4) printf("msgstr[4] \"%s\"\n", msgstr4); |
al@846 | 764 if (msgstr5) printf("msgstr[5] \"%s\"\n", msgstr5); |
al@846 | 765 printf("\n"); |
al@846 | 766 } |
al@846 | 767 clean(); |
al@846 | 768 } |
al@846 | 769 } |
al@846 | 770 if ($0 == "") skip = ""; |
al@846 | 771 } |
al@846 | 772 ' "$tmpfile" > "$tmpfile.awk" |
al@846 | 773 |
al@846 | 774 msgfmt "$tmpfile.awk" -o "$tmpfile.mo" |
al@846 | 775 |
al@846 | 776 if [ -s "$tmpfile.mo" ]; then |
al@846 | 777 rm "$mo"; mv "$tmpfile.mo" "$mo" |
al@846 | 778 else |
al@846 | 779 _ 'Error processing %s' "$mo" |
al@846 | 780 [ -e "$tmpfile.mo" ] && rm "$tmpfile.mo" |
al@846 | 781 fi |
al@846 | 782 |
al@846 | 783 # Clean |
al@846 | 784 rm "$tmpfile" "$tmpfile.pf" "$tmpfile.awk" |
al@846 | 785 done |
al@846 | 786 |
al@846 | 787 local size1=$(find $install -type f -name '*.mo' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@846 | 788 local time1=$(date +%s) |
al@846 | 789 status |
al@846 | 790 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@846 | 791 } |
al@846 | 792 |
al@846 | 793 |
al@848 | 794 # Remove files provided by splitted packages |
al@848 | 795 # For example: |
al@848 | 796 # 1. Package "pkg-main": |
al@848 | 797 # SPLIT="pkg-1 pkg-2 pkg-extra" |
al@848 | 798 # 2. Package="pkg-extra": |
al@848 | 799 # WANTED="pkg-main" |
al@848 | 800 # BUILD_DEPENDS="pkg-1 pkg-2" |
al@848 | 801 # cook_copy_folders usr |
al@848 | 802 # cook_split_rm $BUILD_DEPENDS |
al@848 | 803 |
al@848 | 804 cook_split_rm() { |
al@848 | 805 for i in $@; do |
al@848 | 806 action 'Remove files provided by splitted package %s...' "$i" |
al@848 | 807 while read j; do |
al@848 | 808 [ -f "$fs$j" -o -h "$fs$j" ] && rm $fs$j |
al@848 | 809 rmdir "$(dirname "$fs$j")" 2>/dev/null |
al@848 | 810 done < $WOK/$i/taz/$i-$VERSION/files.list |
al@848 | 811 :; status |
al@848 | 812 done |
al@848 | 813 } |
al@848 | 814 |
al@848 | 815 |
al@769 | 816 # Update installed.cook.diff |
al@769 | 817 |
al@769 | 818 update_installed_cook_diff() { |
al@769 | 819 # If a cook failed deps are removed. |
al@769 | 820 cd $root$INSTALLED; ls -1 > $CACHE/installed.cook |
al@769 | 821 cd $CACHE |
al@769 | 822 [ "$1" == 'force' -o ! -s '/tmp/installed.cook.diff' ] && \ |
al@769 | 823 busybox diff installed.list installed.cook > /tmp/installed.cook.diff |
al@769 | 824 deps=$(cat /tmp/installed.cook.diff | grep ^+[a-zA-Z0-9] | wc -l) |
al@769 | 825 } |
al@769 | 826 |
al@769 | 827 |
pankso@8 | 828 # Remove installed deps. |
al@728 | 829 |
pankso@8 | 830 remove_deps() { |
pankso@8 | 831 # Now remove installed build deps. |
al@728 | 832 diff='/tmp/installed.cook.diff' |
pascal@609 | 833 if [ -s $diff ]; then |
pankso@113 | 834 deps=$(cat $diff | grep ^+[a-zA-Z0-9] | sed s/^+//) |
pankso@113 | 835 nb=$(cat $diff | grep ^+[a-zA-Z0-9] | wc -l) |
al@728 | 836 _n 'Build dependencies to remove:'; echo " $nb" |
al@728 | 837 [ -n "$root" ] && echo "root=\"$root\"" |
al@728 | 838 _n 'Removing:' |
al@728 | 839 for dep in $deps; do |
pankso@8 | 840 echo -n " $dep" |
pankso@426 | 841 echo 'y' | tazpkg remove $dep --root=$root >/dev/null |
pankso@8 | 842 done |
al@596 | 843 newline; newline |
pankso@113 | 844 # Keep the last diff for debug and info. |
pascal@609 | 845 mv -f $diff $CACHE/installed.diff |
pankso@1 | 846 fi |
pankso@1 | 847 } |
pankso@1 | 848 |
al@834 | 849 |
al@809 | 850 # Function to compress all man pages |
al@834 | 851 # Compressing can be disabled with COOKOPTS="!manz" |
al@809 | 852 |
al@809 | 853 compress_manpages() { |
al@834 | 854 [ "${COOKOPTS/!manz/}" != "$COOKOPTS" ] && return |
al@834 | 855 |
al@818 | 856 case "$ARCH" in |
al@818 | 857 arm*) return;; # While SliTaz-arm miss `advancecomp` |
al@818 | 858 esac |
al@809 | 859 local manpath="$install/usr/share/man" dest link |
al@809 | 860 [ -d "$manpath" ] || return |
al@818 | 861 |
al@809 | 862 action 'Compressing man pages...' |
al@809 | 863 |
al@834 | 864 local size0=$(find $install/usr/share/man -type f -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 865 local time0=$(date +%s) |
al@809 | 866 # We'll use only Gzip compression, so decompress other formats first |
al@809 | 867 find $manpath -type f -name '*.bz2' -exec bunzip2 \{\} \; |
al@809 | 868 find $manpath -type f -name '*.xz' -exec unxz \{\} \; |
al@809 | 869 |
al@809 | 870 # Fast compress with gzip |
al@843 | 871 find $manpath -type f -name '*.[1-9]*' -exec gzip \{\} \; |
al@809 | 872 |
al@809 | 873 # Fix symlinks |
al@809 | 874 for i in $(find $install/usr/share/man -type l); do |
al@809 | 875 dest=$(readlink $i | sed 's|\.[gbx]z2*$||') |
al@809 | 876 link=$(echo $i | sed 's|\.[gbx]z2*$||') |
al@809 | 877 rm $i; ln -s $dest.gz $link.gz |
al@809 | 878 done |
al@809 | 879 |
al@809 | 880 # Recompress with advdef (it can't compress, only recompress) |
al@809 | 881 tazpkg -gi advancecomp --quiet |
al@809 | 882 for i in $(find $install/usr/share/man -type f); do |
al@809 | 883 advdef -z4q $i |
al@809 | 884 done |
al@809 | 885 |
al@834 | 886 local size1=$(find $install/usr/share/man -type f -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 887 local time1=$(date +%s) |
al@809 | 888 status |
al@834 | 889 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@834 | 890 } |
al@834 | 891 |
al@834 | 892 |
al@834 | 893 # Function used after compile_rules() to compress all png images |
al@834 | 894 # Compressing can be disabled with COOKOPTS="!pngz" |
al@834 | 895 |
al@846 | 896 compress_png() { |
al@834 | 897 [ "${COOKOPTS/!pngz/}" != "$COOKOPTS" ] && return |
al@834 | 898 case "$ARCH" in |
al@834 | 899 arm*) return;; # While SliTaz-arm miss `pngquant` and `optipng` |
al@834 | 900 esac |
al@834 | 901 [ -z "$(find $install -type f -name '*.png')" ] && return |
al@834 | 902 |
al@834 | 903 action 'Compressing png images...' |
al@834 | 904 local size0=$(find $install -type f -name '*.png' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 905 local time0=$(date +%s) |
al@834 | 906 |
al@834 | 907 local use_pq=true use_op=true |
al@834 | 908 [ "${COOKOPTS/!pngquant/}" != "$COOKOPTS" ] && use_pq=false |
al@834 | 909 [ "${COOKOPTS/!optipng/}" != "$COOKOPTS" ] && use_op=false |
al@834 | 910 |
al@834 | 911 $use_pq && tazpkg -gi pngquant --quiet |
al@834 | 912 $use_op && tazpkg -gi optipng --quiet |
al@834 | 913 |
al@834 | 914 local oplevel=$(echo $COOKOPTS | grep 'op[0-8]' | sed 's|.*op\([0-8]\).*|\1|') |
al@834 | 915 [ -z "$oplevel" ] && oplevel='2' |
al@834 | 916 [ "$oplevel" == '8' ] && oplevel='7 -zm1-9' |
al@834 | 917 |
al@834 | 918 for i in $(find $install -type f -name '*.png'); do |
al@834 | 919 $use_pq && pngquant -f --skip-if-larger --ext .png --speed 1 "$i" |
al@834 | 920 $use_op && optipng -quiet -strip all -o$oplevel "$i" |
al@834 | 921 done |
al@834 | 922 |
al@834 | 923 local size1=$(find $install -type f -name '*.png' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 924 local time1=$(date +%s) |
al@834 | 925 status |
al@834 | 926 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@834 | 927 } |
al@834 | 928 |
al@834 | 929 |
al@834 | 930 # Function used after compile_rules() to compress all svg images |
al@834 | 931 # Compressing can be disabled with COOKOPTS="!svgz" |
al@834 | 932 |
al@846 | 933 compress_svg() { |
al@834 | 934 [ "${COOKOPTS/!svgz/}" != "$COOKOPTS" ] && return |
al@834 | 935 case "$ARCH" in |
al@834 | 936 arm*) return;; # While SliTaz-arm miss `svgcleaner` |
al@834 | 937 esac |
al@834 | 938 [ -z "$(find $install -type f -name '*.svg')" ] && return |
al@834 | 939 |
al@834 | 940 action 'Compressing svg images...' |
al@834 | 941 local size0=$(find $install -type f -name '*.svg' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 942 local time0=$(date +%s) |
al@834 | 943 tazpkg -gi svgcleaner --quiet |
al@834 | 944 cleaner_log="$(mktemp)" |
al@834 | 945 for i in $(find $install -type f -name '*.svg'); do |
al@834 | 946 echo -n "$i: " >> "$cleaner_log" |
al@834 | 947 svgcleaner "$i" "$i" --remove-unresolved-classes false --quiet true >> "$cleaner_log" |
al@834 | 948 done |
al@834 | 949 local size1=$(find $install -type f -name '*.svg' -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@834 | 950 local time1=$(date +%s) |
al@834 | 951 status |
al@834 | 952 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@834 | 953 sed -i '/: $/d' "$cleaner_log" |
al@834 | 954 if [ -s "$cleaner_log" ]; then |
al@834 | 955 echo 'Cleaner warnings and errors:' |
al@834 | 956 awk '{printf " %s\n", $0;}' "$cleaner_log" |
al@834 | 957 echo |
al@834 | 958 fi |
al@834 | 959 rm "$cleaner_log" |
al@809 | 960 } |
al@809 | 961 |
al@728 | 962 |
al@836 | 963 # Function used after compile_rules() to shrink all *.ui and *.glade files: |
al@836 | 964 # remove insignificant spaces and comments |
al@836 | 965 # Compressing can be disabled with COOKOPTS="!uiz" |
al@836 | 966 |
al@836 | 967 compress_ui() { |
al@836 | 968 [ "${COOKOPTS/!uiz/}" != "$COOKOPTS" ] && return |
al@836 | 969 case "$ARCH" in |
al@836 | 970 arm*) return;; # While SliTaz-arm miss `xmlstarlet` |
al@836 | 971 esac |
al@836 | 972 [ -z "$(find $install -type f \( -name '*.ui' -o -name '*.glade' \) )" ] && return |
al@836 | 973 |
al@836 | 974 action 'Compressing ui files...' |
al@836 | 975 local size0=$(find $install -type f \( -name '*.ui' -o -name '*.glade' \) -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@836 | 976 local time0=$(date +%s) |
al@836 | 977 tazpkg -gi xmlstarlet --quiet |
al@836 | 978 temp_ui="$(mktemp)" |
al@836 | 979 for ui in $(find $install -type f \( -name '*.ui' -o -name '*.glade' \) ); do |
al@836 | 980 xmlstarlet c14n --without-comments "$ui" | xmlstarlet sel -B -t -c '*' > "$temp_ui" |
al@836 | 981 cat "$temp_ui" > "$ui" |
al@836 | 982 done |
al@836 | 983 local size1=$(find $install -type f \( -name '*.ui' -o -name '*.glade' \) -exec ls -l \{\} \; | awk '{s+=$5}END{print s}') |
al@836 | 984 local time1=$(date +%s) |
al@836 | 985 status |
al@836 | 986 comp_summary "$time0" "$time1" "$size0" "$size1" |
al@836 | 987 rm "$temp_ui" |
al@836 | 988 } |
al@836 | 989 |
al@836 | 990 |
pankso@1 | 991 # The main cook function. |
al@728 | 992 |
pankso@1 | 993 cookit() { |
al@779 | 994 title 'Cook: %s' "$PACKAGE $VERSION" |
pankso@1 | 995 set_paths |
pankso@359 | 996 |
pankso@377 | 997 # Handle cross-tools. |
pankso@359 | 998 case "$ARCH" in |
pankso@675 | 999 arm*|x86_64) |
paul@387 | 1000 # CROSS_COMPILE is used by at least Busybox and the kernel to set |
al@596 | 1001 # the cross-tools prefix. Sysroot is the root of our target arch |
al@728 | 1002 sysroot="$CROSS_TREE/sysroot" |
al@728 | 1003 tools="$CROSS_TREE/tools" |
pankso@443 | 1004 # Set root path when cross compiling. ARM tested but not x86_64 |
pankso@443 | 1005 # When cross compiling we must install build deps in $sysroot. |
al@737 | 1006 arch="-$ARCH" |
al@728 | 1007 root="$sysroot" |
al@728 | 1008 _ '%s sysroot: %s' "$ARCH" "$sysroot" |
al@728 | 1009 _ 'Adding "%s" to PATH' "$tools/bin" |
al@728 | 1010 export PATH="$PATH:$tools/bin" |
al@728 | 1011 export PKG_CONFIG_PATH="$sysroot/usr/lib/pkgconfig" |
al@737 | 1012 export CROSS_COMPILE="$HOST_SYSTEM-" |
al@728 | 1013 _ 'Using cross-tools: %s' "$CROSS_COMPILE" |
al@728 | 1014 if [ "$ARCH" == 'x86_64' ]; then |
al@737 | 1015 export CC="$HOST_SYSTEM-gcc -m64" |
al@737 | 1016 export CXX="$HOST_SYSTEM-g++ -m64" |
pankso@438 | 1017 else |
al@737 | 1018 export CC="$HOST_SYSTEM-gcc" |
al@737 | 1019 export CXX="$HOST_SYSTEM-g++" |
pankso@438 | 1020 fi |
al@737 | 1021 export AR="$HOST_SYSTEM-ar" |
al@737 | 1022 export AS="$HOST_SYSTEM-as" |
al@737 | 1023 export RANLIB="$HOST_SYSTEM-ranlib" |
al@737 | 1024 export LD="$HOST_SYSTEM-ld" |
al@737 | 1025 export STRIP="$HOST_SYSTEM-strip" |
al@737 | 1026 export LIBTOOL="$HOST_SYSTEM-libtool" ;; |
pankso@359 | 1027 esac |
pankso@359 | 1028 |
al@728 | 1029 [ -n "$QA" ] && receipt_quality |
pankso@44 | 1030 cd $pkgdir |
al@728 | 1031 [ -z "$continue" ] && rm -rf source 2>/dev/null |
al@728 | 1032 rm -rf install taz 2>/dev/null |
pankso@1 | 1033 |
pankso@1 | 1034 # Disable -pipe if less than 512Mb free RAM. |
al@728 | 1035 free=$(free | awk '/buffers:/{print $4}') |
pankso@1 | 1036 if [ "$free" -lt 524288 ] && [ "$CFLAGS" != "${CFLAGS/-pipe}" ]; then |
al@728 | 1037 _ 'Disabling -pipe compile flag: %d RAM free' "$free" |
al@728 | 1038 CFLAGS="${CFLAGS/-pipe}"; CFLAGS=$(echo "$CFLAGS" | tr -s ' ') |
al@728 | 1039 CXXFLAGS="${CXXFLAGS/-pipe}"; CXXFLAGS=$(echo "$CXXFLAGS" | tr -s ' ') |
pankso@1 | 1040 fi |
pankso@1 | 1041 unset free |
pankso@1 | 1042 |
pankso@232 | 1043 # Export flags and path to be used by make and receipt. |
al@728 | 1044 DESTDIR="$pkgdir/install" |
al@596 | 1045 # FIXME: L10n: Is this the right time for 'LC_ALL=C LANG=C'? |
pankso@232 | 1046 export DESTDIR MAKEFLAGS CFLAGS CXXFLAGS CONFIG_SITE LC_ALL=C LANG=C |
pankso@358 | 1047 #LDFLAGS |
pankso@1 | 1048 |
pankso@126 | 1049 # Check for build deps and handle implicit depends of *-dev packages |
pankso@126 | 1050 # (ex: libusb-dev :: libusb). |
pankso@215 | 1051 rm -f $CACHE/installed.local $CACHE/installed.web $CACHE/missing.dep |
pankso@215 | 1052 touch $CACHE/installed.local $CACHE/installed.web |
al@728 | 1053 [ -n "$BUILD_DEPENDS" ] && _ 'Checking build dependencies...' |
al@728 | 1054 [ -n "$root" ] && _ 'Using packages DB: %s' "$root$DB" |
al@728 | 1055 for dep in $BUILD_DEPENDS; do |
al@728 | 1056 implicit="${dep%-dev}" |
al@781 | 1057 # Don't add implicit dependency if it defined in DEPENDS |
al@786 | 1058 # echo '' $DEPENDS '' | fgrep -q " $implicit " && implicit='' |
al@728 | 1059 for i in $dep $implicit; do |
al@737 | 1060 if [ ! -f "$root$INSTALLED/$i/receipt" ]; then |
paul@174 | 1061 # Try local package first. In some cases implicit doesn't exist, ex: |
paul@174 | 1062 # libboost-dev exists but not libboost, so check if we got vers. |
pankso@173 | 1063 unset vers |
pascal@343 | 1064 vers=$(. $WOK/$i/receipt 2>/dev/null ; echo $VERSION) |
pankso@435 | 1065 # We may have a local package. |
al@728 | 1066 if [ -z "$vers" ]; then |
pascal@801 | 1067 vers=$(awk -F$'\t' -vp="$i" '$1==p{print $2; quit}' $PKGS/packages.info 2> /dev/null) |
pankso@435 | 1068 fi |
pankso@435 | 1069 debug "bdep: $i version: $vers" |
al@728 | 1070 if [ -f "$PKGS/$i-$vers$arch.tazpkg" ]; then |
al@728 | 1071 echo $i-$vers$arch.tazpkg >> $CACHE/installed.local |
pankso@126 | 1072 else |
paul@227 | 1073 # Priority to package version in wok (maybe more up-to-date) |
paul@227 | 1074 # than the mirrored one. |
al@728 | 1075 if [ -n "$vers" ]; then |
al@728 | 1076 if fgrep -q $i-$vers$arch $root$DB/packages.list; then |
pankso@215 | 1077 echo $i >> $CACHE/installed.web |
pankso@198 | 1078 else |
paul@211 | 1079 # So package exists in wok but not available. |
al@728 | 1080 _ 'Missing dep (wok/pkg): %s' "$i $vers" |
pankso@215 | 1081 echo $i >> $CACHE/missing.dep |
pankso@198 | 1082 fi |
pankso@225 | 1083 else |
pankso@435 | 1084 # Package is not in wok but may be in online repo. |
al@737 | 1085 if fgrep -q $i-$vers$arch $root$DB/packages.list; then |
pankso@225 | 1086 echo $i >> $CACHE/installed.web |
pankso@225 | 1087 else |
al@728 | 1088 _ 'ERROR: unknown dep "%s"' "$i" |
al@728 | 1089 exit 1 |
pankso@225 | 1090 fi |
pankso@173 | 1091 fi |
pankso@126 | 1092 fi |
pankso@1 | 1093 fi |
pankso@126 | 1094 done |
pankso@1 | 1095 done |
pankso@225 | 1096 |
pankso@215 | 1097 # Get the list of installed packages |
al@728 | 1098 cd $root$INSTALLED; ls -1 > $CACHE/installed.list |
pankso@358 | 1099 |
al@596 | 1100 # Have we a missing build dep to cook? |
al@728 | 1101 if [ -s "$CACHE/missing.dep" ] && [ -n "$AUTO_COOK" ]; then |
al@728 | 1102 _ 'Auto cook config is set: %s' "$AUTO_COOK" |
pankso@204 | 1103 cp -f $LOGS/$PACKAGE.log $LOGS/$PACKAGE.log.$$ |
al@728 | 1104 for i in $(uniq $CACHE/missing.dep); do |
al@728 | 1105 (_ 'Building dep (wok/pkg) : %s' "$i $vers") | \ |
pankso@204 | 1106 tee -a $LOGS/$PACKAGE.log.$$ |
al@596 | 1107 # programmers: next two messages are exact copy from remove_deps() |
al@728 | 1108 togrep1=$(_n 'Build dependencies to remove:') |
al@728 | 1109 togrep2=$(_n 'Removing:') |
al@728 | 1110 cook $i || (_ "ERROR: can't cook dep \"%s\"" "$i" && newline && \ |
al@596 | 1111 fgrep $togrep1 $LOGS/$i.log && \ |
al@596 | 1112 fgrep $togrep2 $LOGS/$i.log && newline) | \ |
pankso@204 | 1113 tee -a $LOGS/$PACKAGE.log.$$ && break |
pankso@204 | 1114 done |
pankso@215 | 1115 rm -f $CACHE/missing.dep |
pankso@204 | 1116 mv $LOGS/$PACKAGE.log.$$ $LOGS/$PACKAGE.log |
pankso@204 | 1117 fi |
pankso@358 | 1118 |
paul@211 | 1119 # QA: Exit on missing dep errors. We exit in both cases, if AUTO_COOK |
paul@211 | 1120 # is enabled and cook fails we have ERROR in log, if no auto cook we have |
pankso@204 | 1121 # missing dep in cached file. |
al@728 | 1122 lerror=$(_n 'ERROR') |
pascal@613 | 1123 if fgrep -q ^$lerror $LOGS/$pkg.log || [ -s "$CACHE/missing.dep" ]; then |
pankso@215 | 1124 [ -s "$CACHE/missing.dep" ] && nb=$(cat $CACHE/missing.dep | wc -l) |
al@728 | 1125 _p 'ERROR: missing %d dependency' 'ERROR: missing %d dependencies' "$nb" "$nb" |
al@728 | 1126 exit 1 |
pankso@202 | 1127 fi |
pankso@358 | 1128 |
al@737 | 1129 # Install local packages: package-version$arch |
pankso@215 | 1130 cd $PKGS |
al@728 | 1131 for i in $(uniq $CACHE/installed.local); do |
al@728 | 1132 _ 'Installing dep (pkg/local): %s' "$i" |
al@788 | 1133 tazpkg install $i --root=$root --local --quiet |
pankso@215 | 1134 done |
pankso@358 | 1135 |
pankso@215 | 1136 # Install web or cached packages (if mirror is set to $PKGS we only |
pankso@215 | 1137 # use local packages). |
al@728 | 1138 for i in $(uniq $CACHE/installed.web); do |
al@728 | 1139 _ 'Installing dep (web/cache): %s' "$i" |
al@779 | 1140 tazpkg get-install $i --root=$root --quiet |
pankso@215 | 1141 done |
pankso@358 | 1142 |
al@769 | 1143 update_installed_cook_diff |
pankso@202 | 1144 |
pankso@1 | 1145 # Get source tarball and make sure we have source dir named: |
paul@62 | 1146 # $PACKAGE-$VERSION to be standard in receipts. Here we use tar.lzma |
paul@62 | 1147 # tarball if it exists. |
al@728 | 1148 if [ -n "$WGET_URL" ] && [ ! -f "$SRC/$TARBALL" ]; then |
pankso@1 | 1149 if [ -f "$SRC/${SOURCE:-$PACKAGE}-$VERSION.tar.lzma" ]; then |
al@728 | 1150 TARBALL="${SOURCE:-$PACKAGE}-$VERSION.tar.lzma" |
al@728 | 1151 LZMA_SRC='' |
pankso@1 | 1152 else |
pankso@1 | 1153 get_source || exit 1 |
pankso@1 | 1154 fi |
pankso@1 | 1155 fi |
al@728 | 1156 if [ -z "$WANTED" ] && [ -n "$TARBALL" ] && [ ! -d "$src" ]; then |
al@728 | 1157 mkdir -p $pkgdir/source/tmp; cd $pkgdir/source/tmp |
pascal@268 | 1158 if ! extract_source ; then |
pascal@268 | 1159 get_source |
pascal@268 | 1160 extract_source || exit 1 |
pascal@268 | 1161 fi |
al@728 | 1162 if [ -n "$LZMA_SRC" ]; then |
pankso@190 | 1163 cd $pkgdir/source |
pankso@190 | 1164 if [ "$(ls -A tmp | wc -l)" -gl 1 ] || [ -f "$(echo tmp/*)" ]; then |
al@728 | 1165 mv tmp tmp-1; mkdir tmp |
pankso@190 | 1166 mv tmp-1 tmp/${SOURCE:-$PACKAGE}-$VERSION |
pankso@190 | 1167 fi |
pankso@190 | 1168 if [ -d "tmp/${SOURCE:-$PACKAGE}-$VERSION" ]; then |
al@728 | 1169 cd tmp; tar -c * | lzma e $SRC/$TARBALL -si |
pankso@190 | 1170 fi |
pankso@190 | 1171 fi |
pankso@190 | 1172 cd $pkgdir/source/tmp |
paul@62 | 1173 # Some archives are not well done and don't extract to one dir (ex lzma). |
pankso@57 | 1174 files=$(ls | wc -l) |
pankso@244 | 1175 [ "$files" == 1 ] && [ -d "$(ls)" ] && mv * ../$PACKAGE-$VERSION |
pankso@244 | 1176 [ "$files" == 1 ] && [ -f "$(ls)" ] && mkdir -p ../$PACKAGE-$VERSION && \ |
pankso@244 | 1177 mv * ../$PACKAGE-$VERSION/$TARBALL |
al@728 | 1178 [ "$files" -gt 1 ] && mkdir -p ../$PACKAGE-$VERSION && \ |
pankso@57 | 1179 mv * ../$PACKAGE-$VERSION |
al@728 | 1180 cd ..; rm -rf tmp |
pankso@1 | 1181 fi |
pankso@662 | 1182 |
pankso@658 | 1183 # Libtool shared libs path hack. |
pankso@658 | 1184 case "$ARCH" in |
pankso@658 | 1185 arm*) cross libhack ;; |
pankso@658 | 1186 esac |
pankso@1 | 1187 |
pankso@9 | 1188 # Execute receipt rules. |
pankso@44 | 1189 if grep -q ^compile_rules $receipt; then |
al@728 | 1190 _ 'Executing: %s' 'compile_rules' |
pankso@352 | 1191 echo "CFLAGS : $CFLAGS" |
pankso@358 | 1192 #echo "LDFLAGS : $LDFLAGS" |
pankso@55 | 1193 [ -d "$src" ] && cd $src |
pankso@97 | 1194 compile_rules $@ || exit 1 |
pankso@10 | 1195 # Stay compatible with _pkg |
pankso@55 | 1196 [ -d "$src/_pkg" ] && mv $src/_pkg $install |
pankso@9 | 1197 # QA: compile_rules success so valid. |
pankso@9 | 1198 mkdir -p $install |
pankso@9 | 1199 else |
al@596 | 1200 # QA: no compile_rules so no error, valid. |
pankso@9 | 1201 mkdir -p $install |
pankso@1 | 1202 fi |
al@809 | 1203 |
al@809 | 1204 # Actions to do after compiling the package |
al@837 | 1205 # Skip all for splitted packages (already done in main package) |
al@837 | 1206 if [ -z "$WANTED" ]; then |
al@837 | 1207 footer |
al@837 | 1208 compress_manpages |
al@846 | 1209 compress_png |
al@846 | 1210 compress_svg |
al@837 | 1211 compress_ui |
al@837 | 1212 fix_desktop_files |
al@846 | 1213 normalize_mo |
al@837 | 1214 fi |
al@779 | 1215 footer |
pankso@360 | 1216 |
pankso@360 | 1217 # Execute testsuite. |
pankso@360 | 1218 if grep -q ^testsuite $receipt; then |
al@779 | 1219 title 'Running testsuite' |
pankso@360 | 1220 testsuite $@ || exit 1 |
al@779 | 1221 footer |
pankso@360 | 1222 fi |
al@769 | 1223 |
al@769 | 1224 update_installed_cook_diff force |
pankso@1 | 1225 } |
pankso@1 | 1226 |
al@728 | 1227 |
pankso@1 | 1228 # Cook quality assurance. |
al@728 | 1229 |
pankso@1 | 1230 cookit_quality() { |
al@728 | 1231 if [ ! -d "$WOK/$pkg/install" ] && [ -z "$WANTED" ]; then |
al@728 | 1232 _ 'ERROR: cook failed' | tee -a $LOGS/$pkg.log |
pankso@9 | 1233 fi |
pankso@9 | 1234 # ERROR can be echoed any time in cookit() |
al@728 | 1235 lerror=$(_n 'ERROR') |
pascal@618 | 1236 if grep -Ev "(conftest|configtest)" $LOGS/$pkg.log | \ |
pascal@618 | 1237 grep -Eq "(^$lerror|undefined reference to)" ; then |
pankso@17 | 1238 debug_info | tee -a $LOGS/$pkg.log |
al@728 | 1239 rm -f $command |
al@728 | 1240 exit 1 |
pankso@1 | 1241 fi |
pankso@1 | 1242 } |
pankso@1 | 1243 |
al@728 | 1244 |
al@728 | 1245 # Create the package. Wanted to use TazPkg to create a tazpkg package at first, |
paul@62 | 1246 # but it doesn't handle EXTRAVERSION. |
al@728 | 1247 |
pankso@1 | 1248 packit() { |
pankso@1 | 1249 set_paths |
pankso@359 | 1250 |
pankso@359 | 1251 # Handle cross compilation |
pankso@359 | 1252 case "$ARCH" in |
pankso@676 | 1253 arm*|x86_64) arch="-$ARCH" ;; |
pankso@359 | 1254 esac |
pankso@359 | 1255 |
al@779 | 1256 title 'Pack: %s' "$PACKAGE $VERSION$arch" |
pankso@359 | 1257 |
pankso@44 | 1258 if grep -q ^genpkg_rules $receipt; then |
al@728 | 1259 _ 'Executing: %s' 'genpkg_rules' |
al@728 | 1260 set -e; cd $pkgdir; mkdir -p $fs |
al@728 | 1261 genpkg_rules || (newline; _ 'ERROR: genpkg_rules failed'; newline) >> \ |
pankso@234 | 1262 $LOGS/$pkg.log |
pankso@241 | 1263 else |
al@728 | 1264 _ 'No packages rules: meta package' |
pankso@241 | 1265 mkdir -p $fs |
pankso@16 | 1266 fi |
pankso@98 | 1267 |
pankso@98 | 1268 # First QA check to stop now if genpkg_rules failed. |
al@728 | 1269 lerror=$(_n 'ERROR') |
pascal@613 | 1270 if fgrep -q ^$lerror $LOGS/$pkg.log; then |
pankso@98 | 1271 exit 1 |
pankso@98 | 1272 fi |
pankso@358 | 1273 |
pankso@44 | 1274 cd $taz |
al@728 | 1275 for file in receipt description.txt; do |
pankso@1 | 1276 [ ! -f "../$file" ] && continue |
al@779 | 1277 action 'Copying "%s"...' "$file" |
al@728 | 1278 cp -f ../$file $pack; chown 0.0 $pack/$file; status |
pankso@1 | 1279 done |
pankso@119 | 1280 copy_generic_files |
pankso@358 | 1281 |
pankso@119 | 1282 # Strip and stuff files. |
pankso@43 | 1283 strip_package |
al@838 | 1284 strip_mo_i18n |
pankso@43 | 1285 |
al@728 | 1286 # Create files.list with redirecting find output. |
al@779 | 1287 action 'Creating the list of files...' |
al@728 | 1288 cd $fs |
al@728 | 1289 find . -type f -print > ../files.list |
al@728 | 1290 find . -type l -print >> ../files.list |
al@728 | 1291 cd ..; sed -i s/'^.'/''/ files.list |
al@728 | 1292 status |
al@728 | 1293 |
pankso@43 | 1294 # Md5sum of files. |
al@779 | 1295 action 'Creating md5sum of files...' |
pankso@16 | 1296 while read file; do |
pankso@16 | 1297 [ -L "fs$file" ] && continue |
pankso@16 | 1298 [ -f "fs$file" ] || continue |
pankso@16 | 1299 case "$file" in |
pankso@232 | 1300 /lib/modules/*/modules.*|*.pyc) continue ;; |
pankso@16 | 1301 esac |
pankso@16 | 1302 md5sum "fs$file" | sed 's/ fs/ /' |
pankso@16 | 1303 done < files.list > md5sum |
pankso@16 | 1304 status |
al@728 | 1305 |
al@728 | 1306 UNPACKED_SIZE=$(du -chs fs receipt files.list md5sum description.txt \ |
al@728 | 1307 2>/dev/null | awk 'END{ print $1 }') |
pankso@358 | 1308 |
pankso@16 | 1309 # Build cpio archives. |
al@779 | 1310 action 'Compressing the FS...' |
pankso@16 | 1311 find fs | cpio -o -H newc --quiet | lzma e fs.cpio.lzma -si |
pankso@16 | 1312 rm -rf fs |
pankso@16 | 1313 status |
al@728 | 1314 |
al@728 | 1315 PACKED_SIZE=$(du -chs fs.cpio.lzma receipt files.list md5sum description.txt \ |
al@728 | 1316 2>/dev/null | awk 'END{ print $1 }') |
al@728 | 1317 |
al@779 | 1318 action 'Updating receipt sizes...' |
pankso@16 | 1319 sed -i s/^PACKED_SIZE.*$// receipt |
pankso@16 | 1320 sed -i s/^UNPACKED_SIZE.*$// receipt |
pankso@16 | 1321 sed -i "s/^PACKAGE=/PACKED_SIZE=\"$PACKED_SIZE\"\nUNPACKED_SIZE=\"$UNPACKED_SIZE\"\nPACKAGE=/" receipt |
pankso@16 | 1322 status |
pankso@16 | 1323 |
pankso@16 | 1324 # Set extra version. |
al@728 | 1325 if [ -n "$EXTRAVERSION" ]; then |
al@779 | 1326 action 'Updating receipt EXTRAVERSION: %s' "$EXTRAVERSION" |
pankso@16 | 1327 sed -i s/^EXTRAVERSION.*$// receipt |
pankso@16 | 1328 sed -i "s/^VERSION=/EXTRAVERSION=\"$EXTRAVERSION\"\nVERSION=/" receipt |
pankso@16 | 1329 status |
pankso@16 | 1330 fi |
pankso@16 | 1331 |
pankso@16 | 1332 # Compress. |
al@779 | 1333 action 'Creating full cpio archive...' |
pankso@16 | 1334 find . -print | cpio -o -H newc --quiet > \ |
al@737 | 1335 ../$PACKAGE-$VERSION$EXTRAVERSION$arch.tazpkg |
pankso@16 | 1336 status |
al@728 | 1337 |
al@779 | 1338 action 'Restoring original package tree...' |
pankso@16 | 1339 unlzma -c fs.cpio.lzma | cpio -idm --quiet |
pankso@16 | 1340 status |
al@728 | 1341 |
al@728 | 1342 rm fs.cpio.lzma; cd .. |
pankso@43 | 1343 |
pankso@43 | 1344 # QA and give info. |
pankso@43 | 1345 tazpkg=$(ls *.tazpkg) |
pankso@43 | 1346 packit_quality |
al@779 | 1347 footer "$(_ 'Package "%s" created' "$tazpkg")" |
pankso@1 | 1348 } |
pankso@1 | 1349 |
al@728 | 1350 |
paul@62 | 1351 # Verify package quality and consistency. |
al@728 | 1352 |
pankso@8 | 1353 packit_quality() { |
al@779 | 1354 #action 'QA: checking for broken link...' |
pankso@157 | 1355 #link=$(find $fs/usr -type l -follow) |
pankso@157 | 1356 #[ "$link" ] && echo -e "\nERROR: broken link in filesystem" |
pankso@157 | 1357 #status |
pankso@358 | 1358 |
pankso@142 | 1359 # Exit if any error found in log file. |
al@728 | 1360 lerror=$(_n 'ERROR') |
pascal@613 | 1361 if fgrep -q ^$lerror $LOGS/$pkg.log; then |
al@728 | 1362 rm -f $command |
al@728 | 1363 exit 1 |
pankso@8 | 1364 fi |
pankso@358 | 1365 |
al@779 | 1366 action 'QA: checking for empty package...' |
pankso@45 | 1367 files=$(cat $WOK/$pkg/taz/$pkg-*/files.list | wc -l) |
al@786 | 1368 if [ "$files" -eq 0 -a "$CATEGORY" != 'meta' ]; then |
al@728 | 1369 newline; _ 'ERROR: empty package' |
al@728 | 1370 rm -f $command |
al@728 | 1371 exit 1 |
pankso@8 | 1372 else |
al@788 | 1373 :; status |
al@788 | 1374 # Find and remove old package(s) |
al@788 | 1375 tempd="$(mktemp -d)"; cd "$tempd" |
pascal@790 | 1376 for testpkg in $(ls $PKGS/$pkg-*.tazpkg 2> /dev/null); do |
al@788 | 1377 # Extract receipt from each matched package |
al@788 | 1378 cpio -F "$testpkg" -i receipt >/dev/null 2>&1 |
al@788 | 1379 name=$(. receipt; echo $PACKAGE) |
al@788 | 1380 rm receipt |
al@788 | 1381 if [ "$name" == "$pkg" ]; then |
al@788 | 1382 action 'Removing old package "%s"' "$(basename "$testpkg")" |
al@788 | 1383 rm -f "$testpkg" |
al@788 | 1384 status |
al@788 | 1385 fi |
al@788 | 1386 done |
al@788 | 1387 rm -r "$tempd" |
pankso@134 | 1388 mv -f $pkgdir/taz/$pkg-*.tazpkg $PKGS |
pankso@11 | 1389 sed -i /^${pkg}$/d $broken |
al@779 | 1390 #action 'Removing source tree...' |
al@779 | 1391 #rm -f $WOK/$pkg/source; status |
pankso@8 | 1392 fi |
pankso@8 | 1393 } |
pankso@8 | 1394 |
al@728 | 1395 |
al@728 | 1396 # Reverse "cat" command: prints input lines in the reverse order |
al@728 | 1397 |
pankso@421 | 1398 tac() { |
pascal@285 | 1399 sed '1!G;h;$!d' $1 |
pascal@285 | 1400 } |
pascal@285 | 1401 |
al@728 | 1402 |
pankso@428 | 1403 # Install package on --install or update the chroot. |
al@728 | 1404 |
pankso@428 | 1405 install_package() { |
pankso@428 | 1406 case "$ARCH" in |
pankso@676 | 1407 arm*|x86_64) |
al@737 | 1408 arch="-$ARCH" |
al@728 | 1409 root="$CROSS_TREE/sysroot" ;; |
pankso@428 | 1410 esac |
pankso@428 | 1411 # Install package if requested but skip install if target host doesn't |
pankso@428 | 1412 # match build system or it will break the build chroot. |
al@728 | 1413 build=$(echo $BUILD_SYSTEM | cut -d- -f1) |
al@728 | 1414 if [ -n "$inst" ] && [ "$build" == "$ARCH" ]; then |
al@737 | 1415 if [ -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" ]; then |
al@728 | 1416 cd $PKGS |
al@728 | 1417 tazpkg install $PACKAGE-$VERSION$EXTRAVERSION.tazpkg --forced |
pankso@428 | 1418 else |
al@728 | 1419 _ 'Unable to install package, build has failed.'; newline |
pankso@428 | 1420 exit 1 |
pankso@428 | 1421 fi |
pankso@428 | 1422 fi |
pankso@428 | 1423 |
pankso@428 | 1424 # Install package if part of the chroot to keep env up-to-date. |
al@728 | 1425 if [ -d "$root$INSTALLED/$pkg" ]; then |
pankso@428 | 1426 . /etc/slitaz/cook.conf |
pankso@428 | 1427 . $WOK/$pkg/taz/$pkg-*/receipt |
al@728 | 1428 _ 'Updating %s chroot environment...' "$ARCH" |
al@728 | 1429 _ 'Updating chroot: %s' "$pkg ($VERSION$EXTRAVERSION$arch)" | log |
al@728 | 1430 cd $PKGS |
al@728 | 1431 tazpkg install $pkg-$VERSION$EXTRAVERSION$arch.tazpkg --forced --root=$root |
pankso@428 | 1432 fi |
pankso@428 | 1433 } |
pankso@428 | 1434 |
al@728 | 1435 |
pascal@696 | 1436 # remove chroot jail |
al@728 | 1437 |
pascal@696 | 1438 umount_aufs() { |
pascal@696 | 1439 tac ${1}rw/aufs-umount.sh | sh |
pascal@696 | 1440 rm -rf ${1}rw |
pascal@696 | 1441 umount ${1}root |
pascal@697 | 1442 rmdir ${1}r* |
pascal@696 | 1443 } |
pascal@696 | 1444 |
al@728 | 1445 |
pascal@285 | 1446 # Launch the cook command into a chroot jail protected by aufs. |
pascal@285 | 1447 # The current filesystems are used read-only and updates are |
pascal@285 | 1448 # stored in a separate branch. |
al@728 | 1449 |
pascal@285 | 1450 try_aufs_chroot() { |
pascal@285 | 1451 |
al@728 | 1452 base="/dev/shm/aufsmnt$$" |
pascal@286 | 1453 |
al@596 | 1454 # Can we setup the chroot? Is it already done? |
pascal@292 | 1455 grep -q ^AUFS_NOT_SUPPORTED $receipt && return |
al@728 | 1456 grep -q ^AUFS_NOT_RAMFS $receipt && base="/mnt/aufsmnt$$" |
pascal@285 | 1457 [ -n "$AUFS_MOUNTS" -a ! -f /aufs-umount.sh ] || return |
pascal@285 | 1458 lsmod | grep -q aufs || modprobe aufs 2> /dev/null || return |
pascal@286 | 1459 mkdir ${base}root ${base}rw || return |
pascal@285 | 1460 |
al@728 | 1461 _ 'Setup aufs chroot...' |
pascal@285 | 1462 |
pascal@285 | 1463 # Sanity check |
pascal@286 | 1464 for i in / /proc /sys /dev/shm /home ; do |
pascal@285 | 1465 case " $AUFS_MOUNTS " in |
pascal@285 | 1466 *\ $i\ *) ;; |
pascal@285 | 1467 *) AUFS_MOUNTS="$AUFS_MOUNTS $i" ;; |
pascal@285 | 1468 esac |
pascal@285 | 1469 done |
pascal@691 | 1470 for mnt in $(ls -d $AUFS_MOUNTS | sort | uniq); do |
pascal@285 | 1471 mount --bind $mnt ${base}root$mnt |
pascal@285 | 1472 if [ $mnt == / ] && ! mount -t aufs -o br=${base}rw:/ none ${base}root; then |
al@728 | 1473 _ 'Aufs mount failure' |
slaxemulator@519 | 1474 umount ${base}root |
pascal@628 | 1475 rm -rf ${base}r* |
slaxemulator@519 | 1476 return |
pascal@285 | 1477 fi |
pascal@285 | 1478 echo "umount ${base}root$mnt" >> ${base}rw/aufs-umount.sh |
pascal@285 | 1479 done |
pascal@696 | 1480 trap "umount_aufs ${base}" INT |
pascal@285 | 1481 |
pascal@285 | 1482 chroot ${base}root $(cd $(dirname $0); pwd)/$(basename $0) "$@" |
pascal@285 | 1483 status=$? |
pascal@285 | 1484 |
al@728 | 1485 _ 'Leaving aufs chroot...' |
al@737 | 1486 umount_aufs $base |
pascal@683 | 1487 # Install package outside the aufs jail |
pascal@683 | 1488 install_package |
pankso@358 | 1489 exit $status |
pascal@285 | 1490 } |
pascal@285 | 1491 |
al@728 | 1492 |
al@705 | 1493 # Encode predefined XML entities |
al@728 | 1494 |
al@705 | 1495 xml_ent() { |
al@705 | 1496 sed -e 's|&|\&|g; s|<|\<|g; s|>|\>|g; s|"|\"|g' -e "s|'|\'|g" |
al@705 | 1497 } |
al@705 | 1498 |
al@728 | 1499 |
paul@387 | 1500 # Create a XML feed for freshly built packages. |
al@728 | 1501 |
pankso@310 | 1502 gen_rss() { |
al@728 | 1503 pubdate=$(date '+%a, %d %b %Y %X') |
al@728 | 1504 cat > $FEEDS/$pkg.xml <<EOT |
pankso@310 | 1505 <item> |
al@737 | 1506 <title>$PACKAGE $VERSION$EXTRAVERSION</title> |
pankso@310 | 1507 <link>${COOKER_URL}?pkg=$PACKAGE</link> |
al@737 | 1508 <guid>$PACKAGE-$VERSION$EXTRAVERSION</guid> |
pankso@310 | 1509 <pubDate>$pubdate</pubDate> |
al@705 | 1510 <description>$(echo -n "$SHORT_DESC" | xml_ent)</description> |
pankso@310 | 1511 </item> |
pankso@310 | 1512 EOT |
pankso@310 | 1513 } |
pankso@310 | 1514 |
al@728 | 1515 |
pankso@662 | 1516 # Truncate stdout log file to $1 Mb. |
al@728 | 1517 |
al@728 | 1518 loglimit() { |
pascal@593 | 1519 if [ -n "$DEFAULT_LOG_LIMIT" ]; then |
pascal@621 | 1520 tee /dev/stderr | head -qc ${1:-$DEFAULT_LOG_LIMIT}m |
pascal@593 | 1521 else |
pascal@593 | 1522 tee /dev/stderr |
pascal@593 | 1523 fi |
pascal@576 | 1524 } |
pascal@576 | 1525 |
al@728 | 1526 |
al@598 | 1527 # Search file in mirrored packages |
al@728 | 1528 |
al@728 | 1529 search_file_mirror() { |
al@598 | 1530 busybox unlzma -c $DB/files.list.lzma | grep $1\$ | cut -d: -f1 | sort -u |
al@598 | 1531 } |
al@598 | 1532 |
al@728 | 1533 |
al@598 | 1534 # Search file in local wok packages |
al@728 | 1535 |
al@728 | 1536 search_file_local() { |
al@598 | 1537 # existing packages have precedence over the package/taz folder |
al@598 | 1538 srch=$1 |
al@598 | 1539 { for package in $(find $PKGS -name '*.tazpkg'); do |
al@728 | 1540 if [ -n "$(busybox cpio --to-stdout --quiet -i files.list < $package | \ |
al@728 | 1541 grep /$srch\$)" ]; then |
al@598 | 1542 busybox cpio -i receipt < $package | fgrep PACKAGE | cut -d\" -f2 |
al@598 | 1543 fi |
al@598 | 1544 done } | sort -u |
al@598 | 1545 } |
al@598 | 1546 |
al@728 | 1547 |
al@598 | 1548 # Ask in multiple choice |
al@728 | 1549 |
al@728 | 1550 ask_multiple() { |
al@598 | 1551 local multiples first my_choice |
al@598 | 1552 multiples="$1" |
al@598 | 1553 first=$(echo "$multiples" | head -n1) |
al@728 | 1554 newline; _ 'Multiple choice:'; echo "$multiples"; newline |
al@728 | 1555 _ 'Select one [%s]: ' "$first"; read my_choice |
al@728 | 1556 found="${my_choice:-$first}" |
al@598 | 1557 } |
al@598 | 1558 |
al@728 | 1559 |
al@598 | 1560 # Search file in local cache (fast), local wok packages, mirrored packages |
al@728 | 1561 |
al@728 | 1562 search_file() { |
al@598 | 1563 local srch cache missing |
al@728 | 1564 srch="$1" |
al@728 | 1565 cache='/var/cache/ldsearch.cache' |
al@728 | 1566 missing='/var/cache/missing.file' |
al@598 | 1567 touch $cache $missing |
al@728 | 1568 found=$(grep $srch $cache | cut -d$'\t' -f2) |
al@728 | 1569 if [ -z "$found" ]; then |
al@598 | 1570 found=$(search_file_local $srch) |
al@728 | 1571 if [ -n "$found" ]; then |
al@598 | 1572 if [ $(echo "$found" | wc -l) -gt 1 ]; then |
al@598 | 1573 ask_multiple "$found" |
al@598 | 1574 fi |
al@728 | 1575 echo -e "$srch\t$found" >> $cache |
al@598 | 1576 else |
al@598 | 1577 found=$(search_file_mirror $srch) |
al@728 | 1578 if [ -n "$found" ]; then |
al@598 | 1579 if [ $(echo "$found" | wc -l) -gt 1 ]; then |
al@598 | 1580 ask_multiple "$found" |
al@598 | 1581 fi |
al@728 | 1582 echo -e "$srch\t$found" >> $cache |
al@598 | 1583 else |
al@598 | 1584 echo "$srch" >> $missing |
al@598 | 1585 fi |
al@598 | 1586 fi |
al@598 | 1587 fi |
al@598 | 1588 } |
al@598 | 1589 |
al@728 | 1590 |
al@731 | 1591 # Return size of file in human readible format |
al@731 | 1592 # Note, "du" in opposite returns size occupied by file on disk (4KB multiple in most cases) |
al@731 | 1593 filesize() { |
al@731 | 1594 busybox ls -lh "$1" | awk '{print $5 "B"}' |
al@731 | 1595 } |
al@731 | 1596 |
al@731 | 1597 |
pankso@1 | 1598 # |
pankso@671 | 1599 # Receipt functions to ease packaging |
pankso@671 | 1600 # |
pankso@671 | 1601 |
pankso@671 | 1602 get_dev_files() { |
al@779 | 1603 action 'Getting standard devel files...' |
pankso@671 | 1604 mkdir -p $fs/usr/lib |
pankso@671 | 1605 cp -a $install/usr/lib/pkgconfig $fs/usr/lib |
pascal@750 | 1606 cp -a $install/usr/lib/*a $fs/usr/lib |
pankso@671 | 1607 cp -a $install/usr/include $fs/usr |
pankso@671 | 1608 status |
pankso@671 | 1609 } |
pankso@671 | 1610 |
al@807 | 1611 |
al@809 | 1612 # Function to use in compile_rules() to copy man page from $src to $install |
al@807 | 1613 |
al@809 | 1614 cook_pick_manpages() { |
al@809 | 1615 local name section |
al@809 | 1616 action 'Copying man pages...' |
al@802 | 1617 |
al@809 | 1618 for i in $@; do |
al@809 | 1619 name=$(echo $i | sed 's|\.[gbx]z2*$||') |
al@809 | 1620 section=${name##*/}; section=${section##*.} |
al@809 | 1621 mkdir -p $install/usr/share/man/man$section |
al@809 | 1622 cp -a $i $install/usr/share/man/man$section |
al@802 | 1623 done |
al@802 | 1624 status |
al@802 | 1625 } |
al@802 | 1626 |
al@807 | 1627 |
al@807 | 1628 # Function to use in genpkg_rules() to copy specified files from $install to $fs |
al@807 | 1629 |
al@802 | 1630 cook_copy_files() { |
al@802 | 1631 action 'Copying files...' |
al@802 | 1632 cd $install |
al@802 | 1633 local i j |
al@802 | 1634 for i in $@; do |
al@802 | 1635 for j in $(find . -name $i ! -type d); do |
al@802 | 1636 mkdir -p $fs$(dirname ${j#.}) |
al@802 | 1637 cp -a $j $fs/${j#.} |
al@802 | 1638 done |
al@802 | 1639 done |
al@802 | 1640 cd - >/dev/null |
al@802 | 1641 status |
al@802 | 1642 } |
al@802 | 1643 |
al@807 | 1644 |
al@834 | 1645 # Function to use in genpkg_rules() to copy specified folders from $install to $fs |
al@834 | 1646 |
al@834 | 1647 cook_copy_folders() { |
al@834 | 1648 action 'Copying folders...' |
al@834 | 1649 cd $install |
al@834 | 1650 local i j |
al@834 | 1651 for i in $@; do |
al@834 | 1652 for j in $(find . -name $i -type d); do |
al@834 | 1653 mkdir -p $fs$(dirname ${j#.}) |
al@834 | 1654 cp -a $j $fs/${j#.} |
al@834 | 1655 done |
al@834 | 1656 done |
al@834 | 1657 cd - >/dev/null |
al@834 | 1658 status |
al@834 | 1659 } |
al@834 | 1660 |
al@834 | 1661 |
al@818 | 1662 # Function to use in genpkg_rules() to copy hicolor icons in specified sizes |
al@818 | 1663 # (default: 16 and 48) from $install to $fs |
al@807 | 1664 |
al@807 | 1665 cook_copy_icons() { |
al@818 | 1666 local sizes=$@ |
al@807 | 1667 action 'Copying hicolor icons...' |
al@807 | 1668 mkdir -p $fs/usr/share/icons/hicolor |
al@818 | 1669 for i in ${sizes:-16 48}; do |
al@818 | 1670 [ -e "$install/usr/share/icons/hicolor/${i}x$i" ] && |
al@818 | 1671 cp -a $install/usr/share/icons/hicolor/${i}x$i \ |
al@818 | 1672 $fs/usr/share/icons/hicolor |
al@807 | 1673 done |
al@807 | 1674 status |
al@807 | 1675 } |
al@807 | 1676 |
al@742 | 1677 dblog() { tee -a $LOGS/pkgdb.log; } |
al@742 | 1678 |
al@742 | 1679 |
al@742 | 1680 |
al@728 | 1681 |
pankso@671 | 1682 # |
pankso@1 | 1683 # Commands |
pankso@1 | 1684 # |
pankso@1 | 1685 |
pankso@1 | 1686 case "$1" in |
pankso@32 | 1687 usage|help|-u|-h) |
pankso@1 | 1688 usage ;; |
al@728 | 1689 |
pankso@1 | 1690 list-wok) |
al@779 | 1691 title 'List of %s packages in "%s"' "$ARCH" "$WOK" |
pankso@642 | 1692 cd $WOK |
al@728 | 1693 if [ "$ARCH" != 'i486' ]; then |
pankso@643 | 1694 count=0 |
al@728 | 1695 for pkg in $(fgrep 'HOST_ARCH=' */receipt | egrep "$ARCH|any" | cut -d: -f1) |
pankso@643 | 1696 do |
pankso@643 | 1697 unset HOST_ARCH |
pankso@643 | 1698 . $pkg |
pankso@643 | 1699 count=$(($count + 1)) |
pankso@643 | 1700 colorize 34 "$PACKAGE" |
pankso@643 | 1701 done |
pankso@642 | 1702 else |
pankso@643 | 1703 count=$(ls | wc -l) |
pankso@643 | 1704 ls -1 |
pankso@642 | 1705 fi |
al@779 | 1706 footer "$(_p '%s package' '%s packages' "$count" "$(colorize 32 "$count")")" |
al@779 | 1707 ;; |
al@728 | 1708 |
pankso@378 | 1709 activity) |
pankso@378 | 1710 cat $activity ;; |
al@728 | 1711 |
pankso@69 | 1712 search) |
pankso@69 | 1713 # Just a simple search function, we dont need more actually. |
pankso@69 | 1714 query="$2" |
al@779 | 1715 title 'Search results for "%s"' "$query" |
al@728 | 1716 cd $WOK; ls -1 | grep "$query" |
al@779 | 1717 footer ;; |
al@728 | 1718 |
pankso@1 | 1719 setup) |
pankso@1 | 1720 # Setup a build environment |
pankso@1 | 1721 check_root |
al@728 | 1722 _ 'Cook: setup environment' | log |
al@779 | 1723 title 'Setting up your environment' |
psychomaniak@821 | 1724 [ -d $SLITAZ ] || mkdir -p $SLITAZ |
al@596 | 1725 cd $SLITAZ |
pankso@52 | 1726 init_db_files |
al@728 | 1727 _ 'Checking for packages to install...' |
pankso@397 | 1728 # Use setup pkgs from cross.conf or cook.conf. When cross compiling |
pankso@645 | 1729 # ARCH-setup or 'cross check' should be used before: cook setup |
pankso@397 | 1730 case "$ARCH" in |
pankso@676 | 1731 arm*|x86_64) |
al@728 | 1732 if [ ! -x '/usr/bin/cross' ]; then |
al@728 | 1733 _ 'ERROR: %s is not installed' 'cross' |
pankso@397 | 1734 exit 1 |
pankso@397 | 1735 fi |
al@728 | 1736 _ 'Using config file: %s' '/etc/slitaz/cross.conf' |
pankso@397 | 1737 . /etc/slitaz/cross.conf ;; |
pankso@397 | 1738 esac |
pankso@397 | 1739 for pkg in $SETUP_PKGS; do |
al@728 | 1740 if [ -n "$forced" ]; then |
pankso@421 | 1741 tazpkg -gi $pkg --forced |
pankso@397 | 1742 else |
al@728 | 1743 [ ! -d "$INSTALLED/$pkg" ] && tazpkg get-install $pkg |
pankso@397 | 1744 fi |
pankso@397 | 1745 done |
pankso@1 | 1746 |
pankso@1 | 1747 # Handle --options |
pankso@1 | 1748 case "$2" in |
al@728 | 1749 --wok) hg clone $WOK_URL wok || exit 1 ;; |
al@728 | 1750 --stable) hg clone $WOK_URL-stable wok || exit 1 ;; |
al@728 | 1751 --undigest) hg clone $WOK_URL-undigest wok || exit 1 ;; |
al@728 | 1752 --tiny) hg clone $WOK_URL-tiny wok || exit 1 ;; |
pankso@1 | 1753 esac |
pankso@1 | 1754 |
pankso@1 | 1755 # SliTaz group and permissions |
pankso@1 | 1756 if ! grep -q ^slitaz /etc/group; then |
al@728 | 1757 _ 'Adding group "%s"' 'slitaz' |
pankso@1 | 1758 addgroup slitaz |
pankso@1 | 1759 fi |
al@728 | 1760 _ 'Setting permissions for group "%s"...' 'slitaz' |
pascal@277 | 1761 find $SLITAZ -maxdepth 2 -exec chown root.slitaz {} \; |
pascal@277 | 1762 find $SLITAZ -maxdepth 2 -exec chmod g+w {} \; |
al@779 | 1763 footer "$(_ 'All done, ready to cook packages :-)')" ;; |
al@728 | 1764 |
pankso@395 | 1765 *-setup) |
pankso@395 | 1766 # Setup for cross compiling. |
al@728 | 1767 arch="${1%-setup}" |
pankso@397 | 1768 check_root |
pankso@644 | 1769 . /etc/slitaz/cook.conf |
pankso@644 | 1770 for pkg in $CROSS_SETUP; do |
al@728 | 1771 if [ -n "$forced" ]; then |
pankso@644 | 1772 tazpkg -gi $pkg --forced |
pankso@644 | 1773 else |
al@728 | 1774 [ ! -d "$INSTALLED/$pkg" ] && tazpkg -gi $pkg |
pankso@644 | 1775 fi |
pankso@644 | 1776 done |
al@728 | 1777 |
al@728 | 1778 _ 'Cook: setup %s cross environment' "$arch" | log |
al@779 | 1779 title 'Setting up your %s cross environment' "$arch" |
pankso@397 | 1780 init_db_files |
pankso@359 | 1781 sed -i \ |
pankso@396 | 1782 -e s"/ARCH=.*/ARCH=\"$arch\"/" \ |
pankso@443 | 1783 -e s"/CROSS_TREE=.*/CROSS_TREE=\"\/cross\/$arch\"/" \ |
pankso@359 | 1784 -e s'/BUILD_SYSTEM=.*/BUILD_SYSTEM=i486-slitaz-linux/' \ |
pankso@395 | 1785 /etc/slitaz/cook.conf |
pankso@395 | 1786 case "$arch" in |
pankso@395 | 1787 arm) |
al@728 | 1788 flags='-O2 -march=armv6' |
pankso@650 | 1789 host="$ARCH-slitaz-linux-gnueabi" ;; |
pankso@650 | 1790 armv6hf) |
al@728 | 1791 flags='-O2 -march=armv6j -mfpu=vfp -mfloat-abi=hard' |
pankso@650 | 1792 host="$ARCH-slitaz-linux-gnueabi" ;; |
pankso@650 | 1793 armv7) |
al@728 | 1794 flags='-Os -march=armv7-a -mfpu=vfpv3-d16 -mfloat-abi=softfp -pipe' |
pankso@650 | 1795 host="$ARCH-slitaz-linux-gnueabi" ;; |
pankso@395 | 1796 x86_64) |
al@728 | 1797 flags='-O2 -mtune=generic -pipe' |
pankso@650 | 1798 host="$ARCH-slitaz-linux" ;; |
pankso@395 | 1799 esac |
pankso@650 | 1800 sed -i \ |
pankso@650 | 1801 -e s"/CFLAGS=.*/CFLAGS=\"$flags\"/" \ |
pankso@677 | 1802 -e s"/HOST_SYSTEM=.*/HOST_SYSTEM=$host/" /etc/slitaz/cook.conf |
pankso@359 | 1803 . /etc/slitaz/cook.conf |
al@728 | 1804 sysroot="$CROSS_TREE/sysroot" |
al@728 | 1805 tools="/cross/$arch/tools" |
al@728 | 1806 root="$sysroot" |
al@596 | 1807 # L10n: keep the same width of translations to get a consistent view |
al@728 | 1808 _ 'Target arch : %s' "$ARCH" |
al@728 | 1809 _ 'Configure args : %s' "$CONFIGURE_ARGS" |
al@728 | 1810 _ 'Build flags : %s' "$flags" |
al@728 | 1811 _ 'Arch sysroot : %s' "$sysroot" |
al@728 | 1812 _ 'Tools prefix : %s' "$tools/bin" |
paul@455 | 1813 # Tell the packages manager where to find packages. |
al@728 | 1814 _ 'Packages DB : %s' "$root$DB" |
al@728 | 1815 mkdir -p $root$INSTALLED |
al@728 | 1816 cd $root$DB; rm -f *.bak |
al@728 | 1817 for list in packages.list packages.desc packages.equiv packages.md5; do |
al@728 | 1818 rm -f $list |
al@728 | 1819 ln -s $SLITAZ/packages/$list $list |
pankso@426 | 1820 done |
pankso@429 | 1821 # We must have the cross compiled glibc-base installed or default |
pankso@429 | 1822 # i486 package will be used as dep by tazpkg and then break the |
pankso@429 | 1823 # cross environment |
al@728 | 1824 if [ ! -f "$root$INSTALLED/glibc-base/receipt" ]; then |
al@728 | 1825 colorize 36 $(_ 'WARNING: %s is not installed in sysroot' '(e)glibc-base') |
pankso@429 | 1826 fi |
pankso@426 | 1827 # Show GCC version or warn if not yet compiled. |
al@737 | 1828 if [ -x "$tools/bin/$HOST_SYSTEM-gcc" ]; then |
al@728 | 1829 _ 'Cross compiler : %s' "$HOST_SYSTEM-gcc" |
pankso@359 | 1830 else |
al@728 | 1831 colorize 36 $(_ 'C compiler "%s" is missing' "$HOST_SYSTEM-gcc") |
al@728 | 1832 _ 'Run "%s" to cook a toolchain' 'cross compile' |
pankso@397 | 1833 fi |
al@779 | 1834 footer ;; |
al@728 | 1835 |
pankso@9 | 1836 test) |
pankso@9 | 1837 # Test a cook environment. |
al@728 | 1838 _ 'Cook test: testing the cook environment' | log |
pankso@9 | 1839 [ ! -d "$WOK" ] && exit 1 |
pankso@9 | 1840 [ ! -d "$WOK/cooktest" ] && cp -r $DATA/cooktest $WOK |
pankso@9 | 1841 cook cooktest ;; |
al@728 | 1842 |
pankso@1 | 1843 new) |
pankso@1 | 1844 # Create the package folder and an empty receipt. |
pankso@1 | 1845 pkg="$2" |
al@728 | 1846 [ -z "$pkg" ] && usage |
pankso@427 | 1847 newline |
pankso@1 | 1848 if [ -d "$WOK/$pkg" ]; then |
al@728 | 1849 _ 'Package "%s" already exists.' "$pkg" |
al@596 | 1850 exit 1 |
pankso@1 | 1851 fi |
al@728 | 1852 |
al@779 | 1853 action 'Creating folder "%s"' "$WOK/$pkg" |
al@728 | 1854 mkdir $WOK/$pkg; cd $WOK/$pkg; status |
al@728 | 1855 |
al@779 | 1856 action 'Preparing the package receipt...' |
pankso@1 | 1857 cp $DATA/receipt . |
pankso@1 | 1858 sed -i s"/^PACKAGE=.*/PACKAGE=\"$pkg\"/" receipt |
al@728 | 1859 status; newline |
pankso@358 | 1860 |
pankso@196 | 1861 # Interactive mode, asking and seding. |
pankso@196 | 1862 case "$3" in |
paul@214 | 1863 --interactive|-x) |
al@728 | 1864 _ 'Entering interactive mode...' |
paul@211 | 1865 separator |
al@728 | 1866 _ 'Package : %s' "$pkg" |
al@728 | 1867 |
al@728 | 1868 _n 'Version : ' ; read answer |
al@596 | 1869 sed -i s/'VERSION=\"\"'/"VERSION=\"$answer\""/ receipt |
al@728 | 1870 |
al@728 | 1871 _n 'Category : ' ; read answer |
al@596 | 1872 sed -i s/'CATEGORY=\"\"'/"CATEGORY=\"$answer\""/ receipt |
al@728 | 1873 |
al@596 | 1874 # L10n: Short description |
al@728 | 1875 _n 'Short desc : ' ; read answer |
al@596 | 1876 sed -i s/'SHORT_DESC=\"\"'/"SHORT_DESC=\"$answer\""/ receipt |
al@728 | 1877 |
al@728 | 1878 _n 'Maintainer : ' ; read answer |
al@596 | 1879 sed -i s/'MAINTAINER=\"\"'/"MAINTAINER=\"$answer\""/ receipt |
al@728 | 1880 |
al@728 | 1881 _n 'License : ' ; read answer |
al@596 | 1882 sed -i s/'LICENSE=\"\"'/"LICENSE=\"$answer\""/ receipt |
al@728 | 1883 |
al@728 | 1884 _n 'Web site : ' ; read answer |
al@596 | 1885 sed -i s#'WEB_SITE=\"\"'#"WEB_SITE=\"$answer\""# receipt |
pankso@427 | 1886 newline |
al@728 | 1887 |
pankso@196 | 1888 # Wget URL. |
al@728 | 1889 _ 'Wget URL to download source tarball.' |
al@728 | 1890 _n 'Example : ' ; echo '$GNU_MIRROR/$PACKAGE/$TARBALL' |
al@728 | 1891 _n 'Wget url : ' ; read answer |
al@728 | 1892 sed -i "s|WGET_URL=.*|WGET_URL=\"$answer\"|" receipt |
al@728 | 1893 |
pankso@196 | 1894 # Ask for a stuff dir. |
al@728 | 1895 confirm "$(_n 'Do you need a stuff directory? (y/N)')" |
al@779 | 1896 if [ "$?" -eq 0 ]; then |
al@779 | 1897 action 'Creating the stuff directory...' |
al@728 | 1898 mkdir $WOK/$pkg/stuff; status |
pankso@196 | 1899 fi |
al@728 | 1900 |
pankso@196 | 1901 # Ask for a description file. |
al@728 | 1902 confirm "$(_n 'Are you going to write a description? (y/N)')" |
al@779 | 1903 if [ "$?" -eq 0 ]; then |
al@779 | 1904 action 'Creating the "%s" file...' 'description.txt' |
al@728 | 1905 touch $WOK/$pkg/description.txt; status |
pankso@196 | 1906 fi |
al@728 | 1907 |
al@779 | 1908 footer "$(_ 'Receipt is ready to use.')" ;; |
pankso@196 | 1909 esac ;; |
al@728 | 1910 |
pankso@1 | 1911 list) |
pankso@1 | 1912 # Cook a list of packages (better use the Cooker since it will order |
pankso@1 | 1913 # packages before executing cook). |
pankso@1 | 1914 check_root |
al@728 | 1915 if [ -z "$2" ]; then |
al@728 | 1916 newline; _ 'No list in argument.'; newline |
al@728 | 1917 exit 1 |
al@728 | 1918 fi |
al@728 | 1919 if [ ! -f "$2" ]; then |
al@728 | 1920 newline; _ 'List "%s" not found.' "$2"; newline |
al@728 | 1921 exit 1 |
al@728 | 1922 fi |
al@728 | 1923 |
al@728 | 1924 _ 'Starting cooking the list "%s"' "$2" | log |
al@728 | 1925 |
al@728 | 1926 for pkg in $(cat $2); do |
pankso@1 | 1927 cook $pkg || broken |
pankso@1 | 1928 done ;; |
al@728 | 1929 |
pankso@1 | 1930 clean-wok) |
pankso@1 | 1931 check_root |
al@779 | 1932 newline; action 'Cleaning all packages files...' |
pankso@1 | 1933 rm -rf $WOK/*/taz $WOK/*/install $WOK/*/source |
al@596 | 1934 status; newline ;; |
al@728 | 1935 |
pankso@1 | 1936 clean-src) |
pankso@1 | 1937 check_root |
al@779 | 1938 newline; action 'Cleaning all packages sources...' |
pankso@1 | 1939 rm -rf $WOK/*/source |
al@596 | 1940 status; newline ;; |
al@728 | 1941 |
pankso@662 | 1942 uncook) |
pankso@662 | 1943 cd $WOK |
pankso@662 | 1944 count=0 |
al@779 | 1945 title 'Checking for uncooked packages' |
al@728 | 1946 |
al@728 | 1947 for pkg in *; do |
pankso@664 | 1948 unset HOST_ARCH EXTRAVERSION |
al@728 | 1949 [ ! -e $pkg/receipt ] && continue |
pankso@662 | 1950 . $pkg/receipt |
pankso@662 | 1951 # Source cooked pkg receipt to get EXTRAVERSION |
pankso@663 | 1952 if [ -d "$WOK/$pkg/taz" ]; then |
pankso@663 | 1953 cd $WOK/$pkg/taz/$pkg-* |
al@728 | 1954 . receipt; cd $WOK |
pankso@662 | 1955 fi |
pankso@662 | 1956 case "$ARCH" in |
pankso@662 | 1957 i486) |
al@728 | 1958 debug "$(_ 'Package "%s"' "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg")" |
al@728 | 1959 if [ ! -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" ]; then |
pankso@662 | 1960 count=$(($count + 1)) |
pankso@662 | 1961 colorize 34 "$pkg" |
pankso@662 | 1962 fi ;; |
pankso@676 | 1963 arm*) |
paul@665 | 1964 # Check only packages included in arch |
pascal@669 | 1965 if echo "$HOST_ARCH" | egrep -q "$ARCH|any"; then |
pankso@662 | 1966 # *.tazpkg |
al@728 | 1967 if [ ! -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION-$ARCH.tazpkg" ]; then |
pankso@662 | 1968 count=$(($count + 1)) |
pankso@662 | 1969 colorize 34 "$pkg" |
pankso@662 | 1970 fi |
pankso@662 | 1971 fi ;; |
pankso@662 | 1972 esac |
pankso@662 | 1973 done |
al@728 | 1974 |
pankso@662 | 1975 if [ "$count" -gt "0" ]; then |
al@779 | 1976 footer "$(_p '%s uncooked package' '%s uncooked packages' "$count" "$(colorize 31 "$count")")" |
pankso@662 | 1977 else |
al@728 | 1978 _ 'All packages are cooked :-)' |
al@779 | 1979 newline |
pankso@662 | 1980 fi |
al@779 | 1981 ;; |
al@728 | 1982 |
pankso@235 | 1983 pkgdb) |
pankso@235 | 1984 # Create suitable packages list for TazPKG and only for built packages |
pankso@235 | 1985 # as well as flavors files for TazLiTo. We dont need logs since we do it |
paul@243 | 1986 # manually to ensure everything is fine before syncing the mirror. |
al@742 | 1987 |
al@742 | 1988 rm $LOGS/pkgdb.log 2>/dev/null |
al@742 | 1989 |
pankso@239 | 1990 case "$2" in |
al@744 | 1991 --flavors|--rmpkg) ;; |
pankso@239 | 1992 *) |
al@728 | 1993 [ -n "$2" ] && PKGS="$2" |
al@728 | 1994 if [ ! -d "$PKGS" ]; then |
al@742 | 1995 { newline; _ "Packages directory \"%s\" doesn't exist" "$PKGS"; newline; } | dblog |
al@728 | 1996 exit 1 |
al@728 | 1997 fi ;; |
pankso@239 | 1998 esac |
al@728 | 1999 |
pankso@226 | 2000 time=$(date +%s) |
al@728 | 2001 flavors="$SLITAZ/flavors" |
al@728 | 2002 live="$SLITAZ/live" |
al@725 | 2003 |
al@728 | 2004 echo 'cook:pkgdb' > $command |
al@728 | 2005 _ 'Cook pkgdb: Creating all packages lists' | log |
al@742 | 2006 newline; { _ 'Creating lists for "%s"' "$PKGS"; separator; } | dblog |
al@728 | 2007 |
al@742 | 2008 { _ 'Cook pkgdb started: %s' "$(date "$(_ '+%%F %%R')")"; newline; } | dblog |
al@725 | 2009 |
pankso@133 | 2010 cd $PKGS |
pascal@699 | 2011 rm -f packages.* extra.list |
al@729 | 2012 touch packages.equiv |
al@725 | 2013 |
al@742 | 2014 _n 'Creating file "%s"' 'packages.list' | dblog |
pankso@85 | 2015 ls -1 *.tazpkg | sed s'/.tazpkg//' > $PKGS/packages.list |
al@742 | 2016 echo " ($(filesize $PKGS/packages.list))" | dblog |
al@725 | 2017 |
al@742 | 2018 _n 'Creating file "%s"' 'packages.md5' | dblog |
pankso@1 | 2019 md5sum *.tazpkg > $PKGS/packages.md5 |
al@742 | 2020 echo " ($(filesize $PKGS/packages.md5))" | dblog |
al@744 | 2021 cp $PKGS/packages.md5 $PKGS/packages.toremove # list of duplicates |
al@725 | 2022 |
al@728 | 2023 md5sum packages.md5 | cut -d' ' -f1 > ID |
al@725 | 2024 ( cat ./ID | tr $'\n' ' '; date -ur ./ID +%s ) > IDs # md5 and timestamp |
al@725 | 2025 |
al@742 | 2026 _n 'Creating file "%s"' 'descriptions.txt' | dblog |
al@742 | 2027 rm $PKGS/descriptions.txt 2>/dev/null |
al@741 | 2028 for i in $(ls $WOK | sort); do |
al@741 | 2029 if [ -e "$WOK/$i/description.txt" ]; then |
al@741 | 2030 echo "$i" >> descriptions.txt |
al@741 | 2031 cat "$WOK/$i/description.txt" | sed 's|^$| |' >> descriptions.txt |
al@741 | 2032 echo >> descriptions.txt |
al@741 | 2033 fi |
al@741 | 2034 done |
al@742 | 2035 echo " ($(filesize $PKGS/descriptions.txt))" | dblog |
al@741 | 2036 |
al@741 | 2037 |
al@742 | 2038 _ 'Creating lists from "%s"' "$WOK" | dblog |
pankso@1 | 2039 cd $WOK |
al@725 | 2040 for pkg in *; do |
pankso@1 | 2041 unset_receipt |
pankso@1 | 2042 . $pkg/receipt |
pascal@600 | 2043 # PACKED_SIZE and UNPACKED_SIZE are only in built receipt |
al@728 | 2044 [ -s $pkg/taz/*/receipt ] && . $pkg/taz/*/receipt |
al@728 | 2045 |
al@728 | 2046 if [ -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" ] || \ |
al@728 | 2047 [ -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION-$ARCH.tazpkg" ]; then |
al@701 | 2048 |
pankso@192 | 2049 # packages.desc lets us search easily in DB |
al@728 | 2050 cat >> $PKGS/packages.desc <<EOT |
al@728 | 2051 $PACKAGE | $VERSION$EXTRAVERSION | $SHORT_DESC | $CATEGORY | $WEB_SITE |
pankso@1 | 2052 EOT |
al@701 | 2053 |
pankso@192 | 2054 # packages.txt used by tazpkg and tazpkg-web also to provide |
pankso@192 | 2055 # a human readable package list with version and description. |
al@728 | 2056 cat >> $PKGS/packages.txt <<EOT |
pankso@192 | 2057 $PACKAGE |
al@728 | 2058 $VERSION$EXTRAVERSION |
pankso@235 | 2059 $SHORT_DESC |
pankso@235 | 2060 $PACKED_SIZE ($UNPACKED_SIZE installed) |
pankso@358 | 2061 |
pankso@192 | 2062 EOT |
al@701 | 2063 |
al@736 | 2064 # packages.info combines TazPkg separate files |
al@736 | 2065 # and will substitute them all |
al@701 | 2066 SIZES=$(echo $PACKED_SIZE $UNPACKED_SIZE | sed 's|\.0||g') |
al@701 | 2067 DEPENDS=$(echo $DEPENDS) # remove newlines from some receipts |
al@736 | 2068 MD5="$(fgrep " $PACKAGE-$VERSION$EXTRAVERSION.tazpkg" $PKGS/packages.md5 | awk '{print $1}')" |
al@728 | 2069 cat >> $PKGS/packages.info <<EOT |
al@736 | 2070 $PACKAGE $VERSION$EXTRAVERSION $CATEGORY $SHORT_DESC $WEB_SITE $TAGS $SIZES $DEPENDS $MD5 |
al@701 | 2071 EOT |
al@701 | 2072 |
pankso@192 | 2073 # packages.equiv is used by tazpkg install to check depends. |
pankso@1 | 2074 for i in $PROVIDE; do |
al@728 | 2075 DEST='' |
pankso@1 | 2076 echo $i | fgrep -q : && DEST="${i#*:}:" |
pankso@1 | 2077 if grep -qs ^${i%:*}= $PKGS/packages.equiv; then |
pankso@1 | 2078 sed -i "s/^${i%:*}=/${i%:*}=$DEST$PACKAGE /" \ |
pankso@1 | 2079 $PKGS/packages.equiv |
pankso@1 | 2080 else |
pankso@1 | 2081 echo "${i%:*}=$DEST$PACKAGE" >> $PKGS/packages.equiv |
pankso@1 | 2082 fi |
pankso@1 | 2083 done |
al@701 | 2084 |
paul@197 | 2085 # files.list provides a list of all packages files. |
pankso@194 | 2086 cat $pkg/taz/*/files.list | sed s/^/"$pkg: \0"/ >> \ |
pankso@194 | 2087 $PKGS/files.list |
al@744 | 2088 |
al@744 | 2089 # list of duplicates |
al@744 | 2090 sed -i "/ $PACKAGE-$VERSION$EXTRAVERSION.tazpkg/d" $PKGS/packages.toremove |
al@744 | 2091 else |
al@746 | 2092 # if receipt variable HOST_ARCH absent/empty or contains ARCH |
al@746 | 2093 if [ -z "$HOST_ARCH" -o "${HOST_ARCH/$ARCH/}" != "$HOST_ARCH" ]; then |
al@746 | 2094 _ ' - absent: %s (%s)' "$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" "$ARCH" | dblog |
al@746 | 2095 fi |
pankso@1 | 2096 fi |
pankso@1 | 2097 done |
pankso@358 | 2098 |
pankso@213 | 2099 # Display list size. |
al@742 | 2100 _ 'Done: %s (%s)' 'packages.desc' "$(filesize $PKGS/packages.desc)" | dblog |
al@742 | 2101 _ 'Done: %s (%s)' 'packages.txt' "$(filesize $PKGS/packages.txt)" | dblog |
al@742 | 2102 _ 'Done: %s (%s)' 'packages.info' "$(filesize $PKGS/packages.info)" | dblog |
al@742 | 2103 _ 'Done: %s (%s)' 'packages.equiv' "$(filesize $PKGS/packages.equiv)" | dblog |
pankso@358 | 2104 |
al@727 | 2105 cd $PKGS |
al@727 | 2106 |
al@744 | 2107 |
al@744 | 2108 # Check package duplicates |
al@744 | 2109 if [ -s "$PKGS/packages.toremove" ]; then |
al@744 | 2110 newline | dblog |
al@744 | 2111 _ 'Removing duplicates:' | dblog |
al@744 | 2112 while read pkgsum pkgfile; do |
al@744 | 2113 echo " - $pkgfile" | dblog |
al@744 | 2114 sed -i "/${pkgfile%.tazpkg}/d" $PKGS/packages.list |
al@744 | 2115 sed -i "/ $pkgfile/d" $PKGS/packages.md5 |
al@744 | 2116 [ -n "$rmpkg" ] && rm $PKGS/$pkgfile # remove packages only with --rmpkg |
al@744 | 2117 done < $PKGS/packages.toremove |
al@744 | 2118 newline | dblog |
al@744 | 2119 fi |
al@745 | 2120 rm $PKGS/packages.toremove |
al@744 | 2121 |
al@744 | 2122 |
pankso@194 | 2123 # files.list.lzma |
al@742 | 2124 _n 'Creating file "%s"' 'files.list.lzma' | dblog |
al@727 | 2125 touch files.list |
al@729 | 2126 # pkgs.slitaz.org strongly depends on list sorted by packages names |
al@729 | 2127 lzma e files.list files.list.lzma |
al@742 | 2128 echo " ($(filesize $PKGS/files.list.lzma))" | dblog |
al@725 | 2129 |
al@729 | 2130 # Pre-sorting filenames causes 10% smaller resulting lzma file |
al@742 | 2131 _n 'Creating file "%s"' 'files-list.lzma' | dblog |
al@729 | 2132 cat files.list | sort -k2 -o files.list.sorted |
al@729 | 2133 lzma e files.list.sorted files-list.lzma |
al@729 | 2134 rm -f files.list files.list.sorted |
al@742 | 2135 echo " ($(filesize $PKGS/files-list.lzma))" | dblog |
al@729 | 2136 |
al@729 | 2137 [ -e files.list.md5 ] && rm files.list.md5 |
al@729 | 2138 md5sum files-list.lzma | cut -d' ' -f1 | tr -d $'\n' > files-list.md5 |
pankso@358 | 2139 |
al@701 | 2140 # packages.info.lzma |
al@701 | 2141 PI=packages.info |
al@742 | 2142 _n 'Creating file "%s"' 'packages.info.lzma' | dblog |
al@727 | 2143 touch $PI |
al@727 | 2144 lzma e $PI $PI.lzma |
al@742 | 2145 echo " ($(filesize $PKGS/packages.info.lzma))" | dblog |
al@725 | 2146 |
al@725 | 2147 # Make bundle to fast recharge |
al@742 | 2148 _n 'Creating file "%s"' 'bundle.tar.lzma' | dblog |
al@725 | 2149 [ -f bundle.tar.lzma ] && rm bundle.tar.lzma |
al@746 | 2150 # Make sure to get "mirrors" file |
al@746 | 2151 until [ -e 'mirrors' ]; do |
al@746 | 2152 wget -q http://mirror1.slitaz.org/mirrors |
al@746 | 2153 echo -n '.' | dblog; sleep 5 |
al@746 | 2154 done |
al@746 | 2155 # Make sure to get "extra.list" file |
al@746 | 2156 until [ -e 'extra.list' ]; do |
al@746 | 2157 wget -q -O extra.list http://mirror1.slitaz.org/packages/get.list |
al@746 | 2158 echo -n '.' | dblog; sleep 5 |
al@746 | 2159 done |
al@730 | 2160 busybox tar -chaf bundle.tar.lzma \ |
al@741 | 2161 mirrors extra.list files-list.md5 packages.info descriptions.txt \ |
al@725 | 2162 packages.desc packages.md5 packages.txt packages.list packages.equiv |
al@727 | 2163 rm ./mirrors |
al@742 | 2164 echo " ($(filesize $PKGS/bundle.tar.lzma))" | dblog |
al@701 | 2165 |
pankso@235 | 2166 # Display some info. |
al@742 | 2167 separator | dblog |
pankso@1 | 2168 nb=$(ls $PKGS/*.tazpkg | wc -l) |
pankso@226 | 2169 time=$(($(date +%s) - $time)) |
al@596 | 2170 # L10n: 's' is for seconds (cooking time) |
al@742 | 2171 { _ 'Packages: %s - Time: %ss' "$nb" "$time"; newline; } | dblog |
al@728 | 2172 |
pankso@358 | 2173 |
paul@243 | 2174 # Create all flavors files at once. Do we really need code to monitor |
al@596 | 2175 # flavors changes? Lets just build them with packages lists before |
pankso@235 | 2176 # syncing the mirror. |
al@728 | 2177 [ "$2" != '--flavors' ] && exit 1 |
al@728 | 2178 |
al@728 | 2179 if [ ! -d "$flavors" ]; then |
al@742 | 2180 { _ 'Missing flavors folder "%s"' "$flavors"; newline; } | dblog |
al@728 | 2181 exit 1 |
al@728 | 2182 fi |
al@728 | 2183 |
al@728 | 2184 [ ! -d "$live" ] && mkdir -p $live |
al@742 | 2185 _ 'Creating flavors files in "%s"' "$live" | dblog |
al@728 | 2186 _ 'Cook pkgdb: Creating all flavors' | log |
al@742 | 2187 separator | dblog |
al@728 | 2188 |
al@742 | 2189 _ 'Recharging lists to use latest packages...' | dblog |
pankso@329 | 2190 tazpkg recharge >/dev/null 2>/dev/null |
pankso@358 | 2191 |
pankso@235 | 2192 # We need a custom tazlito config to set working dir to /home/slitaz. |
pankso@235 | 2193 if [ ! -f "$live/tazlito.conf" ]; then |
al@742 | 2194 _ 'Creating configuration file "%s"' 'tazlito.conf' | dblog |
pankso@235 | 2195 cp /etc/tazlito/tazlito.conf $live |
pankso@235 | 2196 sed -i s@WORK_DIR=.*@WORK_DIR=\"/home/slitaz\"@ \ |
pankso@235 | 2197 $live/tazlito.conf |
pankso@235 | 2198 fi |
pankso@235 | 2199 |
pankso@239 | 2200 # Update Hg flavors repo and pack. |
al@728 | 2201 if [ -d "$flavors/.hg" ]; then |
al@728 | 2202 cd $flavors; hg pull -u |
al@728 | 2203 fi |
pankso@358 | 2204 |
pankso@239 | 2205 cd $live |
al@742 | 2206 _ 'Starting to generate flavors...' | dblog |
pankso@235 | 2207 rm -f flavors.list *.flavor |
al@728 | 2208 for i in $flavors/*; do |
pankso@235 | 2209 fl=$(basename $i) |
al@742 | 2210 _ 'Packing flavor "%s"' "$fl" | dblog |
pankso@235 | 2211 tazlito pack-flavor $fl >/dev/null || exit 1 |
al@728 | 2212 tazlito show-flavor $fl --brief --noheader 2>/dev/null >> flavors.list |
pankso@235 | 2213 done |
pankso@237 | 2214 cp -f $live/*.flavor $live/flavors.list $PKGS |
al@742 | 2215 separator | dblog |
al@742 | 2216 { _ 'Total flavors size: %s' "$(du -sh $live | awk '{print $1}')"; newline; } | dblog |
al@596 | 2217 rm -f $command |
al@742 | 2218 separator | dblog |
al@742 | 2219 _ 'Cook pkgdb end: %s' "$(date "$(_ '+%%F %%R')")" | dblog |
al@742 | 2220 ;; |
al@728 | 2221 |
pankso@1 | 2222 *) |
pankso@1 | 2223 # Just cook and generate a package. |
pankso@1 | 2224 check_root |
pankso@1 | 2225 time=$(date +%s) |
pankso@1 | 2226 pkg="$1" |
pankso@1 | 2227 [ -z "$pkg" ] && usage |
pascal@751 | 2228 lastcooktime=$(sed '/^Cook time/!d;s|.*: *\([0-9]*\)s.*|\1|' \ |
pascal@763 | 2229 $LOGS/$pkg.log 2> /dev/null | sed '$!d') |
pankso@44 | 2230 receipt="$WOK/$pkg/receipt" |
al@728 | 2231 check_pkg_in_wok |
al@728 | 2232 newline |
pankso@47 | 2233 |
pankso@377 | 2234 unset inst |
pankso@377 | 2235 unset_receipt |
pankso@377 | 2236 . $receipt |
al@728 | 2237 |
pankso@377 | 2238 # Handle cross compilation. |
pankso@377 | 2239 case "$ARCH" in |
pankso@676 | 2240 arm*) |
al@728 | 2241 if [ -z "$HOST_ARCH" ]; then |
al@728 | 2242 _ 'cook: HOST_ARCH is not set in "%s" receipt' "$pkg" |
al@728 | 2243 error="$(_ 'package "%s" is not included in %s' "$pkg" "$ARCH")" |
al@728 | 2244 _ 'cook: %s' "$error" |
al@728 | 2245 [ -n "$CROSS_BUGS" ] && _ 'bugs: %s' "$CROSS_BUGS" |
al@728 | 2246 _ 'Cook skip: %s' "$error" | log |
al@728 | 2247 newline |
al@728 | 2248 exit 1 |
pankso@377 | 2249 fi ;; |
pankso@377 | 2250 esac |
pankso@377 | 2251 |
paul@387 | 2252 # Some packages are not included in some arch or fail to cross compile. |
pankso@398 | 2253 : ${HOST_ARCH=i486} |
al@728 | 2254 debug "$(_ 'Host arch %s' "$HOST_ARCH")" |
pankso@675 | 2255 # Handle arm{v6hf,v7,..} |
pankso@675 | 2256 if ! $(echo "$HOST_ARCH" | egrep -q "${ARCH%v[0-9]*}|any"); then |
al@728 | 2257 _ 'cook: %s' "HOST_ARCH=$HOST_ARCH" |
al@728 | 2258 error="$(_ "package \"%s\" doesn't cook or is not included in %s" "$pkg" "$ARCH")" |
al@728 | 2259 _ 'cook: %s' "error" |
al@728 | 2260 [ -n "$CROSS_BUGS" ] && _ 'bugs: %s' "$CROSS_BUGS" |
al@728 | 2261 _ 'Cook skip: %s' "$error" | log |
pascal@673 | 2262 sed -i /^${pkg}$/d $broken |
al@728 | 2263 newline |
al@728 | 2264 exit 0 |
pankso@377 | 2265 fi |
pankso@377 | 2266 |
pankso@47 | 2267 # Skip blocked, 3 lines also for the Cooker. |
al@728 | 2268 if grep -q "^$pkg$" $blocked && [ "$2" != '--unblock' ]; then |
al@728 | 2269 _ 'Package "%s" is blocked' "$pkg"; newline |
al@728 | 2270 exit 0 |
pankso@47 | 2271 fi |
pankso@47 | 2272 |
pascal@289 | 2273 try_aufs_chroot "$@" |
pascal@289 | 2274 |
pankso@47 | 2275 # Log and source receipt. |
al@728 | 2276 _ 'Cook started for: %s' "<a href='cooker.cgi?pkg=$pkg'>$pkg</a>" | log |
pankso@16 | 2277 echo "cook:$pkg" > $command |
pascal@751 | 2278 [ "$lastcooktime" ] && |
pascal@824 | 2279 echo "cook:$pkg $lastcooktime $(date +%s)" >> $cooktime |
pascal@824 | 2280 while read cmd duration start; do |
pascal@824 | 2281 [ $(($start + $duration)) -lt $(date +%s) ] && |
pascal@824 | 2282 echo "sed -i '/^$cmd $duration/d' $cooktime" |
pascal@824 | 2283 done < $cooktime | sh |
pascal@285 | 2284 |
pascal@285 | 2285 # Display and log info if cook process stopped. |
paul@647 | 2286 # FIXME: gettext not working (in single quotes) here! |
al@596 | 2287 trap '_ "\n\nCook stopped: control-C\n\n" | \ |
pascal@285 | 2288 tee -a $LOGS/$pkg.log' INT |
pascal@285 | 2289 |
pankso@1 | 2290 # Handle --options |
pankso@1 | 2291 case "$2" in |
pankso@1 | 2292 --clean|-c) |
al@779 | 2293 action 'Cleaning "%s"' "$pkg" |
al@728 | 2294 cd $WOK/$pkg; rm -rf install taz source |
al@728 | 2295 status; newline |
al@728 | 2296 exit 0 ;; |
al@728 | 2297 |
pankso@1 | 2298 --install|-i) |
pankso@1 | 2299 inst='yes' ;; |
al@728 | 2300 |
pankso@49 | 2301 --getsrc|-gs) |
al@779 | 2302 title 'Getting source for "%s"' "$pkg" |
al@596 | 2303 get_source |
al@728 | 2304 _ 'Tarball: %s' "$SRC/$TARBALL"; newline |
al@596 | 2305 exit 0 ;; |
al@728 | 2306 |
pankso@49 | 2307 --block|-b) |
al@779 | 2308 action 'Blocking package "%s"' "$pkg" |
pankso@49 | 2309 [ $(grep "^$pkg$" $blocked) ] || echo "$pkg" >> $blocked |
al@728 | 2310 status; newline |
al@728 | 2311 exit 0 ;; |
al@728 | 2312 |
pankso@49 | 2313 --unblock|-ub) |
al@779 | 2314 action 'Unblocking package "%s"' "$pkg" |
pankso@49 | 2315 sed -i "/^${pkg}$/"d $blocked |
al@728 | 2316 status; newline |
al@728 | 2317 exit 0 ;; |
al@728 | 2318 |
slaxemulator@501 | 2319 --pack) |
slaxemulator@501 | 2320 if [ -d $WOK/$pkg/taz ]; then |
slaxemulator@501 | 2321 rm -rf $WOK/$pkg/taz |
slaxemulator@501 | 2322 [ -f $LOGS/$pkg-pack.log ] && rm -rf $LOGS/$pkg-pack.log |
slaxemulator@501 | 2323 packit 2>&1 | tee -a $LOGS/$pkg-pack.log |
slaxemulator@501 | 2324 clean_log |
slaxemulator@501 | 2325 else |
al@728 | 2326 _ 'Need to build "%s"' "$pkg" |
al@728 | 2327 exit 0 |
slaxemulator@501 | 2328 fi |
slaxemulator@501 | 2329 exit 0 ;; |
al@728 | 2330 |
al@598 | 2331 --cdeps) |
al@728 | 2332 if [ ! -d $WOK/$pkg/taz ]; then |
al@728 | 2333 _ 'Need to build "%s"' "$pkg" |
al@728 | 2334 exit 0 |
al@728 | 2335 fi |
al@728 | 2336 |
al@779 | 2337 title 'Checking depends' |
al@728 | 2338 lddlist='/tmp/lddlist'; touch $lddlist |
al@728 | 2339 missing='/var/cache/missing.file' |
al@728 | 2340 |
al@598 | 2341 # find all deps using ldd |
al@598 | 2342 for exe in $(find $WOK/$pkg/taz -type f -perm +111); do |
al@598 | 2343 [ "x$(dd if=$exe bs=4 count=1 2>/dev/null)" == "xELF" ] && |
al@598 | 2344 ldd $exe | sed 's| ||' | cut -d' ' -f1 >> $lddlist |
al@728 | 2345 done #" |
al@728 | 2346 |
al@598 | 2347 # remove exe/so duplicates |
al@598 | 2348 sort -u $lddlist > $lddlist.sorted |
al@728 | 2349 |
al@598 | 2350 # search packages |
al@598 | 2351 for exefile in $(cat $lddlist.sorted); do |
al@598 | 2352 search_file $exefile |
al@728 | 2353 echo "$found" >> $lddlist.pkgs |
al@728 | 2354 echo -n '.' |
al@598 | 2355 done |
al@598 | 2356 echo |
al@728 | 2357 |
al@598 | 2358 # remove packages duplicates |
al@598 | 2359 sort -u $lddlist.pkgs > $lddlist.final |
al@598 | 2360 sort -u $missing > $missing.final |
al@598 | 2361 rm -f $lddlist $lddlist.sorted $lddlist.pkgs $missing |
al@598 | 2362 exit 0 ;; |
pankso@1 | 2363 esac |
pankso@1 | 2364 |
pascal@793 | 2365 # Rotate log |
pascal@793 | 2366 for i in $(seq 9 -1 1); do |
pascal@793 | 2367 j=$(($i - 1)) |
al@837 | 2368 [ -e $LOGS/$pkg.log.$j ] && mv -f $LOGS/$pkg.log.$j $LOGS/$pkg.log.$i |
pascal@793 | 2369 done |
al@837 | 2370 [ -e $LOGS/$pkg.log ] && mv $LOGS/$pkg.log $LOGS/$pkg.log.0 |
al@837 | 2371 |
paul@62 | 2372 # Check if wanted is built now so we have separate log files. |
pankso@295 | 2373 for wanted in $WANTED ; do |
pascal@291 | 2374 if grep -q "^$wanted$" $blocked; then |
al@728 | 2375 _ 'WANTED package "%s" is blocked' "$wanted" | tee $LOGS/$pkg.log |
al@728 | 2376 newline |
al@728 | 2377 rm -f $command |
al@728 | 2378 exit 1 |
pankso@217 | 2379 fi |
pascal@291 | 2380 if grep -q "^$wanted$" $broken; then |
al@728 | 2381 _ 'WANTED package "%s" is broken' "$wanted" | tee $LOGS/$pkg.log |
al@728 | 2382 newline |
al@728 | 2383 rm -f $command |
al@728 | 2384 exit 1 |
pankso@218 | 2385 fi |
pascal@291 | 2386 if [ ! -d "$WOK/$wanted/install" ]; then |
pascal@291 | 2387 cook "$wanted" || exit 1 |
pankso@137 | 2388 fi |
pascal@291 | 2389 done |
pankso@1 | 2390 |
pankso@1 | 2391 # Cook and pack or exit on error and log everything. |
pascal@576 | 2392 cookit $@ 2>&1 | loglimit 50 > $LOGS/$pkg.log |
pankso@15 | 2393 remove_deps | tee -a $LOGS/$pkg.log |
pankso@1 | 2394 cookit_quality |
pascal@576 | 2395 packit 2>&1 | loglimit 5 >> $LOGS/$pkg.log |
pankso@1 | 2396 clean_log |
pankso@33 | 2397 |
pankso@33 | 2398 # Exit if any error in packing. |
al@728 | 2399 lerror=$(_n 'ERROR') |
pascal@615 | 2400 if grep -Ev "(/root/.cvspass|conftest|df: /|rm: can't remove)" $LOGS/$pkg.log | \ |
pascal@752 | 2401 grep -Eq "(^$lerror|: No such file or directory|not remade because of errors|ake: \*\*\* .* Error)"; then |
pankso@33 | 2402 debug_info | tee -a $LOGS/$pkg.log |
al@728 | 2403 rm -f $command |
al@728 | 2404 exit 1 |
pankso@33 | 2405 fi |
pankso@358 | 2406 |
pankso@310 | 2407 # Create an XML feed |
pankso@310 | 2408 gen_rss |
pankso@358 | 2409 |
pankso@1 | 2410 # Time and summary |
pankso@1 | 2411 time=$(($(date +%s) - $time)) |
pankso@1 | 2412 summary | tee -a $LOGS/$pkg.log |
pankso@427 | 2413 newline |
pankso@1 | 2414 |
pascal@683 | 2415 # We may want to install/update (outside aufs jail !). |
pascal@683 | 2416 [ -s /aufs-umount.sh ] || |
pankso@428 | 2417 install_package |
pankso@358 | 2418 |
al@849 | 2419 rm -f $command |
al@849 | 2420 |
al@849 | 2421 # Cook splitted packages that builds from the files of just builded package |
al@849 | 2422 if [ "$2" == '--wsplit' -o "$2" == '-ws' ]; then |
al@849 | 2423 splitted=$(SPLIT=''; . $WOK/$pkg/receipt; echo $SPLIT) |
al@849 | 2424 [ "${splitted/$pkg-dev/}" == "$splitted" ] && splitted="$pkg-dev $splitted" |
al@849 | 2425 for i in $splitted; do |
al@849 | 2426 [ -d "$WOK/$i" ] && cook $i |
al@849 | 2427 done |
al@849 | 2428 fi |
al@849 | 2429 ;; |
pankso@1 | 2430 esac |
pankso@1 | 2431 |
pankso@1 | 2432 exit 0 |