192 lines
12 KiB
Bash
192 lines
12 KiB
Bash
#compdef drush
|
|
# ------------------------------------------------------------------------------
|
|
# Copyright (c) 2014 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 Drush (http://drush.ws).
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
# Authors
|
|
# -------
|
|
#
|
|
# * Vasily Kraev (https://github.com/vasilykraev)
|
|
#
|
|
# ------------------------------------------------------------------------------
|
|
|
|
_drush() {
|
|
local curcontext='$curcontext' state line cmds ret=1
|
|
integer NORMARG
|
|
typeset -A opt_args
|
|
|
|
global_args=('--debug' '--verbose' '--yes' '--no' '--simulate' '--root=' '--uri=')
|
|
|
|
_arguments -C \
|
|
'(--*)'{--version,--version}'[Show drush version.]' \
|
|
'(- *)'{-d,--debug}'[Display even more information, including internal messages.]' \
|
|
'(- *)'{-v,--verbose}'[Display extra information about the command.]' \
|
|
'(- *)'{-y,--yes}'[Assume "yes" as answer to all prompts.]' \
|
|
'(- *)'{-n,--no}'[Assume "no" as answer to all prompts.]' \
|
|
'(- *)'{-s,--simulate}'[Simulate all relevant actions (dont actually change the system).]' \
|
|
'(- *)'{-r,--root=}'[Drupal root directory to use (default: current directory).]' \
|
|
'(- *)'{-l,--uri=}'[URI of the drupal site to use (only needed in multisite environments or when running on an alternate port).]' \
|
|
'1: :->cmds' \
|
|
'*::arg:->args' \
|
|
&& ret=0
|
|
|
|
case $state in
|
|
cmds)
|
|
_values 'drush command' \
|
|
'(archive-dump)'{archive-dump,ard,arb}'[Backup your code, files, and database into a single file.]' \
|
|
'(archive-restore)'{archive-restore,arr}'[Expand a site archive into a Drupal web site.]' \
|
|
'(cache-clear)'{cache-clear,cc}'[Clear a specific cache, or all drupal caches.]' \
|
|
'(core-status)'{core-status,status,st}'[Provides a birds-eye view of the current Drupal installation, if any.]' \
|
|
'(core-cron)'{core-cron,cron}'[Run all cron hooks in all active modules for specified site.]' \
|
|
'(core-execute)'{core-execute,exec}'[Execute a shell command. Usually used with a site alias.]' \
|
|
'(drupal-directory)'{drupal-directory,dd}'[Return the filesystem path for modules/themes and other key folders.]' \
|
|
'help[Print this help message.]' \
|
|
'image-flush[Flush all derived images for a given style.]' \
|
|
'(site-alias)'{site-alias,sa}'[Print an alias record.]' \
|
|
'(site-install)'{site-install,si}'[Install Drupal along with modules/themes/configuration using the specified install profile.]' \
|
|
'test-clean[Clean temporary tables and files.]' \
|
|
'test-run[Run tests. Note that you must use the --uri option.]' \
|
|
'(updatedb)'{updatedb,updb}'[Apply any database updates required (as with running update.php).]' \
|
|
'(variable-delete)'{variable-delete,vdel}'[Delete a variable.]' \
|
|
'(variable-get)'{variable-get,vget}'[Get a list of some or all site variables and values.]' \
|
|
'(variable-set)'{variable-set,vset}'[Set a variable.]' \
|
|
'(pm-list)'{pm-list,pml}'[Show a list of available extensions (modules and themes).]' \
|
|
'(pm-disable)'{pm-disable,dis}'[Disable one or more extensions (modules or themes). Disable dependant extensions as well.]' \
|
|
'(pm-download)'{pm-download,dl}'[Download projects from drupal.org or other sources.]' \
|
|
'(pm-enable)'{pm-enable,en}'[Enable one or more extensions (modules or themes). Enable dependant extensions as well.]' \
|
|
'pm-uninstall[Uninstall one or more modules.]' \
|
|
'pm-update[Update Drupal core and contrib projects and apply any pending database updates (Same as pm-updatecode + updatedb).]' \
|
|
'(sql-cli)'{sql-cli,sqlc}'[Open a SQL command-line interface using Drupals credentials.]' \
|
|
'sql-drop[Drop all tables in a given database.]' \
|
|
'sql-dump[Exports the Drupal DB as SQL using mysqldump or equivalent.]' \
|
|
'(sql-query)'{sql-query,sqlq}'[Execute a query against the site database.]' \
|
|
'sql-sync[Copy and import source database to target database. Transfers via rsync.]' \
|
|
'(user-login)'{user-login,uli}'[Display a one time login link for the given user account (defaults to uid 1).]' \
|
|
'(user-password)'{user-password,upwd}'[(Re)Set the password for the user account with the specified name.]' \
|
|
'(devel-reinstall)'{devel-reinstall,dre}'[Disable, Uninstall, and Install a list of projects. (devel)]' \
|
|
'(devel-token)'{devel-token,token}'[List available tokens (devel)]' \
|
|
'(generate-content)'{generate-content,genc}'[Create content. (devel_generate)]' \
|
|
'(generate-menus)'{generate-menus,genm}'[Create menus and menu items. (devel_generate)]' \
|
|
'(generate-terms)'{generate-terms,gent}'[Create terms in specified vocabulary. (devel_generate)]' \
|
|
'(generate-users)'{generate-users,genu}'[Create users. (devel_generate)]' \
|
|
'(generate-vocabs)'{generate-vocabs,genv}'[Create vocabularies. (devel_generate)]' \
|
|
'(features-diff)'{features-diff,fd}'[Show the difference between the default and overridden state of a feature.]' \
|
|
'(features-export)'{features-export,fe}'[Export a feature from your site into a module.]' \
|
|
'(features-list)'{features-list,fl}'[List all the available features for your site.]' \
|
|
'(features-revert)'{features-revert,fr}'[Revert a feature module on your site.]' \
|
|
'(features-revert-all)'{features-revert-all,fra}'[Revert all enabled feature module on your site.]' \
|
|
'(features-update)'{features-update,fu}'[Update a feature module on your site.]' \
|
|
'(features-update-all)'{features-update-all,fua}'[Update all feature modules on your site.]' \
|
|
&& ret=0
|
|
;;
|
|
args)
|
|
case $line[1] in
|
|
(archive-dump|ard)
|
|
_arguments \
|
|
'(--description)--description=[Filter out extensions that are provided by drupal core.]' \
|
|
'(--destination)--destination=[The full path and filename in which the archive should be stored. If omitted, it will be saved to the drush-backups directory.]' \
|
|
'(--no-core)--no-core[Exclude Drupal core, so the backup only contains the site specific stuff.]' \
|
|
'(--pipe)--pipe[Only print the destination of the archive. Useful for scripts that dont pass --destination.]' \
|
|
'(--tar-options)--tar-options=[Options passed thru to the tar command.]' \
|
|
&& ret=0
|
|
compadd -a global_args
|
|
;;
|
|
(archive-restore|arr)
|
|
_arguments \
|
|
'(--db-prefix)--db-prefix[An optional table prefix to use during restore.]' \
|
|
'(--db-su)--db-su[Account to use when creating the new database. Optional.]' \
|
|
'(--db-su-pw)--db-su-pw[Password for the "db-su" account. Optional.]' \
|
|
'(--db-url)--db-url=[A Drupal 6 style database URL indicating the target for database restore. If not provided, the archived settings.php is used. ]' \
|
|
'(--destination)--destination[Specify where the Drupal site should be expanded, including the docroot. Defaults to the current working directory.]' \
|
|
'(--overwrite)--overwrite[Allow drush to overwrite any files in the destination.]' \
|
|
&& ret=0
|
|
compadd -a global_args
|
|
;;
|
|
(user-password|upwd)
|
|
_arguments \
|
|
'--password=:Set the password for the username someuser.' \
|
|
&& ret=0
|
|
;;
|
|
(help)
|
|
_values 'commands' 'arb' 'archive-dump' 'archive-restore' 'ard' 'arr' 'cache-clear' 'cc' 'core-cron' 'core-execute' 'core-status' 'cron' 'dd' 'devel-reinstall' 'devel-token' 'dis' 'dl' 'dre' 'drupal-directory' 'en' 'exec' 'fd' 'fe' 'features-diff' 'features-export' 'features-list' 'features-revert' 'features-revert-all' 'features-update' 'features-update-all' 'fl' 'fr' 'fra' 'fu' 'fua' 'genc' 'generate-content' 'generate-menus' 'generate-terms' 'generate-users' 'generate-vocabs' 'genm' 'gent' 'genu' 'genv' 'help' 'image-flush' 'pm-disable' 'pm-download' 'pm-enable' 'pm-list' 'pm-uninstall' 'pm-update' 'pml' 'sa' 'si' 'site-alias' 'site-install' 'sql-cli' 'sql-drop' 'sql-dump' 'sql-query' 'sql-sync' 'sqlc' 'sqlq' 'st' 'status' 'test-clean' 'test-run' 'token' 'uli' 'updatedb' 'updb' 'upwd' 'user-login' 'user-password' 'variable-delete' 'variable-get' 'variable-set' 'vdel' 'vget' 'vset'
|
|
;;
|
|
(cc)
|
|
_values 'options' 'all' 'drush' 'theme-registry' 'menu' 'css-js' 'block'
|
|
;;
|
|
(pm-list|pml)
|
|
_arguments \
|
|
'(--core)--core[Filter out extensions that are not in drupal core.]' \
|
|
'(--no-core)--no-core[Filter out extensions that are provided by drupal core.]' \
|
|
'(--pipe)--pipe[Returns a whitespace delimited list of the names of the resulting extensions.]' \
|
|
'(--status)--status=-[Filter by extension status. Choices: enabled, disabled and/or "not installed".]:status:(enabled disabled)' \
|
|
'(--type)--type=-[Filter by extensions ension type. Choices: module, theme.]:type:(module theme)' \
|
|
&& ret=0
|
|
;;
|
|
(pm-disable|dis)
|
|
_modules=( $(drush pml --status=enabled --pipe) )
|
|
if [[ $_modules != "" ]]; then
|
|
_values 'enabled modules' $_modules
|
|
fi
|
|
;;
|
|
(pm-enable|en)
|
|
_arguments -C \
|
|
'--resolve-dependencies[Attempt to download any missing dependencies. At the moment, only works when the module name is the same as the project name.]' \
|
|
'--skip[Skip automatic downloading of libraries (c.f. devel).]' && ret=0
|
|
_modules=( $(drush pml --status="disabled,not installed" --pipe) )
|
|
if [[ $_modules != "" ]]; then
|
|
_values -s 'not yet enabled modules' $_modules && ret=0
|
|
fi
|
|
;;
|
|
(*)
|
|
_values 'Global options' \
|
|
{-d,--debug}'[Display even more information, including internal messages.]' \
|
|
{-v,--verbose}'[Display extra information about the command.]' \
|
|
{-y,--yes}'[Assume "yes" as answer to all prompts.]' \
|
|
{-n,--no}'[Assume "no" as answer to all prompts.]' \
|
|
{-s,--simulate}'[Simulate all relevant actions (dont actually change the system).]' \
|
|
{-r,--root=}'[Drupal root directory to use (default: current directory).]' \
|
|
{-l,--uri=}'[URI of the drupal site to use (only needed in multisite environments or when running on an alternate port).]'
|
|
;;
|
|
esac
|
|
;;
|
|
esac
|
|
}
|
|
|
|
_drush '$@'
|
|
|
|
# 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
|