diff --git a/debian/bash-completion b/debian/bash-completion new file mode 100644 index 00000000..787d8743 --- /dev/null +++ b/debian/bash-completion @@ -0,0 +1,549 @@ +#!/bin/bash + +# (The MIT License) +# +# Copyright (c) 2014 Andrey Smirnov +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the 'Software'), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +__aptly_mirror_list() +{ + aptly mirror list -raw +} + +__aptly_repo_list() +{ + aptly repo list -raw +} + +__aptly_snapshot_list() +{ + aptly snapshot list -raw +} + +__aptly_published_distributions() +{ + aptly publish list -raw | cut -d ' ' -f 2 | sort | uniq +} + +__aptly_published_prefixes() +{ + aptly publish list -raw | cut -d ' ' -f 1 | sort | uniq +} + +__aptly_prefixes_for_distribution() +{ + aptly publish list -raw | awk -v dist="$1" '{ if (dist == $2) print $1 }' | sort | uniq +} + +_aptly() +{ + cur="${COMP_WORDS[COMP_CWORD]}" + prev="${COMP_WORDS[COMP_CWORD-1]}" + + commands="db graph mirror package publish repo serve snapshot version" + options="-architectures= -config= -dep-follow-all-variants -dep-follow-recommends -dep-follow-source -dep-follow-suggests" + + db_subcommands="cleanup recover" + mirror_subcommands="create drop show list rename search update" + publish_subcommands="drop list repo snapshot switch update" + snapshot_subcommands="create diff drop filter list merge pull rename search show verify" + repo_subcommands="add copy create drop edit import list move remove rename search show" + package_subcommands="search show" + + local cmd subcmd numargs numoptions i + + numargs=0 + numoptions=0 + + for (( i=1; i < $COMP_CWORD; i++ )); do + if [[ -n "$cmd" ]]; then + if [[ ! -n "$subcmd" ]]; then + subcmd=${COMP_WORDS[i]} + numargs=$(( COMP_CWORD - i - 1 )) + else + if [[ "${COMP_WORDS[i]}" == -* ]]; then + numoptions=$(( numoptions + 1 )) + numargs=$(( numargs - 1 )) + fi + fi + else + if [[ ! "${COMP_WORDS[i]}" == -* ]]; then + cmd=${COMP_WORDS[i]} + fi + fi + done + + if [[ ! -n "$cmd" ]]; + then + case "$cur" in + -*) + COMPREPLY=($(compgen -W "${options}" -- ${cur})) + return 0 + ;; + *) + COMPREPLY=($(compgen -W "${commands}" -- ${cur})) + return 0 + ;; + esac + fi + + if [[ ! -n "$subcmd" ]]; + then + case "$prev" in + "db") + COMPREPLY=($(compgen -W "${db_subcommands}" -- ${cur})) + return 0 + ;; + "mirror") + COMPREPLY=($(compgen -W "${mirror_subcommands}" -- ${cur})) + return 0 + ;; + "repo") + COMPREPLY=($(compgen -W "${repo_subcommands}" -- ${cur})) + return 0 + ;; + "snapshot") + COMPREPLY=($(compgen -W "${snapshot_subcommands}" -- ${cur})) + return 0 + ;; + "publish") + COMPREPLY=($(compgen -W "${publish_subcommands}" -- ${cur})) + return 0 + ;; + "package") + COMPREPLY=($(compgen -W "${package_subcommands}" -- ${cur})) + return 0 + ;; + *) + ;; + esac + fi + + case "$cmd" in + "mirror") + case "$subcmd" in + "create") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-filter= -filter-with-deps -ignore-signatures -keyring= -with-sources -with-udebs" -- ${cur})) + return 0 + fi + fi + ;; + "edit") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-filter= -filter-with-deps -with-sources -with-udebs" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + fi + ;; + "show") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-packages" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + fi + ;; + "search") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + fi + ;; + "rename") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + return 0 + fi + ;; + "drop") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + fi + ;; + "list") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "-raw" -- ${cur})) + return 0 + fi + ;; + "update") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force -download-limit= -ignore-checksums -ignore-signatures -keyring=" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + fi + ;; + esac + ;; + "repo") + case "$subcmd" in + "add") + case $numargs in + 0) + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force-replace -remove-files" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + ;; + 1) + local files=$(find . -mindepth 1 -maxdepth 1 \( -type d -or -name \*.deb -or -name \*.dsc \) -exec basename {} \;) + COMPREPLY=($(compgen -W "${files}" -- ${cur})) + return 0 + ;; + esac + ;; + "copy"|"move") + case $numargs in + 0) + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps -dry-run" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + ;; + 1) + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + return 0 + ;; + esac + ;; + "create") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-comment= -distribution= -component=" -- ${cur})) + return 0 + fi + fi + ;; + "drop") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + fi + ;; + "edit") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-comment= -distribution= -component=" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + fi + ;; + "search") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + fi + ;; + "list") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "-raw" -- ${cur})) + return 0 + fi + ;; + "import") + case $numargs in + 0) + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps -dry-run" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + fi + return 0 + ;; + 1) + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + return 0 + ;; + esac + ;; + "remove") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-dry-run" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + fi + ;; + "show") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-packages" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + return 0 + fi + ;; + "rename") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + return 0 + fi + ;; + esac + ;; + "snapshot") + case "$subcmd" in + "create") + case $numargs in + 1) + COMPREPLY=($(compgen -W "from empty" -- ${cur})) + return 0 + ;; + 2) + if [[ "$prev" == "from" ]]; then + COMPREPLY=($(compgen -W "mirror repo" -- ${cur})) + return 0 + fi + ;; + 3) + if [[ "$prev" == "mirror" ]]; then + COMPREPLY=($(compgen -W "$(__aptly_mirror_list)" -- ${cur})) + return 0 + fi + if [[ "$prev" == "repo" ]]; then + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + return 0 + fi + ;; + esac + ;; + "diff") + if [[ $numargs -eq 0 ]] && [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-only-matching" -- ${cur})) + return 0 + fi + + if [[ $numargs -lt 2 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + return 0 + fi + ;; + "drop") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + fi + return 0 + fi + ;; + "list") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "-raw -sort=" -- ${cur})) + return 0 + fi + ;; + "merge") + if [[ $numargs -gt 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-latest" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + fi + return 0 + fi + ;; + "pull") + if [[ $numargs -eq 0 ]] && [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-all-matches -dry-run -no-deps -no-remove" -- ${cur})) + return 0 + fi + + if [[ $numargs -lt 2 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + return 0 + fi + ;; + "filter") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + fi + return 0 + fi + ;; + "show") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-packages" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + fi + return 0 + fi + ;; + "search") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-deps" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + fi + return 0 + fi + ;; + "rename") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + return 0 + fi + ;; + "verify") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + return 0 + fi + ;; + esac + ;; + "publish") + case "$subcmd" in + "snapshot"|"repo") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force-overwrite -distribution= -component= -gpg-key= -keyring= -label= -origin= -passphrase= -passphrase-file= -secret-keyring= -skip-signing" -- ${cur})) + else + if [[ "$subcmd" == "snapshot" ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_repo_list)" -- ${cur})) + fi + fi + return 0 + fi + + if [[ $numargs -eq 1 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_published_prefixes)" -- ${cur})) + return 0 + fi + ;; + "list") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "-raw" -- ${cur})) + return 0 + fi + ;; + "update") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force-overwrite -gpg-key= -keyring= -passphrase= -passphrase-file= -secret-keyring= -skip-signing" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_published_distributions)" -- ${cur})) + fi + return 0 + fi + + if [[ $numargs -eq 1 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_prefixes_for_distribution $prev)" -- ${cur})) + return 0 + fi + ;; + "switch") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-force-overwrite -component= -gpg-key= -keyring= -passphrase= -passphrase-file= -secret-keyring= -skip-signing" -- ${cur})) + else + COMPREPLY=($(compgen -W "$(__aptly_published_distributions)" -- ${cur})) + fi + return 0 + fi + + if [[ $numargs -eq 1 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_prefixes_for_distribution $prev)" -- ${cur})) + return 0 + fi + + if [[ $numargs -ge 2 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_snapshot_list)" -- ${cur})) + return 0 + fi + ;; + "drop") + if [[ $numargs -eq 0 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_published_distributions)" -- ${cur})) + return 0 + fi + + if [[ $numargs -eq 1 ]]; then + COMPREPLY=($(compgen -W "$(__aptly_prefixes_for_distribution $prev)" -- ${cur})) + return 0 + fi + ;; + esac + ;; + "package") + case "$subcmd" in + "show") + if [[ $numargs -eq 0 ]]; then + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-with-files -with-references" -- ${cur})) + fi + return 0 + fi + ;; + esac + ;; + "serve") + if [[ "$cur" == -* ]]; then + COMPREPLY=($(compgen -W "-listen=" -- ${cur})) + return 0 + fi + ;; + esac +} && complete -F _aptly aptly \ No newline at end of file diff --git a/debian/control b/debian/control index 051ede3a..d798cfd3 100644 --- a/debian/control +++ b/debian/control @@ -2,7 +2,7 @@ Source: aptly Section: utils Priority: extra Maintainer: Sebastien Delafond -Build-Depends: debhelper (>= 9.0.0), golang (>= 1.1), golang-go.tools +Build-Depends: debhelper (>= 9.0.0), golang (>= 1.1), golang-go.tools, bash-completion Standards-Version: 3.9.5 Homepage: http://www.aptly.info Vcs-Git: git://anonscm.debian.org/collab-maint/aptly.git diff --git a/debian/rules b/debian/rules index 5e9dccc9..79b17b49 100755 --- a/debian/rules +++ b/debian/rules @@ -27,5 +27,6 @@ override_dh_auto_build: GOPATH=:$(CURDIR):$(SOURCE_DIR)/_vendor go build -o aptly $(PACKAGE_DIR)/main.go override_dh_auto_install: + dh_bash-completion mkdir -p $(DEST_DIR)/usr/bin cp aptly $(DEST_DIR)/usr/bin/