Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
Re: PATCH: _apt-get and _deb_packages
- X-seq: zsh-workers 7641
- From: Tanaka Akira <akr@xxxxxxxxxxx>
- To: zsh-workers@xxxxxxxxxxxxxx
- Subject: Re: PATCH: _apt-get and _deb_packages
- Date: 04 Sep 1999 08:17:18 +0900
- In-reply-to: Falk Hueffner's message of "03 Sep 1999 22:30:24 +0200"
- Mailing-list: contact zsh-workers-help@xxxxxxxxxxxxxx; run by ezmlm
- References: <rsq3dwxuib6.fsf@xxxxxxxxxxxxxxxxx> <87u2pbu49r.fsf@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx>
In article <87u2pbu49r.fsf@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx>,
Falk Hueffner <falk.hueffner@xxxxxxxxxxxxxxxxxxxxxxxx> writes:
> It would be nice if after 'install' only uninstalled packages would be
> completed, and after 'remove' and 'purge' only installed.
What's `purge'?
At least, the manual in apt 0.3.11 doesn't mention the command.
> dpkg --get-selections | awk '/[^e]install$/ { print $1 }'
> apt-cache dumpavail | awk '/^Package:/ { print $2 }'
I see. Thanks.
Index: Completion/Debian/_apt-get
===================================================================
RCS file: /projects/zsh/zsh/Completion/Debian/_apt-get,v
retrieving revision 1.1.1.1
diff -u -F^( -r1.1.1.1 _apt-get
--- _apt-get 1999/09/02 21:27:08 1.1.1.1
+++ _apt-get 1999/09/03 23:05:44
@@ -1,23 +1,40 @@
#compdef apt-get
-_arguments -s \
- -{,-no-}d --{,no-}download-only \
- -{,-no-}f --{,no-}fix-broken \
- -{,-no-}h --{,no-}help \
- -{,-no-}v --{,no-}version \
- -{,-no-}m --{,no-}ignore-missing \
- --{,no-}fix-missing \
- --{,no-}no-download \
- \*-{,-no-}q \*--{,no-}{quiet,silent} \
- -{,-no-}s --{,no-}{simulate,just-print,dry-run,recon,no-act} \
- -{,-no-}y --{,no-}{yes,assume-yes} \
- -{,-no-}u --{,no-}show-upgraded \
- -{,-no-}b --{,no-}{compile,build} \
- --{,no-}ignore-hold \
- --{,no-}no-upgrade \
- --{,no-}force-yes \
- --{,no-}print-uris \
- {-{,-no-}c,--{,no-}config-file}':Configuration File:_files' \
- {-o,--option}':Foo\:\:Bar=bar:' \
- ':command:(update upgrade dselect-upgrade dist-upgrade install remove source check clean autoclean help)' \
- '*:package:_deb_packages'
+_apt-get () {
+ # This doesn't handle command line of apt completely since command line
+ # parsing library for apt is too complex to handle by _arguments.
+ _arguments -s \
+ -{,-no-}d --{,no-}download-only \
+ -{,-no-}f --{,no-}fix-broken \
+ -{,-no-}h --{,no-}help \
+ -{,-no-}v --{,no-}version \
+ -{,-no-}m --{,no-}ignore-missing \
+ --{,no-}fix-missing \
+ --{,no-}no-download \
+ \*-{,-no-}q \*--{,no-}{quiet,silent} \
+ -{,-no-}s --{,no-}{simulate,just-print,dry-run,recon,no-act} \
+ -{,-no-}y --{,no-}{yes,assume-yes} \
+ -{,-no-}u --{,no-}show-upgraded \
+ -{,-no-}b --{,no-}{compile,build} \
+ --{,no-}ignore-hold \
+ --{,no-}no-upgrade \
+ --{,no-}force-yes \
+ --{,no-}print-uris \
+ {-{,-no-}c,--{,no-}config-file}':Configuration File:_files' \
+ {-o,--option}':Foo\:\:Bar=bar:' \
+ '*::command and packages:_apt-get_args'
+}
+
+_apt-get_args () {
+ if (( CURRENT == 1 )); then
+ compadd "$@" - update upgrade dselect-upgrade dist-upgrade install remove source check clean autoclean help
+ else
+ case "$words[1]" in
+ install) _deb_packages uninstalled "$@";;
+ remove) _deb_packages installed "$@";;
+ *) _deb_packages avail "$@";;
+ esac
+ fi
+}
+
+_apt-get "$@"
Index: Completion/Debian/_deb_packages
===================================================================
RCS file: /projects/zsh/zsh/Completion/Debian/_deb_packages,v
retrieving revision 1.1.1.1
diff -u -F^( -r1.1.1.1 _deb_packages
--- _deb_packages 1999/09/02 21:27:08 1.1.1.1
+++ _deb_packages 1999/09/03 23:05:44
@@ -1,7 +1,27 @@
#autoload
-if (( ! $+_deb_packages )); then
- _deb_packages=( $(awk '/^Package:/ { print $2 }' /var/lib/dpkg/status) )
+# Usage: _deb_packages installed|uninstalled|avail
+
+if (( ! $+_deb_cache_dpkg_get_selections )); then
+ _deb_cache_dpkg_get_selections=(
+ ${(f)"$(dpkg --get-selections)"}
+ )
+ _deb_cache_avail=(
+ ${(f)"$(apt-cache dumpavail | awk '/^Package:/ { print $2 }')"}
+ )
+ _deb_cache_installed=(
+ ${${_deb_cache_dpkg_get_selections:#*deinstall}%% *}
+ )
+ _deb_cache_uninstalled=(
+ ${_deb_cache_avail:#${(j:|:)~${_deb_cache_installed:q}}}
+ )
fi
+
+local command="$1"
+shift
-compadd "$@" - $_deb_packages
+case "$command" in
+ installed) compadd "$@" - $_deb_cache_installed;;
+ uninstalled) compadd "$@" - $_deb_cache_uninstalled;;
+ avail) compadd "$@" - $_deb_cache_avail;;
+esac
--
Tanaka Akira
Messages sorted by:
Reverse Date,
Date,
Thread,
Author