plugins/django/django.plugin.zsh
f9bf396e
 #compdef manage.py
 
 typeset -ga nul_args
 nul_args=(
   '--settings=-[the Python path to a settings module.]:file:_files'
   '--pythonpath=-[a directory to add to the Python path.]::directory:_directories'
   '--traceback[print traceback on exception.]'
   "--version[show program's version number and exit.]"
   {-h,--help}'[show this help message and exit.]'
 )
 
 _managepy-adminindex(){
   _arguments -s : \
     $nul_args \
     '*::directory:_directories' && ret=0
 }
 
 _managepy-createcachetable(){
   _arguments -s : \
     $nul_args && ret=0
 }
 
 _managepy-dbshell(){
   _arguments -s : \
     $nul_args && ret=0
 }
 
 _managepy-diffsettings(){
   _arguments -s : \
     $nul_args && ret=0
 }
 
 _managepy-dumpdata(){
   _arguments -s : \
     '--format=-[specifies the output serialization format for fixtures.]:format:(json yaml xml)' \
     '--indent=-[specifies the indent level to use when pretty-printing output.]:' \
     $nul_args \
     '*::appname:_applist' && ret=0
 }
 
 _managepy-flush(){
   _arguments -s : \
     '--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
     '--noinput[tells Django to NOT prompt the user for input of any kind.]' \
     $nul_args && ret=0
 }
 
 _managepy-help(){
   _arguments -s : \
     '*:command:_managepy_cmds' \
     $nul_args && ret=0
 }
 
 _managepy_cmds(){
     local line
     local -a cmd
     _call_program help-command ./manage.py help \
       |& sed -n '/^ /s/[(), ]/ /gp' \
       | while read -A line; do cmd=($line $cmd) done
     _describe -t managepy-command 'manage.py command' cmd
 }
 
 _managepy-inspectdb(){
   _arguments -s : \
     $nul_args && ret=0
 }
 
 _managepy-loaddata(){
   _arguments -s : \
     '--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
     '*::file:_files' \
     $nul_args && ret=0
 }
 
 _managepy-reset(){
   _arguments -s : \
     '--noinput[tells Django to NOT prompt the user for input of any kind.]' \
     '*::appname:_applist' \
     $nul_args && ret=0
 }
 
 _managepy-runfcgi(){
   local state
   
   local fcgi_opts
   fcgi_opts=(
     'protocol[fcgi, scgi, ajp, ... (default fcgi)]:protocol:(fcgi scgi ajp)'
     'host[hostname to listen on..]:'
     'port[port to listen on.]:'
     'socket[UNIX socket to listen on.]::file:_files'
     'method[prefork or threaded (default prefork)]:method:(prefork threaded)'
     'maxrequests[number of requests a child handles before it is killed and a new child is forked (0 = no limit).]:'
     'maxspare[max number of spare processes / threads.]:'
     'minspare[min number of spare processes / threads.]:'
     'maxchildren[hard limit number of processes / threads.]:'
     'daemonize[whether to detach from terminal.]:boolean:(False True)'
     'pidfile[write the spawned process-id to this file.]:file:_files'
     'workdir[change to this directory when daemonizing.]:directory:_files'
     'outlog[write stdout to this file.]:file:_files'
     'errlog[write stderr to this file.]:file:_files'
   )
   
   _arguments -s : \
     $nul_args \
     '*: :_values "FCGI Setting" $fcgi_opts' && ret=0
 }
 
 _managepy-runserver(){
   _arguments -s : \
     '--noreload[tells Django to NOT use the auto-reloader.]' \
     '--adminmedia[specifies the directory from which to serve admin media.]:directory:_files' \
     $nul_args && ret=0
 }
 
 _managepy-shell(){
   _arguments -s : \
     '--plain[tells Django to use plain Python, not IPython.]' \
     $nul_args && ret=0
 }
 
 _managepy-sql(){}
 _managepy-sqlall(){}
 _managepy-sqlclear(){}
 _managepy-sqlcustom(){}
 _managepy-sqlflush(){}
 _managepy-sqlindexes(){}
 _managepy-sqlinitialdata(){}
 _managepy-sqlreset(){}
 _managepy-sqlsequencereset(){}
 _managepy-startapp(){}
 
 _managepy-syncdb() {
   _arguments -s : \
     '--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
     '--noinput[tells Django to NOT prompt the user for input of any kind.]' \
     $nul_args && ret=0
 }
 
 _managepy-test() {
   _arguments -s : \
     '--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
     '--noinput[tells Django to NOT prompt the user for input of any kind.]' \
     '*::appname:_applist' \
     $nul_args && ret=0
 }
 
 _managepy-testserver() {
   _arguments -s : \
     '--verbosity=-[verbosity level; 0=minimal output, 1=normal output, 2=all output.]:Verbosity:((0\:minimal 1\:normal 2\:all))' \
     '--addrport=-[port number or ipaddr:port to run the server on.]' \
     '*::fixture:_files' \
     $nul_args && ret=0
 }
 
 _managepy-validate() {
   _arguments -s : \
     $nul_args && ret=0
 }
 
 _managepy-commands() {
   local -a commands
   
   commands=(
     'adminindex:prints the admin-index template snippet for the given app name(s).'
     'createcachetable:creates the table needed to use the SQL cache backend.'
     'dbshell:runs the command-line client for the current DATABASE_ENGINE.'
     "diffsettings:displays differences between the current settings.py and Django's default settings."
     'dumpdata:Output the contents of the database as a fixture of the given format.'
     'flush:Executes ``sqlflush`` on the current database.'
     'help:manage.py help.'
     'inspectdb:Introspects the database tables in the given database and outputs a Django model module.'
     'loaddata:Installs the named fixture(s) in the database.'
     'reset:Executes ``sqlreset`` for the given app(s) in the current database.'
     'runfcgi:Run this project as a fastcgi (or some other protocol supported by flup) application,'
     'runserver:Starts a lightweight Web server for development.'
     'shell:Runs a Python interactive interpreter.'
     'sql:Prints the CREATE TABLE SQL statements for the given app name(s).'
     'sqlall:Prints the CREATE TABLE, custom SQL and CREATE INDEX SQL statements for the given model module name(s).'
     'sqlclear:Prints the DROP TABLE SQL statements for the given app name(s).'
     'sqlcustom:Prints the custom table modifying SQL statements for the given app name(s).'
     'sqlflush:Returns a list of the SQL statements required to return all tables in the database to the state they were in just after they were installed.'
     'sqlindexes:Prints the CREATE INDEX SQL statements for the given model module name(s).'
     "sqlinitialdata:RENAMED: see 'sqlcustom'"
     'sqlreset:Prints the DROP TABLE SQL, then the CREATE TABLE SQL, for the given app name(s).'
     'sqlsequencereset:Prints the SQL statements for resetting sequences for the given app name(s).'
     "startapp:Creates a Django app directory structure for the given app name in this project's directory."
     "syncdb:Create the database tables for all apps in INSTALLED_APPS whose tables haven't already been created."
     'test:Runs the test suite for the specified applications, or the entire site if no apps are specified.'
     'testserver:Runs a development server with data from the given fixture(s).'
     'validate:Validates all installed models.'
   )
   
   _describe -t commands 'manage.py command' commands && ret=0
 }
 
 _applist() {
   local line
   local -a apps
   _call_program help-command "python -c \"import os.path as op, re, django.conf, sys;\\
                                           bn=op.basename(op.abspath(op.curdir));[sys\\
                                           .stdout.write(str(re.sub(r'^%s\.(.*?)$' %
                                           bn, r'\1', i)) + '\n') for i in django.conf.settings.\\
                                           INSTALLED_APPS if re.match(r'^%s' % bn, i)]\"" \
                              | while read -A line; do apps=($line $apps) done
   _values 'Application' $apps && ret=0
 }
 
 _managepy() {
   local curcontext=$curcontext ret=1
   
   if ((CURRENT == 2)); then
     _managepy-commands
   else
     shift words
     (( CURRENT -- ))
     curcontext="${curcontext%:*:*}:managepy-$words[1]:"
     _call_function ret _managepy-$words[1]
   fi
 }
 
 compdef _managepy manage.py
 compdef _managepy django