X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-contents;h=d6a5996ba34846945b7db0b68074f0314e88b84a;hb=62e2d81f8e5c1a2284660752524753638ae59766;hp=3d1d13fc29ca93f08fb63bc9e1d91942f068afc1;hpb=51a6d79f8a532376a9f27dbb5133bf13a5474703;p=zpackage diff --git a/zpm-contents b/zpm-contents index 3d1d13f..d6a5996 100755 --- a/zpm-contents +++ b/zpm-contents @@ -2,31 +2,89 @@ pkgfile=${ZPMDB:-/var/lib/zpm/db.zpm} -while getopts f: opt; do +long=0 +pkgonly=0 +quiet=0 + +while getopts f:qln opt; do case $opt in f) pkgfile="$OPTARG" ;; + l) long=1 ;; + n) pkgonly=1 ;; + q) quiet=1 ;; esac done shift $((OPTIND - 1)) -set -e - if [ ! -f $pkgfile ]; then echo cannot find $pkgfile exit 1 fi +if [ $long -gt 0 ]; then + cols="filetype,printf('%.4s', mode) as mode,username,groupname," +fi + +if [ $pkgonly -eq 1 ]; then + cols="pkgid" +elif [ $quiet -eq 0 ]; then + cols="pkgid,$cols" +fi -for pkg in "$@"; do - pkgid=$(zpm findpkg -f $pkgfile $pkg) +pkglist= +while [ $# -gt 0 ]; do + pkg=$1 + shift + if [ "$pkg" = '--' ]; then + break; + fi - zpm shell $pkgfile < %s', path, target) + else + path + end as path + EOC + fi + printf 'from packagefiles_pkgid\nwhere true\n' + if [ -n "$globlist" ]; then + printf "and (%s)\n" "$globlist" + fi + if [ -n "$pkglist" ]; then + printf "and pkgid in (%s)\n" "$pkglist" + fi + printf 'order by pkgid,path\n' + printf ';\n' +} | zpm shell $pkgfile +#} | cat