X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-install;h=64b064bf7170d90e4b85f9e12b53374f41a82946;hb=62e2d81f8e5c1a2284660752524753638ae59766;hp=8d259c0be2ad9d4d40a9a2759e209b261d238545;hpb=d3b90e6aa8ab580c77ead76ff5c6c6dca7991cc6;p=zpackage diff --git a/zpm-install b/zpm-install index 8d259c0..64b064b 100755 --- a/zpm-install +++ b/zpm-install @@ -1,105 +1,240 @@ #!/bin/sh -#package=${1:-$ZPMPACKAGE} -pkgver=${ZPMPACKAGEVER:-1.0} -pkgrel=${ZPMPACKAGEREL:-1} - -pkgroot=/ - -# allocate an install id, perhaps hash package and timestamp -# installid=$(echo $(date) $pkglist | zpm hash) - -# extract pre-scripts and run them -# get list of paths to install -# for each path, if directory, create and set mode -# for each path, create leading directories -# extract to something like /var/tmp/.hash, with low perms -# only atomic if same filesystem, so use .installid.hash in the -# install directory -# set perms and such -# move into place -# after all the files, extract post scripts and run them - -# also need to mark package as installing so if it fails part way -# through, it can be finished later -# probably also want an option to "backup" any packages being upgraded -# so it's trivial to downgrade or to revert if the install fails - -# option for "multipackage" just to let the system know that's what you meant -# option to take filenames from stdin -# parse package, version, release from file if not given -# TODO what's the difference between prefix and pkgroot -# need an option to not chown the files -# option to install but not merge/track -while getopts :f:v:r:d:a:u:l:p:b:P:R: opt; do - case $opt in - R) pkgroot="$OPTARG" ;; - f) pkgfile="$OPTARG" ;; - v) pkgver="$OPTARG" ;; - r) pkgrel="$OPTARG" ;; - d) description="$OPTARG" ;; - a) arch="$OPTARG" ;; - u) url="$OPTARG" ;; - l) licenses="$OPTARG" ;; - p) packager="$OPTARG" ;; - b) builddate="$OPTARG" ;; - P) prefix="$OPTARG" ;; - esac -done -shift $((OPTIND - 1)) +warn() { + echo $* 1>&2 +} die() { echo $* 1>&2 + zpm log -i -a 'aborting install' -t "$pkgid" "$*" exit 1 } +dryrun=0 +verbose=0 +runscripts=1 +runconfigure=1 +absorb=0 +overwrite=0 +syncopts='' + +# zpm-install [-SCn] [ -d localdb ] [ -f pkgfile ] [ -R installroot ] pkgstr ... +while getopts f:d:R:nSCvAO opt; do + case $opt in + f) pkgfile="$OPTARG" ;; + d) localdb="$OPTARG" ;; + R) rootdir="$OPTARG" ;; + S) runscripts=0 ;; + C) runconfigure=0 ;; + A) absorb=1; syncopts="${syncopts} -A" ;; + O) overwrite=1; syncopts="${syncopts} -O" ;; + n) dryrun=1 ;; + v) verbose=1 ;; + *) die "usage ..." ;; + esac +done +shift $(( OPTIND - 1)) + +pkgid=$1 + +if [ -z "$pkgid" ]; then + die "must specify pkgid" +fi + +eval "$(zpm parse -E $pkgid)" + if [ -z "$pkgfile" ]; then - # actually, if no pkgfile, get pkgfile from repo - # but need to loop over finding package files then - # so this program probably needs to be "install from pkgfile" - # and a separate one that will loop over a package - # spec list and find from repos - die "must specify package file" - pkgfile="$package-$pkgver-$pkgrel.zpm" + pkgfile=$ZPM_PACKAGE_FILE fi -set -e -zpm test -v $pkgfile +# cases R = full package id, F = specified package file -if [ $# -gt 0 ]; then - pkglist="$@" -else - pkglist=$(zpm findpkg $pkgfile) +# immediate error +# -- 00 error, must specify something +if [ -z "$release" ] && [ -z "$pkgfile" ]; then + die must specify package file or complete package id fi -pathlist() { - sqlite3 $pkgfile<&2 + if [ $dryrun -gt 0 ]; then + #zpm list -v + #zpm shell $ZPMDB 'select * from install_status' + zpm syncfs $syncopts -nv -f $pkgfile + zpm pkg $pkgid status=dryrun + continue + fi + + if [ $verbose -gt 0 ]; then + syncopts="${syncopts} -v" + fi + + zpm syncfs $syncopts -f $pkgfile + + if [ $? -ne 0 ]; then + zpm pkg $pkgid status=failed + die 'zpm-syncfs failed'; + fi + + if [ $runscripts -gt 0 ]; then + zpm script -f $pkgfile -p post-install $pkgid $current + fi + + if [ -n "$current" ]; then + zpm pkg $pkgid status=installed :$current status=updated + else + zpm pkg $pkgid status=installed + fi + + if [ $(id -u) -eq 0 ]; then + if [ ! -d $rootdir/etc ]; then + warn "no etc directory in $rootdir, skipping ldconfig" + elif [ -f $rootdir/sbin/ldconfig ]; then + $rootdir/sbin/ldconfig -r ${rootdir:-/} + elif [ -f /sbin/ldconfig ]; then + /sbin/ldconfig -r ${rootdir:-/} + else + true + fi + fi + + # TODO skip configure if not on a terminal, regardless of settings + # TODO will need force option + if [ $runconfigure -gt 0 ]; then + zpm script -f $pkgfile -p configure $pkgid $current + else + true + fi +done