From 9e4e730ecc2b7d5b99bd057f3a7efaff7e4b37d0 Mon Sep 17 00:00:00 2001 From: Nathan Wagner Date: Tue, 13 Nov 2018 20:13:03 +0000 Subject: [PATCH] rewrite merge merge everything if no package specified take -u option to delete the package before merge --- zpm-merge | 221 +++++++++++++++++++++++++----------------------------- 1 file changed, 104 insertions(+), 117 deletions(-) diff --git a/zpm-merge b/zpm-merge index aa2b71f..67b8c73 100755 --- a/zpm-merge +++ b/zpm-merge @@ -17,12 +17,13 @@ die() { verbose=0 mergefiles=0 mergescripts=1 -target=/var/lib/zpm/local.db +mergeall=1 +update=0 target=${ZPMDB:=/var/lib/zpm/local.db} # TODO option to merge all packages found in pkgfile -while getopts :f:vd:FSs: opt; do +while getopts :f:vd:FSs:au opt; do case $opt in f) pkgfile="$OPTARG" ;; v) verbose=1 ;; @@ -30,6 +31,9 @@ while getopts :f:vd:FSs: opt; do F) mergefiles=1 ;; S) mergescripts=0 ;; s) newstatus="$OPTARG" ;; + a) mergeall=1 ;; + u) update=1 ;; + *) echo 'zpm-merge unknown option' $OPTARG; exit 1 ;; esac done @@ -42,141 +46,124 @@ fi zpm test -v "$target" || exit 1 +if [ $# -eq 0 ]; then + mergeall=1 +else + mergeall=0 +fi + # TODO if pkgfile is specified, allow multiple packages as args -pkgid=$1 -shift +if [ $mergeall -eq 0 ]; then + pkgid=$1 + shift -if [ -z "$pkgid" ]; then - die "must specify pkgid" -fi + if [ -z "$pkgid" ]; then + die "must specify pkgid" + fi -eval "$(zpm parse -E $pkgid)" + eval "$(zpm parse -E $pkgid)" -if [ -z "$pkgfile" ]; then - pkgfile=$ZPM_PACKAGE_FILE -fi + if [ -z "$pkgfile" ]; then + pkgfile=$ZPM_PACKAGE_FILE + fi -# calculate package id, pkgfile, etc -# cases R = full package id, F = specified package file + # calculate package id, pkgfile, etc + # cases R = full package id, F = specified package file -# immediate error -# --- 000 error, must specify something -if [ -z "$release" ] && [ -z "$pkgfile" ]; then - die must specify package file or complete package id -fi + # immediate error + # --- 000 error, must specify something + if [ -z "$release" ] && [ -z "$pkgfile" ]; then + die must specify package file or complete package id + fi -# try to get from package file -if [ -z "$release" ]; then - pkgid=$(zpm findpkg -f $pkgfile $pkgid) - if [ -z "$pkgid" ]; then - die cannot find package id + # try to get from package file + if [ -z "$release" ]; then + pkgid=$(zpm findpkg -f $pkgfile $pkgid) + if [ -z "$pkgid" ]; then + die cannot find package id + fi + eval "$(zpm parse -E $pkgid)" fi - eval "$(zpm parse -E $pkgid)" -fi -# --F 001 error, wouldn't know which pkgid to create, could derive from file? -if [ -z "$release" ]; then - die must specify complete package id -fi + # --F 001 error, wouldn't know which pkgid to create, could derive from file? + if [ -z "$release" ]; then + die must specify complete package id + fi -# set file from pkgid -# -R- 010 set file from pkgid, create in file, error if no file -if [ -z "$pkgfile" ]; then - pkgfile="$pkgid.zpm" -fi + # set file from pkgid + # -R- 010 set file from pkgid, create in file, error if no file + if [ -z "$pkgfile" ]; then + pkgfile="$pkgid.zpm" + fi -if [ $verbose -gt 0 ]; then - echo merging $pkgfile $pkgid into $target + if [ $verbose -gt 0 ]; then + echo merging $pkgfile $pkgid into $target + fi + pkglist=$pkgid +else + pkglist=$(zpm list "$pkgfile") fi zpm test -v "$pkgfile" || exit 1 -merged=$(zpm shell "$target" "select 1 from packages_pkgid where pkgid = '$pkgid'") -if [ -n "$merged" ]; then - die "$pkgid already exists in $target"; +if [ -n "$newstatus" ]; then + newstatus=$(zpm quote "$newstatus") fi -# TODO file tags and package tags -{ -cat <