spk annotate spk-add @ rev 57

spk-add: log install message
author Christophe Lincoln <pankso@slitaz.org>
date Thu May 17 15:04:31 2012 +0200 (2012-05-17)
parents 256ff61b7248
children 17ac07667767
rev   line source
pankso@27 1 #!/bin/sh
meshca@11 2 #
pankso@23 3 # Spk-add - Install SliTaz packages. Read the README before adding or
pankso@23 4 # modifing any code in spk!
pankso@23 5 #
pankso@23 6 # Copyright (C) SliTaz GNU/Linux - BSD License
pankso@23 7 # Author: See AUTHORS files
pankso@23 8 #
pankso@50 9 . /usr/lib/slitaz/libspk.sh
meshca@11 10
pankso@50 11 tmpdir="/tmp/spk/$RANDOM"
meshca@11 12
pankso@23 13 #
pankso@23 14 # Functions
pankso@23 15 #
pankso@23 16
pankso@23 17 # Help and usage
pankso@23 18 usage() {
pankso@23 19 name=$(basename $0)
pankso@23 20 cat << EOT
pankso@23 21
pankso@23 22 $(boldify $(gettext "Usage:")) $name [packages|--options]
pankso@23 23
pankso@23 24 $(gettext "Install SliTaz Packages")
pankso@23 25
pankso@23 26 $(boldify $(gettext "Options:"))
pankso@30 27 --forced $(gettext "Force package reinstallation")
pankso@30 28 --root= $(gettext "Set the root file system path")
pankso@40 29 --debug $(gettext "Display some usefull debug information")
pankso@23 30
pankso@23 31 $(boldify $(gettext "Examples:"))
pankso@23 32 $name package1 package2 packageN
pankso@23 33
pankso@23 34 EOT
pankso@23 35 exit 0
pankso@23 36 }
meshca@11 37
pankso@57 38 # Log install messages
pankso@57 39 log_install() {
pankso@57 40 debug "log_install: $logdir/$pkg/install.log"
pankso@57 41 mkdir -p $logdir/$pkg
pankso@57 42 tee $logdir/$pkg/install.log
pankso@57 43 }
pankso@57 44
pankso@29 45 # Update system databases
pankso@29 46 update_databases() {
pankso@34 47 if [ -f $root/usr/bin/update-desktop-database ] && [ -n "$updatedesktopdb" ]; then
pankso@34 48 chroot "$root/" /usr/bin/update-desktop-database /usr/share/applications 2>/dev/null
pankso@29 49 fi
pankso@29 50 # Mimetypes
pankso@34 51 if [ -f $root/usr/bin/update-mime-database ] && [ -n "$updatemimedb" ]; then
pankso@34 52 chroot "$root/" /usr/bin/update-mime-database /usr/share/mime
pankso@29 53 fi
pankso@29 54 # Icons
pankso@34 55 if [ -f $root/usr/bin/gtk-update-icon-cache ] && [ -n "$updateicondb" ]; then
pankso@34 56 chroot "$root/" /usr/bin/gtk-update-icon-cache /usr/share/icons/hicolor
pankso@29 57 fi
pankso@29 58 # Glib schemas
pankso@34 59 if [ -f $root/usr/bin/glib-compile-schemas ] && [ -n "$compile_schemas" ]; then
pankso@34 60 chroot "$root/" /usr/bin/glib-compile-schemas /usr/share/glib-2.0/schemas
pankso@29 61 fi
pankso@29 62 # Kernel modules
pankso@34 63 if [ -f $root/sbin/depmod ] && [ -n "$updatedepmod" ]; then
pankso@34 64 chroot "$root/" /sbin/depmod -a
pankso@29 65 fi
pankso@29 66 }
pankso@29 67
meshca@11 68 # This function installs a package in the rootfs.
meshca@11 69 # Parameters: package_name package_file
pankso@23 70 install_package() {
meshca@11 71 local package_file=$1
pankso@23 72
meshca@11 73 # Set by receipt: pre_depends() DEPENDS SELF_INSTALL CONFIG_FILES post_install()
pankso@23 74
meshca@11 75 local package_name=$PACKAGE
meshca@11 76 local package_dir="$installed/$package_name"
pankso@55 77 mkdir -p $package_dir || exit 1
meshca@11 78
meshca@11 79 # Run pre_depends from receipt if it exists
pankso@34 80 if grep -q ^pre_depends $tmpdir/receipt; then
pankso@34 81 pre_depends $root
meshca@11 82 fi
meshca@11 83
meshca@11 84 # Resolve package deps.
meshca@11 85 if missing_deps $package_name $DEPENDS; then
pankso@53 86 if [ "$confirm" ]; then
pankso@53 87 gettext "Install missing dependencies"
pankso@53 88 if ! confirm; then
pankso@53 89 gettext "WARNING: Any dependencies installed"; newline
pankso@53 90 else
pankso@53 91 install_deps $package_name $DEPENDS
pankso@53 92 fi
pankso@53 93 else
pankso@53 94 install_deps $package_name $DEPENDS
pankso@53 95 fi
pankso@53 96 else
pankso@53 97 newline
meshca@11 98 fi
pankso@23 99
pankso@57 100 boldify $(gettext "Adding"; echo " $package_name")
meshca@11 101 separator
pankso@34 102 gettext "Copying"; echo -n " $package_name..."
pankso@34 103 cp $package_file $tmpdir
meshca@11 104 status
pankso@23 105
pankso@50 106 # Add package checksum to $installed.$SUM
pankso@53 107 if [ "$verbose" ]; then
pankso@53 108 gettext "Incrementing:"; echo -n " $(basename $installed.$SUM)"
pankso@53 109 fi
pankso@53 110 sed -i "/$(basename $package_file)/"d $installed.$SUM 2>/dev/null
pankso@50 111 $CHECKSUM $(basename $package_file) >> $installed.$SUM
pankso@50 112 [ "$verbose" ] && status
pankso@50 113
meshca@11 114 # Extract Package
pankso@34 115 cd $tmpdir || exit 1
pankso@26 116 rm receipt
pankso@26 117 spk-archive extract $package_file
pankso@26 118 cd - >/dev/null
pankso@23 119
meshca@11 120 # Get files to remove if upgrading
meshca@11 121 local files_to_remove
meshca@11 122 if [ -f $package_dir/files.list ]; then
pankso@32 123 for file in $(cat $package_dir/files.list)
pankso@32 124 do
pankso@54 125 grep -q "^$(echo $file | grepesc)$" $tmpdir/files.list && continue
pankso@32 126 local modifiers=$(cat $package_dir/modifiers 2> /dev/null; \
pankso@37 127 fgrep -sl $package_dir */modifiers | cut -d/ -f1)
meshca@11 128 for i in modifiers; do
pankso@54 129 grep -qs "^$(echo $file | grepesc)$" $i/files.list && continue 2
meshca@11 130 done
meshca@11 131 files_to_remove="$files_to_remove $file"
meshca@11 132 done
meshca@11 133 fi
meshca@43 134 debug "file_to_remove: $files_to_remove"
pankso@23 135
pankso@38 136 # Create list of all possibly modified files
meshca@11 137 local file_list
pankso@34 138 for i in $(fgrep -v [ $tmpdir/files.list); do
pankso@34 139 [ -e "${root}${i}" ] || continue
pankso@34 140 [ -d "${root}${i}" ] && continue
meshca@11 141 file_list="$file_list $i"
meshca@11 142 done
pankso@50 143
meshca@43 144 debug "file_list is set"
pankso@23 145
pankso@37 146 # Check possibly modified files against other packages files.list
meshca@43 147 debug "check modified files"
pankso@38 148 for file in $file_list
pankso@38 149 do
pankso@55 150 local filegrep=$(egrep ^${file}$ $installed/*/files.list)
pankso@38 151 if [ "$filegrep" ]; then
pankso@38 152 local list=$(echo $filegrep | cut -d ":" -f 1)
pankso@55 153 local count=0
meshca@44 154 for pkg_file in $list; do
meshca@44 155 local name=$(basename $(dirname $pkg_file))
pankso@55 156 [ "$package_name" == "$name" ] && continue 2
pankso@55 157 count=$(($count +1))
pankso@55 158 [ "$count" == "1" ] && gettext "Modified package:"; \
pankso@55 159 colorize " $name" 31
pankso@55 160 gettext "Overwriting file:"; echo " $file"
pankso@55 161 # If confirm is set, ask to remove. Do we want that ?
pankso@55 162 # If gawk is installed for example we will never remove Busybox
pankso@55 163 # Use CONFLICTS receipt variable to avoid
pankso@55 164 if [ "$confirm" ]; then
pankso@55 165 echo -n "NOTE: confirm: spk-rm $name ???"; read
meshca@44 166 fi
meshca@44 167 done
pankso@38 168 fi
pankso@38 169 done
pankso@23 170
pankso@34 171 cd $tmpdir || exit 1
pankso@55 172 cp receipt files.list $package_dir || exit 1
pankso@33 173
pankso@26 174 # Copy the description if found.
pankso@26 175 [ -f "description.txt" ] && cp description.txt $package_dir
pankso@23 176
pankso@26 177 # Pre install commands.
pankso@26 178 if grep -q ^pre_install $package_dir/receipt; then
pankso@34 179 pre_install $root
pankso@26 180 fi
pankso@23 181
pankso@26 182 # Handle Config Files from receipt
pankso@26 183 if [ -n "$CONFIG_FILES" ]; then
pankso@26 184 cd $fs || exit 1
pankso@26 185 # save 'official' configuration files
pankso@26 186 eval_gettext "Saving configuration files for \$package_name... "
pankso@23 187
pankso@26 188 local confs
pankso@26 189 for i in $CONFIG_FILES; do
pankso@26 190 confs="$confs $(find ${i#/} -type f 2> /dev/null)"
pankso@26 191 done
pankso@23 192
pankso@34 193 echo $confs | cpio -o -H newc --quiet | gzip -9 > \
pankso@34 194 $package_dir/volatile.cpio.gz
pankso@23 195
pankso@26 196 # keep user configuration files
pankso@34 197 for configfile in $confs; do
pankso@34 198 [ -e $configfile ] || continue
pankso@34 199 cp -a $configfile fs/$configfile
pankso@26 200 done
pankso@26 201 status
pankso@26 202 cd - >/dev/null
pankso@26 203 fi
pankso@23 204
pankso@26 205 # Merge ROOT_FS with Package FS
pankso@34 206 gettext "Installing in:"; echo -n " $root/"
pankso@34 207 cp -a fs/* $root/
pankso@26 208 status
pankso@26 209
pankso@26 210 # Remove old config files
pankso@32 211 if [ "$files_to_remove" ]; then
pankso@32 212 gettext "Removing old"; echo -n " $package_name..."
pankso@26 213 for file in $files_to_remove; do
pankso@32 214 if [ "$verbose" ]; then
pankso@32 215 gettext "Removing:"; echo " ${root}${file}"
pankso@32 216 fi
pankso@32 217 remove_with_path ${root}${file}
pankso@26 218 done
meshca@11 219 status
pankso@26 220 fi
pankso@26 221 cd - >/dev/null
pankso@23 222
meshca@11 223 # Remove the temporary directory.
meshca@11 224 gettext "Removing all tmp files... "
pankso@34 225 rm -rf $tmpdir
meshca@11 226 status
pankso@23 227
meshca@11 228 # Post install commands.
meshca@11 229 if grep -q ^post_install $package_dir/receipt; then
pankso@34 230 post_install $root
meshca@11 231 fi
pankso@23 232
meshca@11 233 # Update-desktop-database if needed.
meshca@11 234 if [ "$(fgrep .desktop $package_dir/files.list | fgrep /usr/share/applications/)" ]; then
meshca@11 235 updatedesktopdb=yes
meshca@11 236 fi
meshca@11 237 # Update-mime-database if needed.
meshca@11 238 if [ "$(fgrep /usr/share/mime $package_dir/files.list)" ]; then
meshca@11 239 updatemimedb=yes
meshca@11 240 fi
meshca@11 241 # Update-icon-database
meshca@11 242 if [ "$(fgrep /usr/share/icon/hicolor $package_dir/files.list)" ]; then
meshca@11 243 updateicondb=yes
meshca@11 244 fi
meshca@11 245 # Compile glib schemas if needed.
meshca@11 246 if [ "$(fgrep /usr/share/glib-2.0/schemas $package_dir/files.list)" ]; then
meshca@11 247 compile_schemas=yes
meshca@11 248 fi
meshca@11 249 # Update depmod list
meshca@11 250 if [ "$(fgrep /lib/modules $package_dir/files.list)" ]; then
meshca@11 251 updatedepmod=yes
meshca@11 252 fi
meshca@11 253 separator
pankso@57 254 echo -n "$package_name ${VERSION}${EXTRAVERSION} "
pankso@57 255 gettext "is installed"; newline
meshca@11 256 newline
meshca@11 257 }
meshca@11 258
meshca@11 259 # Install .tazpkg packages.
meshca@11 260 # Parameters: package_file
pankso@28 261 install_local() {
meshca@11 262 package_file="$1"
pankso@55 263 #check_valid_tazpkg $package_file
pankso@55 264 if [ -f "$package_file" ]; then
pankso@55 265 if [ $(dirname $package_file) == "." ]; then
pankso@55 266 package_file=$(pwd)/$package_file
pankso@55 267 fi
pankso@55 268 debug "package file: $package_file"
pankso@55 269 else
pankso@55 270 gettext "Unable to find:"; echo " $package_file"
pankso@55 271 exit 1
pankso@55 272 fi
pankso@55 273
pankso@55 274 # Get package name now to check if installed
pankso@55 275 mkdir -p $tmpdir
pankso@55 276 extract_receipt $tmpdir $package_file
pankso@55 277 source $tmpdir/receipt
pankso@55 278 [ "$forced" ] || check_installed $PACKAGE
pankso@56 279 [ "$count" == "1" ] && newline
meshca@11 280 install_package $package_file
pankso@29 281 update_databases
meshca@11 282 }
meshca@11 283
meshca@11 284 # Download and install a package. TODO: Handle Undigest Mirrors
meshca@11 285 # Parameters: package_name
pankso@28 286 install_web() {
meshca@11 287 local package_name="$1"
meshca@11 288
meshca@11 289 # Check if get-Package
meshca@11 290 if ! is_package_mirrored $package_name; then
meshca@11 291 package_name="get-$package_name"
meshca@11 292 AUTOEXEC=true
meshca@11 293 fi
meshca@11 294
meshca@11 295 # Check if package is mirrored
meshca@11 296 if ! is_package_mirrored $package_name; then
pankso@26 297 gettext "Could not find package on mirror:"; echo " $package_name"
meshca@11 298 exit 1
meshca@11 299 fi
meshca@11 300
meshca@11 301 # package_full=Package-Version
meshca@11 302 local package_full=$(full_package $package_name)
pankso@23 303
pankso@26 304 cd $CACHE_DIR > /dev/null
pankso@26 305 if [ -f "$package_full.tazpkg" ]; then
pankso@39 306 [ "$count" == 1 ] && newline
pankso@39 307 gettext "Using cache:"; echo " $(colorize "$package_full" 34)"
pankso@26 308 # Check package download was finished
pankso@26 309 if ! tail -c 2k $package_full.tazpkg | fgrep -q 00000000TRAILER; then
pankso@53 310 gettext "Continuing download of:"; echo " $package_name"
pankso@26 311 download "$package_full.tazpkg"
pankso@26 312 fi
pankso@26 313 # Check that the package has the correct checksum
pankso@30 314 #if [ "$($CHECKSUM $package_full.tazpkg)" != "$(fgrep \" $package_full.tazpkg\" $pkgsmd5)" ]; then
pankso@30 315 # rm -f $package.tazpkg
pankso@30 316 # download "$package_full.tazpkg"
pankso@30 317 #fi
pankso@26 318 else
pankso@53 319 newline && download "$package_full.tazpkg"
pankso@26 320 fi
pankso@23 321
pankso@55 322 # Create package path early to avoid dependencies loop
pankso@55 323 mkdir -p $tmpdir
pankso@55 324 extract_receipt $tmpdir "$CACHE_DIR/$package_full.tazpkg"
pankso@55 325 source $tmpdir/receipt
pankso@55 326
meshca@11 327 install_package "$CACHE_DIR/$package_full.tazpkg"
pankso@23 328
pankso@53 329 #[ "$AUTOEXEC" ] && chroot $root/ $package_name
pankso@53 330 [ "$AUTOEXEC" ] && $package_name $root
pankso@29 331 update_databases
meshca@11 332 }
meshca@11 333
pankso@53 334 # Install all missing deps of a package.
pankso@53 335 # Usage: install_deps package DEPENDS
meshca@11 336 install_deps() {
meshca@11 337 local package=$1
meshca@11 338 shift
meshca@11 339 local deps="$@"
pankso@53 340 for pkgorg in $deps; do
pankso@53 341 local pkg=$(equivalent_pkg $pkgorg)
pankso@53 342 # Check if package is not installed
pankso@53 343 if [ ! -d "$installed/$pkg" ]; then
pankso@53 344 if [ ! -f "$PKGS_DB/packages.list" ]; then
pankso@53 345 #spk-up --recharge-only
pankso@53 346 tazpkg recharge
meshca@11 347 fi
pankso@53 348 spk-add $pkg
pankso@53 349 fi
pankso@53 350 done
meshca@11 351 }
meshca@11 352
pankso@30 353 #
pankso@30 354 # Commands and exit
pankso@30 355 #
pankso@30 356
pankso@30 357 case "$1" in
pankso@30 358 ""|*usage|*help) usage ;;
meshca@11 359 esac
pankso@24 360
pankso@28 361 #
pankso@28 362 # Handle packages: package package.tazpkg ... packageN packageN.tazpkg
pankso@28 363 #
pankso@28 364
pankso@51 365 : ${count=0}
pankso@28 366 check_root
pankso@28 367
pankso@24 368 for pkg in $@
pankso@24 369 do
pankso@28 370 case "$pkg" in
pankso@30 371 *.tazpkg|*.spk)
pankso@56 372 count=$(($count + 1))
pankso@57 373 install_local $pkg | log_install ;;
pankso@55 374 *.deb|.rmp)
pankso@55 375 echo "TODO: spk-convert then install" ;;
pankso@55 376 *.*) gettext "WARNING: Not a valid package:"; echo " $pkg" ;;
pankso@30 377 --*) continue ;;
pankso@30 378 *)
pankso@30 379 [ "$forced" ] || check_installed $pkg
pankso@39 380 count=$(($count + 1))
pankso@57 381 install_web $pkg | log_install ;;
pankso@28 382 esac
pankso@24 383 done
pankso@56 384
pankso@56 385 # Show all new counted packages in verbose mode
pankso@56 386 if [ "$verbose" ]; then
pankso@56 387 gettext "New installed packages:"; colorize " $count" 34
pankso@56 388 fi
pankso@56 389
pankso@24 390 exit 0