184 lines
9.9 KiB
Bash
184 lines
9.9 KiB
Bash
#compdef ansible-galaxy
|
|
# ------------------------------------------------------------------------------
|
|
# Copyright (c) 2011 Github zsh-users - http://github.com/zsh-users
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# * Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# * Neither the name of the zsh-users nor the
|
|
# names of its contributors may be used to endorse or promote products
|
|
# derived from this software without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
# DISCLAIMED. IN NO EVENT SHALL ZSH-USERS BE LIABLE FOR ANY
|
|
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
# ------------------------------------------------------------------------------
|
|
# Description
|
|
# -----------
|
|
#
|
|
# Completion script for ansible-galaxy v2.0.0.2 (http://ansible.org)
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
# Authors
|
|
# -------
|
|
#
|
|
# * Romain Bossart (https://github.com/bosr)
|
|
# * Adam Stevko (https://github.com/xen0l)
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
#
|
|
# Note: I tried to use `_arguments --`, but the output of `ansible --help`
|
|
# is not parsed entirely correctly, and anyway no modules or host would available.
|
|
#
|
|
|
|
# ansible-galaxy zsh completion
|
|
#
|
|
_ansible-galaxy ()
|
|
{
|
|
local context curcontext="$curcontext" state line
|
|
typeset -A opt_args
|
|
|
|
_arguments -C \
|
|
"1:command:(delete import info init install list login remove search setup)" \
|
|
"*::option:->option"
|
|
|
|
case $state in
|
|
option)
|
|
case $line[1] in
|
|
delete)
|
|
_arguments \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":github_user:(GITHUB_USER)" \
|
|
":github_repo:(GITHUB_REPO)"
|
|
;;
|
|
import)
|
|
_arguments \
|
|
"--branch[REFERENCE The name of a branch to import.]:reference:(master)" \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"--no-wait[Don't wait for import results.]" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"--status[Check the status of the most recent import request forgiven github_user/github_repo.]" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":github_user:(GITHUB_USER)" \
|
|
":github_repo:(GITHUB_REPO)"
|
|
;;
|
|
info)
|
|
_arguments \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"(-p --roles-path)"{-p,--roles-path}"[ROLES_PATH The path to the directory containing your roles (default: from ansible.cfg)]:roles path:_files -/" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":role name:(ROLE,version)"
|
|
;;
|
|
init)
|
|
_arguments \
|
|
"(-f --force)"{-f,--force}"[ Force overwriting an existing role]" \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"(-p --init-path)"{-p,--init-path}"[INIT_PATH path in which the skeleton role will be created (default=./)]:init path:(./)" \
|
|
"(--offline)--offline[Don't query the galaxy API when creating roles]" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":role name:(ROLE)"
|
|
;;
|
|
install)
|
|
_arguments \
|
|
"(-f --force)"{-f,--force}"[Force overwriting an existing role]" \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"(-i --ignore-errors)"{-i,--ignore-errors}"[Ignore errors and continue with the next specified role]" \
|
|
"(-n --no-deps)"{-n,--no-deps}"[Don't download roles listed as dependencies]" \
|
|
"(-r --role-file)"{-r,--role-file}"[ROLE_FILE A file containing a list of roles to be imported]:role file:_files" \
|
|
"(-p --roles-path)"{-p,--roles-path}"[ROLES_PATH The path to the directory containing your roles (default: from ansible.cfg)]:roles path:_files -/" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":role name:(ROLE)"
|
|
;;
|
|
list)
|
|
_arguments \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-p --roles-path)"{-p,--roles-path}"[ROLES_PATH The path to the directory containing your roles (default: from ansible.cfg)]:roles path:_files -/" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":role name:(ROLE)"
|
|
;;
|
|
login)
|
|
_arguments \
|
|
"--github_token[TOKEN Identify with github token rather than username and password.]:token:(TOKEN)" \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]"
|
|
;;
|
|
remove)
|
|
_arguments \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-p --roles-path)"{-p,--roles-path}"[ROLES_PATH The path to the directory containing your roles (default: from ansible.cfg)]:roles path:_files -/" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
"*:role name:(ROLE)"
|
|
;;
|
|
search)
|
|
_arguments \
|
|
"--author[AUTHOR GitHub username]:author:(AUTHOR)" \
|
|
"--galaxy-tags[TAGS list of galaxy tags to filter by]:tags:(TAGS)" \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"--platforms[PLATFORMS list of OS platforms to filter by" \
|
|
"(-p --roles-path)"{-p,--roles-path}"[ROLES_PATH The path to the directory containing your roles (default: from ansible.cfg)]:roles path:_files -/" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]"
|
|
;;
|
|
setup)
|
|
_arguments \
|
|
"(-h --help)"{-h,--help}"[help message]" \
|
|
"(-c --ignore-certs)"{-c,--ignore-certs}"[Ignore SSL certificate validation errors.]" \
|
|
"--list[List all of your integrations.]" \
|
|
"--remove[REMOVE_ID Remove the integration matching the provided ID value.]:id:(REMOVE_ID)" \
|
|
"(-s --server)"{-s,--server}"[API_SERVER The API server destination]:api server:(http://apiserver)" \
|
|
"(-v --verbose)"{-v,--verbose}"[verbose mode (-vvv for more, -vvvv to enable connection debugging)]" \
|
|
"--version[show program's version number and exit]" \
|
|
":source:(travis)" \
|
|
":github_user:(GITHUB_USER)" \
|
|
":github_repo:(GITHUB_REPO)" \
|
|
":secret:(SECRET)"
|
|
;;
|
|
esac
|
|
;;
|
|
esac
|
|
}
|
|
|
|
_ansible-galaxy "$@"
|
|
|
|
# Local Variables:
|
|
# mode: Shell-Script
|
|
# sh-indentation: 2
|
|
# indent-tabs-mode: nil
|
|
# sh-basic-offset: 2
|
|
# End:
|
|
# vim: ft=zsh sw=2 ts=2 et
|