X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-contents;h=6cdd485d4562397bb10baffac3334fe5d156c40a;hb=50b0480e6259c1e4bed6e6dc7990e080ceb5e855;hp=23c07ae29a1d327050f8c5a06e953c5b141083c0;hpb=e2dfb7252f431080ce11afa01e08729e59d97116;p=zpackage diff --git a/zpm-contents b/zpm-contents index 23c07ae..6cdd485 100755 --- a/zpm-contents +++ b/zpm-contents @@ -1,44 +1,97 @@ #!/bin/sh -pkgfile=${ZPMDB:-/var/lib/zpm/db.zpm} +pkgfile=${ZPMDB:-/var/lib/zpm/local.db} -verbose=0 +long=0 +pkgonly=0 +quiet=0 +config=include +showsoname=0 -while getopts f:v opt; do +while getopts f:qlncCL opt; do case $opt in f) pkgfile="$OPTARG" ;; - v) verbose=1 + l) long=1 ;; + n) pkgonly=1 ;; + q) quiet=1 ;; + c) config=only ;; + C) config=exclude ;; + L) showsoname=1 ;; esac done shift $((OPTIND - 1)) -set -e - if [ ! -f $pkgfile ]; then echo cannot find $pkgfile exit 1 fi -cols= -if [ $verbose -gt 0 ]; then - cols="filetype,printf('%4.4s', mode) as mode,username,groupname," +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) - - zpm shell $pkgfile < %%s', path, target)\n" + if [ $showsoname -eq 1 ]; then + printf "when EL.soname is not null then printf('%%s (%%s)', path, EL.soname)\n" + fi + printf "else path end as path\n" + fi + printf 'from packagefiles_pkgid PF left join elflibraries EL on EL.file = PF.hash\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 + case $config in + only) printf "and configuration = 1\n" ;; + exclude) printf "and configuration = 0\n" ;; + esac + printf 'order by pkgid,path\n' + printf ';\n' +} | zpm shell $pkgfile +#} | cat