X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-install;h=64b064bf7170d90e4b85f9e12b53374f41a82946;hb=e8412186c6099fa67c7bb9c7547e42d7490c7edb;hp=815d610f62e7aa246f3f5c099182718a312e29d4;hpb=f80dff40dd80d4775e66fc4cbb557b56cfea7aa6;p=zpackage diff --git a/zpm-install b/zpm-install index 815d610..64b064b 100755 --- a/zpm-install +++ b/zpm-install @@ -6,6 +6,7 @@ warn() { die() { echo $* 1>&2 + zpm log -i -a 'aborting install' -t "$pkgid" "$*" exit 1 } @@ -88,7 +89,7 @@ package=$(zpm quote "$name") pkgver=$(zpm quote "$version") pkgrel=$(zpm quote "$release") -if [ -z "$rootdir" ]; then +if [ -n "$rootdir" ]; then : rootdir=${rootdir%%/} fi @@ -97,6 +98,9 @@ if [ -z "$localdb" ]; then fi if [ ! -f "$localdb" ]; then + if [ -n "$rootdir" ] && [ ! -d $rootdir ]; then + mkdir $rootdir || die "can't create $rootdir: $!" + fi for d in /var /var/lib /var/lib/zpm; do test -d $rootdir/$d || mkdir $rootdir/$d || die "can't create $rootdir/$d/: $!" done @@ -141,11 +145,9 @@ if [ -n "$rootdir" ]; then export ZPM_ROOT_DIR fi -# TODO mark already installed packages as updating? for pkgstr in "$@"; do pkgid=$(zpm findpkg -f $pkgfile $pkgstr) if [ $? -ne 0 ]; then - # TODO log die "can't find package $pkgstr in $pkgfile" fi @@ -162,9 +164,8 @@ for pkgstr in "$@"; do if [ $runscripts -gt 0 ]; then # TODO run pre-upgrade script if needed # zpm runscript -p pre-upgrade $current $pkgid - zpm runscript -f $pkgfile -p pre-install $pkgid $current + zpm script -f $pkgfile -p pre-install $pkgid $current if [ $? -ne 0 ]; then - # TODO log die "pre-install script for $pkgid failed" fi fi @@ -181,11 +182,11 @@ for pkgstr in "$@"; do zpm rmpackage $pkgid zpm merge -f $pkgfile -s installing $pkgid if [ $? -ne 0 ]; then - # TODO log die "merging $pkgid failed" fi + else + zpm pkg $pkgid status=installing fi - # TODO but need to mark as installing if not merged #zpm shell $ZPMDB 'select * from install_status' 1>&2 if [ $dryrun -gt 0 ]; then @@ -203,11 +204,12 @@ for pkgstr in "$@"; do 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 runscript -f $pkgfile -p post-install $pkgid $current + zpm script -f $pkgfile -p post-install $pkgid $current fi if [ -n "$current" ]; then @@ -231,6 +233,8 @@ for pkgstr in "$@"; do # TODO skip configure if not on a terminal, regardless of settings # TODO will need force option if [ $runconfigure -gt 0 ]; then - zpm runscript -f $pkgfile -p configure $pkgid $current + zpm script -f $pkgfile -p configure $pkgid $current + else + true fi done