X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-contents;h=18fac9443dc45360dbb947f89c7bfcf40042c12f;hb=cc612731047e7f15a5e3c4cdd042793345764d7c;hp=447e095a1eab9d97dfbf084474a7ee6993fbf83f;hpb=3e81f5aec6dbb79f13ecfd50d506767fc6b5da7f;p=zpackage diff --git a/zpm-contents b/zpm-contents index 447e095..18fac94 100755 --- a/zpm-contents +++ b/zpm-contents @@ -8,8 +8,9 @@ quiet=0 config=include showsoname=0 status= +sharedlibsonly=0 -while getopts f:qlncCLI opt; do +while getopts f:qlncCLIs opt; do case $opt in f) pkgfile="$OPTARG" ;; l) long=1 ;; @@ -18,7 +19,8 @@ while getopts f:qlncCLI opt; do c) config=only ;; C) config=exclude ;; L) showsoname=1 ;; - I) status=installed + s) sharedlibsonly=1 ;; + I) status=installed ;; esac done shift $((OPTIND - 1)) @@ -89,7 +91,7 @@ cols=${cols%,} printf "else path end as path\n" fi printf "from packagefiles_pkgid PF\n" - if [ $showsoname -eq 1 ]; then + if [ $showsoname -eq 1 ] || [ $sharedlibsonly -eq 1 ]; then printf "left join elflibraries EL on EL.file = PF.hash\n" fi if [ -n "$status" ]; then @@ -106,10 +108,13 @@ cols=${cols%,} only) printf "and configuration = 1\n" ;; exclude) printf "and configuration = 0\n" ;; esac + if [ $sharedlibsonly -eq 1 ]; then + printf "and EL.soname is not null\n" + fi if [ -n "$status" ]; then printf "and P.status = '%s'\n" "$status" fi - printf 'order by package,version collate vercmp, release, path\n' + printf 'order by PF.package, PF.version collate vercmp, PF.release, PF.path\n' printf ';\n' } | zpm shell $pkgfile #} | cat