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