summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Shahaf <d.s@daniel.shahaf.name>2020-04-27 11:38:13 +0000
committerDaniel Shahaf <d.s@daniel.shahaf.name>2020-05-03 01:29:05 +0000
commitd128bc0bd475a43d71ef220b797a6291ffbf808c (patch)
tree5c3b347c6026c1a9a668fc5cf752cff2890248fb
parentdeca7c928520fba5a73383f1cac0b3ace8e0e45d (diff)
downloadzsh-d128bc0bd475a43d71ef220b797a6291ffbf808c.tar.gz
zsh-d128bc0bd475a43d71ef220b797a6291ffbf808c.zip
45731: _debsnap: New completion function.
-rw-r--r--ChangeLog3
-rw-r--r--Completion/Debian/Command/_debsnap77
2 files changed, 80 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 1afa30114..f4ef8b888 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2020-05-03 Daniel Shahaf <d.s@daniel.shahaf.name>
+ * 45731: Completion/Debian/Command/_debsnap: New completion
+ function.
+
* 45730: Completion/Base/Utility/_arguments, Doc/Zsh/compsys.yo,
Src/Zle/computil.c, Src/utils.c, Test/Y03arguments.ztst:
_arguments: Add the -0 flag, which makes $opt_args be populated
diff --git a/Completion/Debian/Command/_debsnap b/Completion/Debian/Command/_debsnap
new file mode 100644
index 000000000..b9393cac4
--- /dev/null
+++ b/Completion/Debian/Command/_debsnap
@@ -0,0 +1,77 @@
+#compdef debsnap
+
+# Based on debsnap from devscripts-2.20.3
+
+local context state state_descr line ret=1
+local -a expl
+typeset -A opt_args
+
+_arguments \
+ '(-d --destdir)'{-d+,--destdir=}'[set download directory]:download directory:_files -/' \
+ '(-f --force)'{-f,--force}'[allow non-empty destination directory]' \
+ '(-v --verbose)'{-v,--verbose}'[print configuration and report progress]' \
+ --list"[list versions; don't download]" \
+ --binary'[operate on binary packages (default: source packages)]' \
+ '*'{-a+,--architecture=}'[specify architectures to download]:architecture to download:_deb_architectures' \
+ --first='[download all versions newer than this]:version number (lower bound):->versions' \
+ --last='[download all versions older than this]:version number (upper bound):->versions' \
+ '(-)'{-h,--help}'[show usage information]' \
+ '(-)'--version'[show version number and license]' \
+ '1: :->package' \
+ '2:version number to download:->versions' \
+ && ret=0
+
+# -a implies --binary
+if (( ${+opt_args[-a]} || ${+opt_args[--architecture]} )); then
+ opt_args[--binary]=''
+fi
+
+case $state in
+ (package)
+ if (( ${+opt_args[--binary]} )); then
+ _description binary-packages expl 'binary package to download'
+ _deb_packages "${expl[@]}" avail && ret=0
+ else
+ _description source-packages expl 'source package to download'
+ _deb_packages "${expl[@]}" source && ret=0
+ fi
+ ;;
+ (versions)
+ local package=${(Q)line[1]}
+ if [[ -n $package ]]; then
+ # Compute the arguments to --list
+ local -a args
+ () {
+ local i j
+
+ # repeatable flags with arguments, where the values can't contain colons
+ for i in ${(k)opt_args[(I)(-a|--architecture)]}; do
+ for j in ${(@s.:.)opt_args[$i]}; do
+ [[ -n $j ]] || continue
+ args+=( $i $j )
+ done
+ done
+
+ # non-repeatable flags with arguments, where the values may contain colons
+ for i in ${(k)opt_args[(I)(--first|--last)]}; do
+ # Avoid spurious "No matches" results in 'debsnap --first 42.1 --last 42.<TAB>'.
+ [[ $context != option${i}-* ]] || continue
+
+ # Un-escape colons (epoch separators in the version number)
+ args+=( $i ${(Q)opt_args[$i]} )
+ done
+
+ # flags without arguments
+ args+=( ${(k)opt_args[(I)(--binary)]} )
+ }
+
+ local -a versions=( ${(Oaf)"$(_call_program versions debsnap --list ${args} -- ${line[1]})"} )
+ _description -V versions expl ${state_descr}
+ compadd "$@" "${expl[@]}" -a versions && ret=0
+ else
+ _message -- $state_descr && ret=0
+ fi
+ ;;
+esac
+
+return ret