#compdef android # ------------------------------------------------------------------------------ # Copyright (c) 2011 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 the android command (Revision 12) # (http://developer.android.com/guide/developing/tools/android.html). # # ------------------------------------------------------------------------------ # Authors # ------- # # * Julien Nicoulaud # # ------------------------------------------------------------------------------ # -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*- # vim: ft=zsh sw=2 ts=2 et # ------------------------------------------------------------------------------ typeset -A opt_args local context state line curcontext="$curcontext" android_cmd _android() { local ret=1 android_cmd="$words[1]" _arguments -C -A "-*" \ '(- : *)'{-h,--help}'[get help on a specific command]:command:_android_cmds' \ '(-s --silent -v --verbose)'{-v,--verbose}'[verbose mode: errors, warnings and informational messages are printed]' \ '(-v --verbose -s --silent)'{-s,--silent}'[silent mode: only errors are printed out]' \ '1: :_android_cmds' \ '*::arg:->args' \ && ret=0 case "$state" in (args) curcontext="${curcontext%:*:*}:android-cmd-$words[1]:" case $words[1] in (list) _arguments -C \ '1: :_android_list_entities' \ '*::list-arg:->list-args' \ && ret=0 case "$state" in (list-args) case $words[1] in (avd|target) _arguments \ '(-0 --null)'{-0,--null}'[terminate lines with \0 instead of \n (e.g. for xargs -0)]' \ '(-c --compact)'{-c,--compact}'[compact output (suitable for scripts)]' \ && ret=0 ;; (sdk) _arguments \ '(-o --obsolete)'{-o,--obsolete}'[install obsolete packages]' \ '--proxy-host[HTTP/HTTPS proxy host (overrides settings if defined)]:proxy host:_hosts' \ '--proxy-port[HTTP/HTTPS proxy port (overrides settings if defined)]:proxy port number' \ '(-s --no-https)'{-s,--no-https}'[use HTTP instead of HTTPS (the default) for downloads]' \ '(-u --no-ui)'{-u,--no-ui}'[display list result on console (no GUI)]' \ && ret=0 ;; esac ;; esac ;; (create) _arguments -C \ '1: :_android_create_entities' \ '*::create-arg:->create-args' \ && ret=0 case "$state" in (create-args) case $words[1] in (avd) _arguments \ '(-c --sdcard)'{-c,--sdcard}'[path to a shared SD card image, or size of a new sdcard for the new AVD]:SD card image or size:_files -g "*.img"' \ '(-n --name)'{-n,--name}'[name of the new AVD]:name' \ '(-a --snapshot)'{-a,--snapshot}'[place a snapshots file in the AVD, to enable persistence]' \ '(-p --path)'{-p,--path}'[directory where the new AVD will be created]: :_files -/' \ '(-f --force)'{-f,--force}'[forces creation (overwrites an existing AVD)]' \ '(-s --skin)'{-s,--skin}'[skin for the new AVD]:skin' \ '(-t --target)'{-t,--target}'[target ID of the new AVD]: :_android_targets' \ && ret=0 ;; (project) _arguments \ '(-n --name)'{-n,--name}'[project name]:project name' \ '(-p --path)'{-p,--path}'[the new project'\''s directory]: :_files -/' \ '(-k --package)'{-k,--package}'[Android package name for the application]:package name' \ '(-a --activity)'{-a,--activity}'[name of the default Activity that is created]:activity name' \ '(-t --target)'{-t,--target}'[target ID of the new project]: :_android_targets' \ && ret=0 ;; (test-project) _arguments \ '(-n --name)'{-n,--name}'[project name]:project name' \ '(-p --path)'{-p,--path}'[the new project'\''s directory]: :_files -/' \ '(-m --main)'{-m,--main}'[path to directory of the app under test, relative to the test project directory]:path' \ && ret=0 ;; (lib-project) _arguments \ '(-n --name)'{-n,--name}'[project name]:project name' \ '(-p --path)'{-p,--path}'[the new project'\''s directory]: :_files -/' \ '(-k --package)'{-k,--package}'[Android package name for the application]:package name' \ '(-t --target)'{-t,--target}'[target ID of the new project]: :_android_targets' \ && ret=0 ;; esac ;; esac ;; (update) _arguments -C \ '1: :_android_update_entities' \ '*::update-arg:->update-args' \ && ret=0 # TODO Options: # Action "update avd": # -n --name Name of the AVD to update [required] # # Action "update project": # -l --library Directory of an Android library to add, relative to this project's directory # -p --path The project's directory [required] # -n --name Project name # -t --target Target ID to set for the project # -s --subprojects Also updates any projects in sub-folders, such as test projects. # # Action "update test-project": # -m --main Directory of the app under test, relative to the test project directory [required] # -p --path The project's directory [required] # # Action "update lib-project": # -p --path The project's directory [required] # -t --target Target ID to set for the project # # Action "update adb": # No options # # Action "update sdk": # --proxy-port HTTP/HTTPS proxy port (overrides settings if defined) # --proxy-host HTTP/HTTPS proxy host (overrides settings if defined) # -s --no-https Uses HTTP instead of HTTPS (the default) for downloads # -f --force Forces replacement of a package or its parts, even if something has been modified # -u --no-ui Updates from command-line (does not display the GUI) # -o --obsolete Installs obsolete packages # -t --filter A filter that limits the update to the specified types of packages in the form of # a comma-separated list of [platform, tool, platform-tool, doc, sample, extra] # -n --dry-mode Simulates the update but does not download or install anything ;; (move) _arguments -C \ '1: :_android_move_entities' \ '*::move-arg:->move-args' \ && ret=0 case "$state" in (move-args) case $words[1] in (avd) _arguments \ '(-n --name)'{-n,--name}'[name of the AVD to move or rename]: :_android_avd_names' \ '(-p --path)'{-p,--path}'[path to the AVD'\''s new directory]: :_files -/' \ '(-r --rename)'{-r,--rename}'[new name of the AVD]:name' \ && ret=0 ;; esac ;; esac ;; (delete) _arguments -C \ '1: :_android_delete_entities' \ '*::delete-arg:->delete-args' \ && ret=0 case "$state" in (delete-args) case $words[1] in (avd) _arguments \ '(-n --name)'{-n,--name}'[name of the AVD to delete]: :_android_avd_names' \ && ret=0 ;; esac ;; esac ;; (display) _arguments \ '1: :_android_display_entities' \ && ret=0 ;; esac ;; esac return ret } (( $+functions[_android_cmds] )) || _android_cmds() { local commands; commands=( 'list:list existing targets or virtual devices' 'create:create new virtual devices or projects' 'update:update a virtual device, project, SDK or adb' 'move:move a virtual device' 'delete:delete a virtual device' 'display:display manager windows' ) _describe -t commands 'command' commands "$@" } (( $+functions[_android_list_entities] )) || _android_list_entities() { local entities; entities=( 'avd:list existing Android Virtual Devices' 'target:list existing targets' 'sdk:list remote SDK repository' ) _describe -t entities 'entity' entities "$@" } (( $+functions[_android_create_entities] )) || _android_create_entities() { local entities; entities=( 'avd:create a new Android Virtual Device' 'project:create a new Android project' 'test-project:create a new Android project for a test package' 'lib-project:create a new Android library project' ) _describe -t entities 'entity' entities "$@" } (( $+functions[_android_update_entities] )) || _android_update_entities() { local entities; entities=( 'avd:update an Android Virtual Device to match the folders of a new SDK' 'project:update an Android project' 'test-project:update the Android project for a test package' 'lib-project:update an Android library project' 'adb:update adb to support the USB devices declared in the SDK add-ons' 'sdk:update the SDK by suggesting new platforms to install if available' ) _describe -t entities 'entity' entities "$@" } (( $+functions[_android_move_entities] )) || _android_move_entities() { local entities; entities=( 'avd:move or rename an Android Virtual Device' ) _describe -t entities 'entity' commands "$@" } (( $+functions[_android_delete_entities] )) || _android_delete_entities() { local entities; entities=( 'avd:delete an Android Virtual Device' ) _describe -t entities 'entity' entities "$@" } (( $+functions[_android_display_entities] )) || _android_display_entities() { local entities; entities=( 'sdk:display the SDK Manager window' 'avd:display the AVD Manager window' ) _describe -t entities 'entity' entities "$@" } (( $+functions[_android_targets] )) || _android_targets() { local targets; targets=(${(f)"$(_call_program targets $android_cmd list target --compact)"//:/\\:}) _describe -t targets 'target' targets "$@" } (( $+functions[_android_avd_names] )) || _android_avd_names() { local avd_names; avd_names=(${(f)"$(_call_program targets $android_cmd list avd --compact)"//:/\\:}) _describe -t avd-names 'AVD name' avd_names "$@" } _android "$@"