about summary refs log tree commit diff
path: root/Completion/Debian
diff options
context:
space:
mode:
authorClint Adams <clint@users.sourceforge.net>2001-12-14 18:04:44 +0000
committerClint Adams <clint@users.sourceforge.net>2001-12-14 18:04:44 +0000
commit2ed38d79ca0bbc613115b30a9e99a797542ab053 (patch)
treeaffaff981b8cbc516b99521517c9b31855d43239 /Completion/Debian
parentedc86e4308b6babe49cbb8bed7145d710fa3b90b (diff)
downloadzsh-2ed38d79ca0bbc613115b30a9e99a797542ab053.tar.gz
zsh-2ed38d79ca0bbc613115b30a9e99a797542ab053.tar.xz
zsh-2ed38d79ca0bbc613115b30a9e99a797542ab053.zip
16336: use apt-cache --generate pkgnames instead of apt-cache dumpavail
Diffstat (limited to 'Completion/Debian')
-rw-r--r--Completion/Debian/Type/_deb_packages78
1 files changed, 78 insertions, 0 deletions
diff --git a/Completion/Debian/Type/_deb_packages b/Completion/Debian/Type/_deb_packages
new file mode 100644
index 000000000..cc5eaf109
--- /dev/null
+++ b/Completion/Debian/Type/_deb_packages
@@ -0,0 +1,78 @@
+#autoload
+
+# Usage: _deb_packages expl... avail|installed|uninstalled
+
+_deb_packages_update_avail () {
+  if ( [[ ${+_deb_packages_cache_avail} -eq 0 ]] ||
+      _cache_invalid DEBS_avail ) && ! _retrieve_cache DEBS_avail;
+  then
+    _deb_packages_cache_avail=(
+      ${(f)"$(apt-cache --generate pkgnames)"}
+    )
+
+    _store_cache DEBS_avail _deb_packages_cache_avail
+  fi
+  cachevar=_deb_packages_cache_avail
+}
+
+_deb_packages_update_installed () {
+  if ( [[ ${+_deb_packages_cache_installed} -eq 0 ]] ||
+      _cache_invalid DEBS_installed ) && ! _retrieve_cache DEBS_installed;
+  then
+    _deb_packages_cache_installed=(
+      ${${${(f)"$(dpkg --get-selections)"}:#*deinstall}%%	*}
+    )
+    _store_cache DEBS_installed _deb_packages_cache_installed
+  fi
+  cachevar=_deb_packages_cache_installed
+}
+
+_deb_packages_update_uninstalled () {
+  _deb_packages_update_avail
+  _deb_packages_update_installed
+  if (( ! $+_deb_packages_cache_uninstalled )); then
+    _deb_packages_cache_uninstalled=(
+      ${_deb_packages_cache_avail:#${(j:|:)~${_deb_packages_cache_installed:q}}}
+    )
+  fi
+  cachevar=_deb_packages_cache_uninstalled
+}
+
+_deb_packages () {
+  local command="$argv[$#]" expl cachevar pkgset update_policy
+
+  zstyle -s ":completion:*:*:$service:*" cache-policy update_policy
+  if [[ -z "$update_policy" ]]; then
+    zstyle ":completion:*:*:$service:*" cache-policy _debs_caching_policy
+  fi
+
+  [[ "$command" = (installed|uninstalled|avail) ]] || {
+    _message "_deb_packages:unknown command: $command"
+    return
+  }
+
+  zstyle -s ":completion:${curcontext}:" packageset pkgset
+
+  [[ "$pkgset" = (installed|uninstalled|avail|available) ]] || {
+    pkgset="$command"
+  }
+
+  [[ "$pkgset" = "available" ]] && pkgset="avail"
+
+  expl=("${(@)argv[1,-2]}")
+
+  _deb_packages_update_$pkgset
+
+  _tags packages && compadd "$expl[@]" - "${(@P)cachevar}"
+}
+
+ _debs_caching_policy () {
+    # rebuild if cache is more than a week old
+      oldp=( "$1"(mw+1) )
+        (( $#oldp )) && return 0
+
+	  [[ /var/cache/apt/pkgcache.bin -nt "$1" ||
+	     /var/lib/dpkg/available -nt "$1" ]]
+	  }
+
+_deb_packages "$@"