]> pd.if.org Git - zpackage/commitdiff
rework zpm-merge
authorNathan Wagner <nw@hydaspes.if.org>
Wed, 28 Nov 2018 11:39:14 +0000 (11:39 +0000)
committerNathan Wagner <nw@hydaspes.if.org>
Wed, 28 Nov 2018 11:39:14 +0000 (11:39 +0000)
zpm-merge

index 57a5359da73769da913f35af64359c02d99926ae..0af784927f8cf1533258b326d564ce3f4da46b00 100755 (executable)
--- a/zpm-merge
+++ b/zpm-merge
@@ -26,6 +26,7 @@ mergeall=1
 update=0
 remove_older=0
 only_if_newer=0
+one_at_a_time=0
 
 target=${ZPMDB:=/var/lib/zpm/local.db}
 
@@ -44,6 +45,7 @@ while getopts :f:vd:FSs:auon opt; do
                u) update=1 ;;
                o) remove_older=1 ;;
                n) only_if_newer=1 ;;
+               O) one_at_a_time=1 ;;
                *) echo 'zpm-merge unknown option' $OPTARG; exit 1 ;;
        esac
 done
@@ -150,21 +152,32 @@ mergeone() {
        fi
 }
 
-# check for already merged packages
-if [ $update -eq 0 ]; then
-       efail=0
+check_have() {
+       merged=$(zpm shell "$target" "select 1 from packages_pkgid where pkgid = '$1'")
+       test -n "$merged"
+}
 
-       for pkg in $pkglist; do
-               merged=$(zpm shell "$target" "select 1 from packages_pkgid where pkgid = '$pkgid'")
-               if [ -n "$merged" ]; then
-                       warn "$pkgid already exists in $target";
-                       efail=1
+filter_out_have() {
+       mlist=
+       for pkgid in "$@"; do
+               if ! check_have "$pkgid" ; then
+                       mlist="$mlist $pkgid"
                fi
        done
-       if [ $efail -eq 1 ]; then
-               die "aborting merge"
-       fi
-fi
+       mlist=${mlist#' '}
+       printf '%s' "$mlist"
+}
+
+filter_have() {
+       mlist=
+       for pkgid in "$@"; do
+               if check_have "$pkgid" ; then
+                       mlist="$mlist $pkgid"
+               fi
+       done
+       mlist=${mlist#' '}
+       printf '%s' "$mlist"
+}
 
 check_newer() {
        pkg=$1
@@ -176,26 +189,25 @@ check_newer() {
        return 1
 }
 
-mlist="$pkglist"
-if [ $only_if_newer -eq 1 ]; then
+filter_newer() {
        mlist=
-       for pkgid in $pkglist; do
+       for pkgid in "$@"; do
                if check_newer "$pkgid" ; then
                        mlist="$mlist $pkgid"
                fi
        done
-       if [ -z "$mlist" ]; then
-               exit 0
-       fi
-fi
+       mlist=${mlist#' '}
+       printf '%s' "$mlist"
+}
 
+merge_list() {
 # TODO file tags and package tags
-{
+(
        printf ".bail on\n"
        printf "attach '%s' as remote;\n" "$pkgfile"
        printf "begin;\n"
 
-       for pkgid in $pkglist; do
+       for pkgid in "$@"; do
                mergeone "$pkgid"
        done
 
@@ -203,8 +215,36 @@ fi
        printf "insert or ignore into elflibraries select * from remote.elflibraries;\n"
 
        printf "commit;\n"
-} | zpm shell $target
+) | zpm shell $target
 
 if [ $verbose -ne 0 ]; then
        printf "%s\n" $pkglist
 fi
+}
+
+# check for already merged packages
+if [ $update -eq 0 ] && [ $only_if_newer -eq 0 ]; then
+       have=$(filter_have $pkglist)
+       if [ -n "$have" ]; then
+               die "already merged: $have"
+       fi
+fi
+
+if [ $update -eq 0 ]; then
+       pkglist=$(filter_out_have $pkglist)
+fi
+
+if [ $only_if_newer -eq 1 ]; then
+       pkglist=$(filter_newer $pkglist)
+       if [ -z "$pkglist" ]; then
+               exit 0
+       fi
+fi
+
+if [ $one_at_a_time -eq 1 ]; then
+       for pkgid in $pkglist; do
+               merge_list $pkgid
+       done
+else
+       merge_list $pkglist
+fi