die() {
echo $* 1>&2
+ zpm log -i -a 'aborting install' -p "$pkgid" "$*"
exit 1
}
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
# zpm runscript -p pre-upgrade $current $pkgid
zpm runscript -f $pkgfile -p pre-install $pkgid $current
if [ $? -ne 0 ]; then
- # TODO log
die "pre-install script for $pkgid failed"
fi
fi
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
zpm syncfs $syncopts -f $pkgfile
if [ $? -ne 0 ]; then
+ zpm pkg $pkgid status=failed
die 'zpm-syncfs failed';
fi