cookutils annotate modules/pkgdb @ rev 1024

cook, lighttpd/index.cgi, modules/compressor, modules/mk_pkg_receipt, modules/pkgdb: patch for the x86_64 native architecture support, fix empty depends, etc.
author Aleksej Bobylev <al.bobylev@gmail.com>
date Wed Jan 24 12:14:38 2018 +0200 (2018-01-24)
parents ef2c335c986f
children 815349e0020b
rev   line source
al@857 1 #!/bin/sh
al@857 2 #
al@857 3 # pkgdb - module of the SliTaz Cook
al@857 4 # Copyright (C) SliTaz GNU/Linux - GNU GPL v3
al@857 5 #
al@857 6
al@857 7 . /usr/lib/slitaz/libcook.sh
al@857 8
al@857 9
al@857 10 #
al@857 11 # Functions
al@857 12 #
al@857 13
al@857 14 dblog() { tee -a $LOGS/pkgdb.log; }
al@857 15
al@857 16
al@857 17 # Return size of file in human readible format
al@857 18 # Note, "du" in opposite returns size occupied by file on disk (4KB multiple in most cases)
al@857 19
al@857 20 filesize() { busybox ls -lh "$1" | awk '{print $5 "B"}'; }
al@857 21
al@857 22
al@857 23
al@857 24
al@857 25
al@857 26 # Create suitable packages list for TazPkg and only for built packages
al@857 27 # as well as flavors files for TazLiTo. We don't need logs since we do it
al@857 28 # manually to ensure everything is fine before syncing the mirror.
al@857 29
al@914 30 # Find how much time was spent the last time (for web interface)
al@899 31 lastcooktime=$(sed '/Time:/!d; s|.*: *\([0-9]*\)s.*|\1|' $LOGS/pkgdb.log 2>/dev/null | sed '$!d')
al@899 32 [ -n "$lastcooktime" ] && echo "cook:pkgdb $lastcooktime $(date +%s)" >> $cooktime
al@899 33 while read cmd duration start; do
al@899 34 [ $(($start + $duration)) -lt $(date +%s) ] &&
al@899 35 echo "sed -i '/^$cmd $duration/d' $cooktime"
al@899 36 done < $cooktime | sh
al@899 37
al@857 38 rm $LOGS/pkgdb.log 2>/dev/null
al@857 39
al@857 40 case "$1" in
al@857 41 --flavors|--rmpkg) ;;
al@857 42 *)
al@857 43 [ -n "$1" ] && PKGS="$1"
al@857 44 if [ ! -d "$PKGS" ]; then
al@857 45 { newline; _ "Packages directory \"%s\" doesn't exist" "$PKGS"; newline; } | dblog
al@857 46 exit 1
al@857 47 fi ;;
al@857 48 esac
al@857 49
al@857 50 time=$(date +%s)
al@857 51 flavors="$SLITAZ/flavors"
al@857 52 live="$SLITAZ/live"
al@857 53
al@1024 54 arch=''
al@1024 55 case "$ARCH" in
al@1024 56 arm*|x86_64) arch="-$ARCH" ;;
al@1024 57 esac
al@1024 58
al@857 59 echo 'cook:pkgdb' > $command
al@857 60 _ 'Cook pkgdb: Creating all packages lists' | log
al@857 61 newline; { _ 'Creating lists for "%s"' "$PKGS"; separator; } | dblog
al@857 62
al@857 63 { _ 'Cook pkgdb started: %s' "$(date "$(_ '+%%F %%R')")"; newline; } | dblog
al@857 64
al@857 65 cd $PKGS
al@857 66 rm -f packages.* extra.list
al@968 67 #touch packages.equiv
al@857 68
al@975 69 # Web interface database files should exist on the mirror1
al@975 70 >.folderlist; >.filelist
al@976 71 chmod 666 .folderlist .filelist
al@975 72
al@857 73 _n 'Creating file "%s"' 'packages.list' | dblog
al@968 74 find . -name '*.tazpkg' | sed 's|^./||; s|.tazpkg$||' > $PKGS/packages.list
al@857 75 echo " ($(filesize $PKGS/packages.list))" | dblog
al@857 76
al@857 77 _n 'Creating file "%s"' 'packages.md5' | dblog
al@968 78 find . -name '*.tazpkg' -exec md5sum '{}' \; | sed 's|./||' > $PKGS/packages.md5
al@857 79 echo " ($(filesize $PKGS/packages.md5))" | dblog
al@862 80 cp $PKGS/packages.md5 $PKGS/packages.toremove # list of unnecessary packages
al@857 81
al@857 82 md5sum packages.md5 | cut -d' ' -f1 > ID
al@857 83 ( cat ./ID | tr $'\n' ' '; date -ur ./ID +%s ) > IDs # md5 and timestamp
al@857 84
al@857 85 _n 'Creating file "%s"' 'descriptions.txt' | dblog
al@857 86 rm $PKGS/descriptions.txt 2>/dev/null
al@857 87 for i in $(ls $WOK | sort); do
al@914 88 [ -d "$WOK/$i/taz" ] || continue
al@914 89
al@914 90 for j in $(ls $WOK/$i/taz | sort); do
al@914 91 [ -e "$WOK/$i/taz/$j/description.txt" ] || continue
al@914 92
al@914 93 pkgname=$(. $WOK/$i/taz/$j/receipt; echo $PACKAGE)
al@951 94 echo "$pkgname"
al@951 95 sed 's|^$| |' "$WOK/$i/taz/$j/description.txt"
al@951 96 echo
al@951 97 done >> descriptions.txt
al@857 98 done
al@857 99 echo " ($(filesize $PKGS/descriptions.txt))" | dblog
al@857 100
al@982 101 _n 'Creating file "%s"' 'bdeps.txt' | dblog
al@982 102 rm $PKGS/bdeps.txt 2>/dev/null
al@982 103 for i in $(ls $WOK | sort); do
al@982 104 [ -s "$WOK/$i/receipt" ] || continue
al@982 105 bdeps=$(. $WOK/$i/receipt; echo $BUILD_DEPENDS) # remove newlines from some receipts
al@982 106 echo "$i $bdeps" >> $PKGS/bdeps.txt
al@982 107 done
al@982 108 echo " ($(filesize $PKGS/bdeps.txt))" | dblog
al@982 109
al@857 110
al@857 111 _ 'Creating lists from "%s"' "$WOK" | dblog
al@963 112 [ -e $PKGS/files.list ] && rm $PKGS/files.list
al@857 113 cd $WOK
al@945 114 rsumf=$(mktemp)
al@914 115 for i in *; do
al@914 116 [ -d "$WOK/$i/taz" ] || continue
al@857 117
al@914 118 for j in $(ls $WOK/$i/taz | sort); do
al@945 119 pack="$i/taz/$j"
al@945 120 [ -f "$WOK/$pack/receipt" ] || continue
al@914 121 unset_receipt
al@951 122 . ./$pack/receipt
al@857 123
al@1024 124 if [ -f "$PKGS/$PACKAGE-$VERSION$EXTRAVERSION$arch.tazpkg" ]; then
al@914 125
al@914 126 # packages.desc lets us search easily in DB
al@914 127 cat >> $PKGS/packages.desc <<EOT
al@857 128 $PACKAGE | $VERSION$EXTRAVERSION | $SHORT_DESC | $CATEGORY | $WEB_SITE
al@857 129 EOT
al@857 130
al@914 131 # packages.txt used by tazpkg and tazpkg-web also to provide
al@914 132 # a human readable package list with version and description.
al@914 133 cat >> $PKGS/packages.txt <<EOT
al@857 134 $PACKAGE
al@857 135 $VERSION$EXTRAVERSION
al@857 136 $SHORT_DESC
al@857 137 $PACKED_SIZE ($UNPACKED_SIZE installed)
al@857 138
al@857 139 EOT
al@857 140
al@914 141 # packages.info combines TazPkg separate files
al@914 142 # and will substitute them all
al@914 143 SIZES=$(echo $PACKED_SIZE $UNPACKED_SIZE | sed 's|\.0||g')
al@914 144 DEPENDS=$(echo $DEPENDS) # remove newlines from some receipts
al@945 145
al@945 146 #MD5="$(fgrep " $PACKAGE-$VERSION$EXTRAVERSION.tazpkg" $PKGS/packages.md5 | awk '{print $1}')"
al@945 147 cp $pack/md5sum $rsumf
al@945 148 md5sum $pack/receipt | sed 's| [^ ]*/| |' >> $rsumf
al@945 149 [ -e "$pack/description.txt" ] && md5sum $pack/description.txt | sed 's| [^ ]*/| |' >> $rsumf
al@945 150 rsum=$(md5sum $rsumf | awk '{print $1}')
al@945 151
al@914 152 cat >> $PKGS/packages.info <<EOT
al@945 153 $PACKAGE $VERSION$EXTRAVERSION $CATEGORY $SHORT_DESC $WEB_SITE $TAGS $SIZES $DEPENDS $rsum $PROVIDE
al@857 154 EOT
al@857 155
al@914 156 # packages.equiv is used by tazpkg install to check depends.
al@914 157 for k in $PROVIDE; do
al@914 158 DEST=''
al@914 159 echo $k | fgrep -q : && DEST="${k#*:}:"
al@914 160 if grep -qs ^${k%:*}= $PKGS/packages.equiv; then
al@914 161 sed -i "s/^${k%:*}=/${k%:*}=$DEST$PACKAGE /" \
al@914 162 $PKGS/packages.equiv
al@914 163 else
al@914 164 echo "${k%:*}=$DEST$PACKAGE" >> $PKGS/packages.equiv
al@914 165 fi
al@914 166 done
al@914 167
al@914 168 # files.list provides a list of all packages files.
al@961 169 sed "s|^|$PACKAGE: \0|" $i/taz/$j/files.list >> $PKGS/files.list
al@914 170
al@914 171 # list of unnecessary packages
al@1024 172 sed -i "/ $PACKAGE-$VERSION$EXTRAVERSION$arch.tazpkg/d" $PKGS/packages.toremove
al@914 173 else
al@914 174 # if receipt variable HOST_ARCH absent/empty or contains ARCH
al@914 175 if [ -z "$HOST_ARCH" -o "${HOST_ARCH/$ARCH/}" != "$HOST_ARCH" ]; then
al@914 176 _ ' - absent: %s (%s)' "$PACKAGE-$VERSION$EXTRAVERSION.tazpkg" "$ARCH" | dblog
al@857 177 fi
al@857 178 fi
al@914 179 done
al@857 180 done
al@968 181 touch $PKGS/packages.desc $PKGS/packages.txt $PKGS/packages.info $PKGS/packages.equiv
al@945 182 rm $rsumf
al@945 183
al@857 184
al@857 185 # Display list size.
al@857 186 _ 'Done: %s (%s)' 'packages.desc' "$(filesize $PKGS/packages.desc)" | dblog
al@857 187 _ 'Done: %s (%s)' 'packages.txt' "$(filesize $PKGS/packages.txt)" | dblog
al@857 188 _ 'Done: %s (%s)' 'packages.info' "$(filesize $PKGS/packages.info)" | dblog
al@857 189 _ 'Done: %s (%s)' 'packages.equiv' "$(filesize $PKGS/packages.equiv)" | dblog
al@857 190
al@857 191 cd $PKGS
al@857 192
al@857 193
al@862 194 # Check for unnecessary packages
al@857 195 if [ -s "$PKGS/packages.toremove" ]; then
al@857 196 newline | dblog
al@862 197 case x$rmpkg in
al@862 198 x) _ 'Found unnecessary packages (use `cook pkgdb --rmpkg` to remove):' | dblog;;
al@862 199 *) _ 'Removing unnecessary packages:' | dblog;;
al@862 200 esac
al@857 201 while read pkgsum pkgfile; do
al@857 202 echo " - $pkgfile" | dblog
al@857 203 sed -i "/${pkgfile%.tazpkg}/d" $PKGS/packages.list
al@857 204 sed -i "/ $pkgfile/d" $PKGS/packages.md5
al@857 205 [ -n "$rmpkg" ] && rm $PKGS/$pkgfile # remove packages only with --rmpkg
al@857 206 done < $PKGS/packages.toremove
al@857 207 newline | dblog
al@857 208 fi
al@857 209 rm $PKGS/packages.toremove
al@857 210
al@857 211
al@857 212 # files.list.lzma
al@857 213 _n 'Creating file "%s"' 'files.list.lzma' | dblog
al@857 214 touch files.list
al@857 215 # pkgs.slitaz.org strongly depends on list sorted by packages names
al@1024 216 #lzma e files.list files.list.lzma
al@1024 217 /bin/lzma -zeqcT0 files.list > files.list.lzma
al@857 218 echo " ($(filesize $PKGS/files.list.lzma))" | dblog
al@857 219
al@857 220 # Pre-sorting filenames causes 10% smaller resulting lzma file
al@857 221 _n 'Creating file "%s"' 'files-list.lzma' | dblog
al@857 222 cat files.list | sort -k2 -o files.list.sorted
al@1024 223 #lzma e files.list.sorted files-list.lzma
al@1024 224 /bin/lzma -zeqcT0 files.list.sorted > files-list.lzma
al@857 225 rm -f files.list files.list.sorted
al@857 226 echo " ($(filesize $PKGS/files-list.lzma))" | dblog
al@857 227
al@857 228 [ -e files.list.md5 ] && rm files.list.md5
al@857 229 md5sum files-list.lzma | cut -d' ' -f1 | tr -d $'\n' > files-list.md5
al@857 230
al@857 231 # Make bundle to fast recharge
al@857 232 _n 'Creating file "%s"' 'bundle.tar.lzma' | dblog
al@857 233 [ -f bundle.tar.lzma ] && rm bundle.tar.lzma
al@857 234 # Make sure to get "mirrors" file
al@857 235 until [ -e 'mirrors' ]; do
al@857 236 wget -q http://mirror1.slitaz.org/mirrors
al@857 237 echo -n '.' | dblog; sleep 5
al@857 238 done
al@857 239 # Make sure to get "extra.list" file
al@857 240 until [ -e 'extra.list' ]; do
al@857 241 wget -q -O extra.list http://mirror1.slitaz.org/packages/get.list
al@857 242 echo -n '.' | dblog; sleep 5
al@857 243 done
al@1024 244 busybox tar -chf bundle.tar \
al@857 245 mirrors extra.list files-list.md5 packages.info descriptions.txt \
al@857 246 packages.desc packages.md5 packages.txt packages.list packages.equiv
al@1024 247 /bin/lzma -zeqcT0 bundle.tar > bundle.tar.lzma
al@1024 248 rm ./bundle.tar ./mirrors
al@857 249 echo " ($(filesize $PKGS/bundle.tar.lzma))" | dblog
al@857 250
al@857 251 # Display some info.
al@857 252 separator | dblog
al@968 253 nb=$(ls $PKGS/*.tazpkg 2>/dev/null | wc -l)
al@857 254 time=$(($(date +%s) - $time))
al@857 255 # L10n: 's' is for seconds (cooking time)
al@857 256 { _ 'Packages: %s - Time: %ss' "$nb" "$time"; newline; } | dblog
al@857 257
al@857 258
al@857 259 # Create all flavors files at once. Do we really need code to monitor
al@857 260 # flavors changes? Let's just build them with packages lists before
al@857 261 # syncing the mirror.
al@899 262 [ "$1" != '--flavors' ] && rm $command && exit 1
al@857 263
al@857 264 if [ ! -d "$flavors" ]; then
al@857 265 { _ 'Missing flavors folder "%s"' "$flavors"; newline; } | dblog
al@899 266 rm $command
al@857 267 exit 1
al@857 268 fi
al@857 269
al@857 270 [ ! -d "$live" ] && mkdir -p $live
al@857 271 _ 'Creating flavors files in "%s"' "$live" | dblog
al@857 272 _ 'Cook pkgdb: Creating all flavors' | log
al@857 273 separator | dblog
al@857 274
al@857 275 _ 'Recharging lists to use latest packages...' | dblog
al@857 276 tazpkg recharge >/dev/null 2>/dev/null
al@857 277
al@857 278 # We need a custom tazlito config to set working dir to /home/slitaz.
al@857 279 if [ ! -f "$live/tazlito.conf" ]; then
al@857 280 _ 'Creating configuration file "%s"' 'tazlito.conf' | dblog
al@857 281 cp /etc/tazlito/tazlito.conf $live
al@857 282 sed -i s@WORK_DIR=.*@WORK_DIR=\"/home/slitaz\"@ \
al@857 283 $live/tazlito.conf
al@857 284 fi
al@857 285
al@857 286 # Update Hg flavors repo and pack.
al@857 287 if [ -d "$flavors/.hg" ]; then
al@857 288 cd $flavors; hg pull -u
al@857 289 fi
al@857 290
al@857 291 cd $live
al@857 292 _ 'Starting to generate flavors...' | dblog
al@857 293 rm -f flavors.list *.flavor
al@857 294 for i in $flavors/*; do
al@857 295 fl=$(basename $i)
al@857 296 _ 'Packing flavor "%s"' "$fl" | dblog
al@857 297 tazlito pack-flavor $fl >/dev/null || exit 1
al@857 298 tazlito show-flavor $fl --brief --noheader 2>/dev/null >> flavors.list
al@857 299 done
al@857 300 cp -f $live/*.flavor $live/flavors.list $PKGS
al@857 301 separator | dblog
al@857 302 { _ 'Total flavors size: %s' "$(du -sh $live | awk '{print $1}')"; newline; } | dblog
al@857 303 separator | dblog
al@857 304 _ 'Cook pkgdb end: %s' "$(date "$(_ '+%%F %%R')")" | dblog
al@857 305
al@899 306 rm $command
al@876 307
al@857 308
al@857 309 exit 0