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
 |