mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2025-12-26 02:12:33 +01:00
minimal plugins now!
This commit is contained in:
parent
36d897addd
commit
65c9751b92
53 changed files with 1 additions and 3579 deletions
|
|
@ -1,26 +0,0 @@
|
||||||
stat -f%m . > /dev/null 2>&1
|
|
||||||
if [ "$?" = 0 ]; then
|
|
||||||
stat_cmd=(stat -f%m)
|
|
||||||
else
|
|
||||||
stat_cmd=(stat -L --format=%Y)
|
|
||||||
fi
|
|
||||||
|
|
||||||
_ant_does_target_list_need_generating () {
|
|
||||||
if [ ! -f .ant_targets ]; then return 0;
|
|
||||||
else
|
|
||||||
accurate=$($stat_cmd .ant_targets)
|
|
||||||
changed=$($stat_cmd build.xml)
|
|
||||||
return $(expr $accurate '>=' $changed)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_ant () {
|
|
||||||
if [ -f build.xml ]; then
|
|
||||||
if _ant_does_target_list_need_generating; then
|
|
||||||
sed -n '/<target/s/<target.*name="\([^"]*\).*$/\1/p' build.xml > .ant_targets
|
|
||||||
fi
|
|
||||||
compadd `cat .ant_targets`
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compdef _ant ant
|
|
||||||
|
|
@ -59,3 +59,4 @@ asroot() {
|
||||||
|
|
||||||
# TODO There needs to be a better way to support this
|
# TODO There needs to be a better way to support this
|
||||||
[[ -x /usr/bin/cower ]] && source $ZSH/plugins/archlinux/aur-helpers/aur-helper-cower.zsh
|
[[ -x /usr/bin/cower ]] && source $ZSH/plugins/archlinux/aur-helpers/aur-helper-cower.zsh
|
||||||
|
[[ -x /usr/bin/meat ]] && source $ZSH/plugins/archlinux/aur-helpers/aur-helper-meat.zsh
|
||||||
|
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
||||||
if [ -f `brew --prefix`/etc/autojump ]; then
|
|
||||||
. `brew --prefix`/etc/autojump
|
|
||||||
fi
|
|
||||||
|
|
@ -1,82 +0,0 @@
|
||||||
#compdef bundle
|
|
||||||
|
|
||||||
local curcontext="$curcontext" state line _gems _opts ret=1
|
|
||||||
|
|
||||||
_arguments -C -A "-v" -A "--version" \
|
|
||||||
'(- 1 *)'{-v,--version}'[display version information]' \
|
|
||||||
'1: :->cmds' \
|
|
||||||
'*:: :->args' && ret=0
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
cmds)
|
|
||||||
_values "bundle command" \
|
|
||||||
"install[Install the gems specified by the Gemfile or Gemfile.lock]" \
|
|
||||||
"update[Update dependencies to their latest versions]" \
|
|
||||||
"package[Package the .gem files required by your application]" \
|
|
||||||
"exec[Execute a script in the context of the current bundle]" \
|
|
||||||
"config[Specify and read configuration options for bundler]" \
|
|
||||||
"check[Determine whether the requirements for your application are installed]" \
|
|
||||||
"list[Show all of the gems in the current bundle]" \
|
|
||||||
"show[Show the source location of a particular gem in the bundle]" \
|
|
||||||
"console[Start an IRB session in the context of the current bundle]" \
|
|
||||||
"open[Open an installed gem in the editor]" \
|
|
||||||
"viz[Generate a visual representation of your dependencies]" \
|
|
||||||
"init[Generate a simple Gemfile, placed in the current directory]" \
|
|
||||||
"gem[Create a simple gem, suitable for development with bundler]" \
|
|
||||||
"help[Describe available tasks or one specific task]"
|
|
||||||
ret=0
|
|
||||||
;;
|
|
||||||
args)
|
|
||||||
case $line[1] in
|
|
||||||
help)
|
|
||||||
_values 'commands' \
|
|
||||||
'install' \
|
|
||||||
'update' \
|
|
||||||
'package' \
|
|
||||||
'exec' \
|
|
||||||
'config' \
|
|
||||||
'check' \
|
|
||||||
'list' \
|
|
||||||
'show' \
|
|
||||||
'console' \
|
|
||||||
'open' \
|
|
||||||
'viz' \
|
|
||||||
'init' \
|
|
||||||
'gem' \
|
|
||||||
'help' && ret=0
|
|
||||||
;;
|
|
||||||
install)
|
|
||||||
_arguments \
|
|
||||||
'(--no-color)--no-color[disable colorization in output]' \
|
|
||||||
'(--local)--local[do not attempt to connect to rubygems.org]' \
|
|
||||||
'(--quiet)--quiet[only output warnings and errors]' \
|
|
||||||
'(--gemfile)--gemfile=-[use the specified gemfile instead of Gemfile]:gemfile' \
|
|
||||||
'(--system)--system[install to the system location]' \
|
|
||||||
'(--deployment)--deployment[install using defaults tuned for deployment environments]' \
|
|
||||||
'(--frozen)--frozen[do not allow the Gemfile.lock to be updated after this install]' \
|
|
||||||
'(--path)--path=-[specify a different path than the system default]:path:_files' \
|
|
||||||
'(--binstubs)--binstubs=-[generate bin stubs for bundled gems to ./bin]:directory:_files' \
|
|
||||||
'(--without)--without=-[exclude gems that are part of the specified named group]:groups'
|
|
||||||
ret=0
|
|
||||||
;;
|
|
||||||
exec)
|
|
||||||
_normal && ret=0
|
|
||||||
;;
|
|
||||||
(open|show)
|
|
||||||
_gems=( $(bundle show 2> /dev/null | sed -e '/^ \*/!d; s/^ \* \([^ ]*\) .*/\1/') )
|
|
||||||
if [[ $_gems != "" ]]; then
|
|
||||||
_values 'gems' $_gems && ret=0
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
_opts=( $(bundle help $line[1] | sed -e '/^ \[-/!d; s/^ \[\(-[^=]*\)=.*/\1/') )
|
|
||||||
_opts+=( $(bundle help $line[1] | sed -e '/^ -/!d; s/^ \(-.\), \[\(-[^=]*\)=.*/\1 \2/') )
|
|
||||||
if [[ $_opts != "" ]]; then
|
|
||||||
_values 'options' $_opts && ret=0
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
return ret
|
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
fpath=($ZSH/plugins/bundler $fpath)
|
|
||||||
autoload -U compinit
|
|
||||||
compinit -i
|
|
||||||
|
|
||||||
alias be="bundle exec"
|
|
||||||
alias bi="bundle install"
|
|
||||||
alias bl="bundle list"
|
|
||||||
alias bp="bundle package"
|
|
||||||
alias bu="bundle update"
|
|
||||||
|
|
||||||
# The following is based on https://github.com/gma/bundler-exec
|
|
||||||
|
|
||||||
bundled_commands=(cap capify cucumber foreman guard heroku nanoc rackup rails rainbows rake rspec ruby shotgun spec spork thin unicorn unicorn_rails)
|
|
||||||
|
|
||||||
## Functions
|
|
||||||
|
|
||||||
_bundler-installed() {
|
|
||||||
which bundle > /dev/null 2>&1
|
|
||||||
}
|
|
||||||
|
|
||||||
_within-bundled-project() {
|
|
||||||
local check_dir=$PWD
|
|
||||||
while [ "$(dirname $check_dir)" != "/" ]; do
|
|
||||||
[ -f "$check_dir/Gemfile" ] && return
|
|
||||||
check_dir="$(dirname $check_dir)"
|
|
||||||
done
|
|
||||||
false
|
|
||||||
}
|
|
||||||
|
|
||||||
_run-with-bundler() {
|
|
||||||
if _bundler-installed && _within-bundled-project; then
|
|
||||||
bundle exec $@
|
|
||||||
else
|
|
||||||
$@
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
## Main program
|
|
||||||
for cmd in $bundled_commands; do
|
|
||||||
eval "function bundled_$cmd () { _run-with-bundler $cmd \$@}"
|
|
||||||
alias $cmd=bundled_$cmd
|
|
||||||
|
|
||||||
if which _$cmd > /dev/null 2>&1; then
|
|
||||||
compdef _$cmd bundled_$cmd
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
@ -1,36 +0,0 @@
|
||||||
# Set this to 1 if you want to cache the tasks
|
|
||||||
_cake_cache_task_list=1
|
|
||||||
|
|
||||||
# Cache filename
|
|
||||||
_cake_task_cache_file='.cake_task_cache'
|
|
||||||
|
|
||||||
_cake_get_target_list () {
|
|
||||||
cake | grep '^cake ' | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$'
|
|
||||||
}
|
|
||||||
|
|
||||||
_cake_does_target_list_need_generating () {
|
|
||||||
|
|
||||||
if [ ${_cake_cache_task_list} -eq 0 ]; then
|
|
||||||
return 1;
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -f ${_cake_task_cache_file} ]; then return 0;
|
|
||||||
else
|
|
||||||
accurate=$(stat -f%m $_cake_task_cache_file)
|
|
||||||
changed=$(stat -f%m Cakefile)
|
|
||||||
return $(expr $accurate '>=' $changed)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_cake () {
|
|
||||||
if [ -f Cakefile ]; then
|
|
||||||
if _cake_does_target_list_need_generating; then
|
|
||||||
_cake_get_target_list > ${_cake_task_cache_file}
|
|
||||||
compadd `cat ${_cake_task_cache_file}`
|
|
||||||
else
|
|
||||||
compadd `_cake_get_target_list`
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compdef _cake cake
|
|
||||||
|
|
@ -1,21 +0,0 @@
|
||||||
function _cap_does_task_list_need_generating () {
|
|
||||||
if [ ! -f .cap_tasks~ ]; then return 0;
|
|
||||||
else
|
|
||||||
accurate=$(stat -f%m .cap_tasks~)
|
|
||||||
changed=$(stat -f%m config/deploy.rb)
|
|
||||||
return $(expr $accurate '>=' $changed)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function _cap () {
|
|
||||||
if [ -f config/deploy.rb ]; then
|
|
||||||
if _cap_does_task_list_need_generating; then
|
|
||||||
echo "\nGenerating .cap_tasks~..." > /dev/stderr
|
|
||||||
cap show_tasks -q | cut -d " " -f 1 | sed -e '/^ *$/D' -e '1,2D'
|
|
||||||
> .cap_tasks~
|
|
||||||
fi
|
|
||||||
compadd `cat .cap_tasks~`
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compctl -K _cap cap
|
|
||||||
|
|
@ -1,20 +0,0 @@
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
# FILE: compleat.plugin.zsh
|
|
||||||
# DESCRIPTION: oh-my-zsh plugin file.
|
|
||||||
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
|
||||||
# VERSION: 1.0.0
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
if (( ${+commands[compleat]} )); then
|
|
||||||
local prefix="${commands[compleat]:h:h}"
|
|
||||||
local setup="${prefix}/share/compleat-1.0/compleat_setup"
|
|
||||||
|
|
||||||
if [[ -f "$setup" ]]; then
|
|
||||||
if ! bashcompinit >/dev/null 2>&1; then
|
|
||||||
autoload -U bashcompinit
|
|
||||||
bashcompinit -i
|
|
||||||
fi
|
|
||||||
|
|
||||||
source "$setup"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
@ -1,67 +0,0 @@
|
||||||
#compdef cpanm
|
|
||||||
|
|
||||||
##
|
|
||||||
# cpanminus Z Shell completion script
|
|
||||||
##
|
|
||||||
#
|
|
||||||
# Current supported cpanm version: 1.4000 (Tue Mar 8 01:00:49 PST 2011)
|
|
||||||
#
|
|
||||||
# The latest code is always located at:
|
|
||||||
# https://github.com/rshhh/cpanminus/blob/master/etc/_cpanm
|
|
||||||
#
|
|
||||||
|
|
||||||
local arguments curcontext="$curcontext"
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
|
|
||||||
arguments=(
|
|
||||||
|
|
||||||
# Commands
|
|
||||||
# '(--install -i)'{--install,-i}'[Installs the modules]'
|
|
||||||
'(- :)--self-upgrade[Upgrades itself]'
|
|
||||||
'(- :)--info[Displays distribution info on CPAN]'
|
|
||||||
'(--installdeps)--installdeps[Only install dependencies]'
|
|
||||||
'(--look)--look[Download/unpack the distribution and then open the directory with your shell]'
|
|
||||||
'(- :)'{--help,-h}'[Displays help information]'
|
|
||||||
'(- :)'{--version,-V}'[Displays software version]'
|
|
||||||
|
|
||||||
# Options
|
|
||||||
{--force,-f}'[Force install]'
|
|
||||||
{--notest,-n}'[Do not run unit tests]'
|
|
||||||
{--sudo,-S}'[sudo to run install commands]'
|
|
||||||
'(-v --verbose --quiet -q)'{--verbose,-v}'[Turns on chatty output]'
|
|
||||||
'(-q --quiet --verbose -v)'{--quiet,-q}'[Turns off all output]'
|
|
||||||
{--local-lib,-l}'[Specify the install base to install modules]'
|
|
||||||
{--local-lib-contained,-L}'[Specify the install base to install all non-core modules]'
|
|
||||||
'--mirror[Specify the base URL for the mirror (e.g. http://cpan.cpantesters.org/)]:URLs:_urls'
|
|
||||||
'--mirror-only[Use the mirror\''s index file instead of the CPAN Meta DB]'
|
|
||||||
'--prompt[Prompt when configure/build/test fails]'
|
|
||||||
'--reinstall[Reinstall the distribution even if you already have the latest version installed]'
|
|
||||||
'--interactive[Turn on interactive configure]'
|
|
||||||
|
|
||||||
'--scandeps[Scan the depencencies of given modules and output the tree in a text format]'
|
|
||||||
'--format[Specify what format to display the scanned dependency tree]:scandeps format:(tree json yaml dists)'
|
|
||||||
|
|
||||||
'--save-dists[Specify the optional directory path to copy downloaded tarballs]'
|
|
||||||
# '--uninst-shadows[Uninstalls the shadow files of the distribution that you\''re installing]'
|
|
||||||
|
|
||||||
'--auto-cleanup[Number of days that cpanm\''s work directories expire in. Defaults to 7]'
|
|
||||||
'(--no-man-pages)--man-pages[Generates man pages for executables (man1) and libraries (man3)]'
|
|
||||||
'(--man-pages)--no-man-pages[Do not generate man pages]'
|
|
||||||
|
|
||||||
|
|
||||||
# Note: Normally with "--lwp", "--wget" and "--curl" options set to true (which is the default) cpanm tries LWP,
|
|
||||||
# Wget, cURL and HTTP::Tiny (in that order) and uses the first one available.
|
|
||||||
# (So that the exclusions are not enabled here for the completion)
|
|
||||||
'(--lwp)--lwp[Use LWP module to download stuff]'
|
|
||||||
'(--wget)--wget[Use GNU Wget (if available) to download stuff]'
|
|
||||||
'(--curl)--curl[Use cURL (if available) to download stuff]'
|
|
||||||
|
|
||||||
# Other completions
|
|
||||||
'*:Local directory or archive:_files -/ -g "*.(tar.gz|tgz|tar.bz2|zip)(-.)"'
|
|
||||||
# '*::args: _normal' # this looks for default files (any files)
|
|
||||||
)
|
|
||||||
_arguments -s $arguments \
|
|
||||||
&& return 0
|
|
||||||
|
|
||||||
return 1
|
|
||||||
|
|
@ -1,39 +0,0 @@
|
||||||
#!/bin/zsh
|
|
||||||
#
|
|
||||||
# Make the dirstack more persistant
|
|
||||||
#
|
|
||||||
# Add dirpersist to $plugins in ~/.zshrc to load
|
|
||||||
#
|
|
||||||
|
|
||||||
# $zdirstore is the file used to persist the stack
|
|
||||||
zdirstore=~/.zdirstore
|
|
||||||
|
|
||||||
dirpersistinstall () {
|
|
||||||
if grep 'dirpersiststore' ~/.zlogout > /dev/null; then
|
|
||||||
else
|
|
||||||
if read -q \?"Would you like to set up your .zlogout file for use with dirspersist? (y/n) "; then
|
|
||||||
echo "# Store dirs stack\n# See ~/.oh-my-zsh/plugins/dirspersist.plugin.zsh\ndirpersiststore" >> ~/.zlogout
|
|
||||||
else
|
|
||||||
echo "If you don't want this message to appear, remove dirspersist from \$plugins"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
dirpersiststore () {
|
|
||||||
dirs -p | perl -e 'foreach (reverse <STDIN>) {chomp;s/([& ])/\\$1/g ;print "if [ -d $_ ]; then pushd -q $_; fi\n"}' > $zdirstore
|
|
||||||
}
|
|
||||||
|
|
||||||
dirpersistrestore () {
|
|
||||||
if [ -f $zdirstore ]; then
|
|
||||||
source $zdirstore
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
DIRSTACKSIZE=10
|
|
||||||
setopt autopushd pushdminus pushdsilent pushdtohome pushdignoredups
|
|
||||||
|
|
||||||
dirpersistinstall
|
|
||||||
dirpersistrestore
|
|
||||||
|
|
||||||
# Make popd changes permanent without having to wait for logout
|
|
||||||
alias popd="popd;dirpersiststore"
|
|
||||||
|
|
@ -1,222 +0,0 @@
|
||||||
#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
|
|
||||||
|
|
@ -1,8 +0,0 @@
|
||||||
#compdef extract
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
'(-r --remove)'{-r,--remove}'[Remove archive.]' \
|
|
||||||
"*::archive file:_files -g '(#i)*.(tar|tgz|tbz|tbz2|txz|tlz|gz|bz2|xz|lzma|Z|zip|rar|7z|deb)(-.)'" && return 0
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,85 +0,0 @@
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
# FILE: extract.plugin.zsh
|
|
||||||
# DESCRIPTION: oh-my-zsh plugin file.
|
|
||||||
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
|
||||||
# VERSION: 1.0.1
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
function extract() {
|
|
||||||
local remove_archive
|
|
||||||
local success
|
|
||||||
local file_name
|
|
||||||
local extract_dir
|
|
||||||
|
|
||||||
if (( $# == 0 )); then
|
|
||||||
echo "Usage: extract [-option] [file ...]"
|
|
||||||
echo
|
|
||||||
echo Options:
|
|
||||||
echo " -r, --remove Remove archive."
|
|
||||||
echo
|
|
||||||
echo "Report bugs to <sorin.ionescu@gmail.com>."
|
|
||||||
fi
|
|
||||||
|
|
||||||
remove_archive=1
|
|
||||||
if [[ "$1" == "-r" ]] || [[ "$1" == "--remove" ]]; then
|
|
||||||
remove_archive=0
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
while (( $# > 0 )); do
|
|
||||||
if [[ ! -f "$1" ]]; then
|
|
||||||
echo "extract: '$1' is not a valid file" 1>&2
|
|
||||||
shift
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
success=0
|
|
||||||
file_name="$( basename "$1" )"
|
|
||||||
extract_dir="$( echo "$file_name" | sed "s/\.${1##*.}//g" )"
|
|
||||||
case "$1" in
|
|
||||||
(*.tar.gz|*.tgz) tar xvzf "$1" ;;
|
|
||||||
(*.tar.bz2|*.tbz|*.tbz2) tar xvjf "$1" ;;
|
|
||||||
(*.tar.xz|*.txz) tar --xz --help &> /dev/null \
|
|
||||||
&& tar --xz -xvf "$1" \
|
|
||||||
|| xzcat "$1" | tar xvf - ;;
|
|
||||||
(*.tar.zma|*.tlz) tar --lzma --help &> /dev/null \
|
|
||||||
&& tar --lzma -xvf "$1" \
|
|
||||||
|| lzcat "$1" | tar xvf - ;;
|
|
||||||
(*.tar) tar xvf "$1" ;;
|
|
||||||
(*.gz) gunzip "$1" ;;
|
|
||||||
(*.bz2) bunzip2 "$1" ;;
|
|
||||||
(*.xz) unxz "$1" ;;
|
|
||||||
(*.lzma) unlzma "$1" ;;
|
|
||||||
(*.Z) uncompress "$1" ;;
|
|
||||||
(*.zip) unzip "$1" -d $extract_dir ;;
|
|
||||||
(*.rar) unrar e -ad "$1" ;;
|
|
||||||
(*.7z) 7za x "$1" ;;
|
|
||||||
(*.deb)
|
|
||||||
mkdir -p "$extract_dir/control"
|
|
||||||
mkdir -p "$extract_dir/data"
|
|
||||||
cd "$extract_dir"; ar vx "../${1}" > /dev/null
|
|
||||||
cd control; tar xzvf ../control.tar.gz
|
|
||||||
cd ../data; tar xzvf ../data.tar.gz
|
|
||||||
cd ..; rm *.tar.gz debian-binary
|
|
||||||
cd ..
|
|
||||||
;;
|
|
||||||
(*)
|
|
||||||
echo "extract: '$1' cannot be extracted" 1>&2
|
|
||||||
success=1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
(( success = $success > 0 ? $success : $? ))
|
|
||||||
(( $success == 0 )) && (( $remove_archive == 0 )) && rm "$1"
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
alias x=extract
|
|
||||||
|
|
||||||
# add extract completion function to path
|
|
||||||
fpath=($ZSH/plugins/extract $fpath)
|
|
||||||
autoload -U compinit
|
|
||||||
compinit -i
|
|
||||||
|
|
||||||
|
|
@ -1,34 +0,0 @@
|
||||||
#compdef gas
|
|
||||||
|
|
||||||
local curcontext="$curcontext" state line cmds ret=1
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
'(- 1 *)'{-v,--version}'[display version information]' \
|
|
||||||
'(-h|--help)'{-h,--help}'[show help information]' \
|
|
||||||
'1: :->cmds' \
|
|
||||||
'*: :->args' && ret=0
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
cmds)
|
|
||||||
cmds=(
|
|
||||||
"version:Prints Gas's version"
|
|
||||||
"use:Uses author"
|
|
||||||
"show:Shows your current user"
|
|
||||||
"list:Lists your authors"
|
|
||||||
"import:Imports current user to gasconfig"
|
|
||||||
"help:Describe available tasks or one specific task"
|
|
||||||
"delete:Deletes author"
|
|
||||||
"add:Adds author to gasconfig"
|
|
||||||
)
|
|
||||||
_describe -t commands 'gas command' cmds && ret=0
|
|
||||||
;;
|
|
||||||
args)
|
|
||||||
case $line[1] in
|
|
||||||
(use|delete)
|
|
||||||
_values -S , 'authors' $(cat ~/.gas | sed -n -e 's/^\[\(.*\)\]/\1/p') && ret=0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
return ret
|
|
||||||
|
|
@ -1,64 +0,0 @@
|
||||||
#compdef gem
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
# gem zsh completion, based on homebrew completion
|
|
||||||
|
|
||||||
_gem_installed() {
|
|
||||||
installed_gems=(`gem list --local --no-versions`)
|
|
||||||
}
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
'cert:Manage RubyGems certificates and signing settings'
|
|
||||||
'check:Check installed gems'
|
|
||||||
'cleanup:Clean up old versions of installed gems in the local repository'
|
|
||||||
'contents:Display the contents of the installed gems'
|
|
||||||
'dependency:Show the dependencies of an installed gem'
|
|
||||||
'environment:Display information about the RubyGems environment'
|
|
||||||
'fetch:Download a gem and place it in the current directory'
|
|
||||||
'generate_index:Generates the index files for a gem server directory'
|
|
||||||
'help:Provide help on the `gem` command'
|
|
||||||
'install:Install a gem into the local repository'
|
|
||||||
'list:Display gems whose name starts with STRING'
|
|
||||||
'lock:Generate a lockdown list of gems'
|
|
||||||
'mirror:Mirror a gem repository'
|
|
||||||
'outdated:Display all gems that need updates'
|
|
||||||
'owner:Manage gem owners on RubyGems.org.'
|
|
||||||
'pristine:Restores installed gems to pristine condition from files located in the gem cache'
|
|
||||||
'push:Push a gem up to RubyGems.org'
|
|
||||||
'query:Query gem information in local or remote repositories'
|
|
||||||
'rdoc:Generates RDoc for pre-installed gems'
|
|
||||||
'search:Display all gems whose name contains STRING'
|
|
||||||
'server:Documentation and gem repository HTTP server'
|
|
||||||
'sources:Manage the sources and cache file RubyGems uses to search for gems'
|
|
||||||
'specification:Display gem specification (in yaml)'
|
|
||||||
'stale:List gems along with access times'
|
|
||||||
'uninstall:Uninstall gems from the local repository'
|
|
||||||
'unpack:Unpack an installed gem to the current directory'
|
|
||||||
'update:Update the named gems (or all installed gems) in the local repository'
|
|
||||||
'which:Find the location of a library file you can require'
|
|
||||||
)
|
|
||||||
|
|
||||||
local expl
|
|
||||||
local -a gems installed_gems
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
'(-v --version)'{-v,--version}'[show version]' \
|
|
||||||
'(-h --help)'{-h,--help}'[show help]' \
|
|
||||||
'*:: :->subcmds' && return 0
|
|
||||||
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
_describe -t commands "gem subcommand" _1st_arguments
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$words[1]" in
|
|
||||||
list)
|
|
||||||
if [[ "$state" == forms ]]; then
|
|
||||||
_gem_installed
|
|
||||||
_requested installed_gems expl 'installed gems' compadd -a installed_gems
|
|
||||||
fi ;;
|
|
||||||
uninstall|update)
|
|
||||||
_gem_installed
|
|
||||||
_wanted installed_gems expl 'installed gems' compadd -a installed_gems ;;
|
|
||||||
esac
|
|
||||||
|
|
@ -1,332 +0,0 @@
|
||||||
#!zsh
|
|
||||||
#
|
|
||||||
# Installation
|
|
||||||
# ------------
|
|
||||||
#
|
|
||||||
# To achieve git-flow completion nirvana:
|
|
||||||
#
|
|
||||||
# 0. Update your zsh's git-completion module to the newest verion.
|
|
||||||
# From here. http://zsh.git.sourceforge.net/git/gitweb.cgi?p=zsh/zsh;a=blob_plain;f=Completion/Unix/Command/_git;hb=HEAD
|
|
||||||
#
|
|
||||||
# 1. Install this file. Either:
|
|
||||||
#
|
|
||||||
# a. Place it in your .zshrc:
|
|
||||||
#
|
|
||||||
# b. Or, copy it somewhere (e.g. ~/.git-flow-completion.zsh) and put the following line in
|
|
||||||
# your .zshrc:
|
|
||||||
#
|
|
||||||
# source ~/.git-flow-completion.zsh
|
|
||||||
#
|
|
||||||
# c. Or, use this file as a oh-my-zsh plugin.
|
|
||||||
#
|
|
||||||
|
|
||||||
_git-flow ()
|
|
||||||
{
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
|
|
||||||
local -a subcommands
|
|
||||||
subcommands=(
|
|
||||||
'init:Initialize a new git repo with support for the branching model.'
|
|
||||||
'feature:Manage your feature branches.'
|
|
||||||
'release:Manage your release branches.'
|
|
||||||
'hotfix:Manage your hotfix branches.'
|
|
||||||
'support:Manage your support branches.'
|
|
||||||
'version:Shows version information.'
|
|
||||||
)
|
|
||||||
_describe -t commands 'git flow' subcommands
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
|
|
||||||
(init)
|
|
||||||
_arguments \
|
|
||||||
-f'[Force setting of gitflow branches, even if already configured]'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(version)
|
|
||||||
;;
|
|
||||||
|
|
||||||
(hotfix)
|
|
||||||
__git-flow-hotfix
|
|
||||||
;;
|
|
||||||
|
|
||||||
(release)
|
|
||||||
__git-flow-release
|
|
||||||
;;
|
|
||||||
|
|
||||||
(feature)
|
|
||||||
__git-flow-feature
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
__git-flow-release ()
|
|
||||||
{
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
|
|
||||||
local -a subcommands
|
|
||||||
subcommands=(
|
|
||||||
'start:Start a new release branch.'
|
|
||||||
'finish:Finish a release branch.'
|
|
||||||
'list:List all your release branches. (Alias to `git flow release`)'
|
|
||||||
)
|
|
||||||
_describe -t commands 'git flow release' subcommands
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
|
|
||||||
(start)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]'\
|
|
||||||
':version:__git_flow_version_list'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(finish)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]' \
|
|
||||||
-s'[Sign the release tag cryptographically]'\
|
|
||||||
-u'[Use the given GPG-key for the digital signature (implies -s)]'\
|
|
||||||
-m'[Use the given tag message]'\
|
|
||||||
-p'[Push to $ORIGIN after performing finish]'\
|
|
||||||
':version:__git_flow_version_list'
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
__git-flow-hotfix ()
|
|
||||||
{
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
|
|
||||||
local -a subcommands
|
|
||||||
subcommands=(
|
|
||||||
'start:Start a new hotfix branch.'
|
|
||||||
'finish:Finish a hotfix branch.'
|
|
||||||
'list:List all your hotfix branches. (Alias to `git flow hotfix`)'
|
|
||||||
)
|
|
||||||
_describe -t commands 'git flow hotfix' subcommands
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
|
|
||||||
(start)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]'\
|
|
||||||
':hotfix:__git_flow_version_list'\
|
|
||||||
':branch-name:__git_branch_names'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(finish)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]' \
|
|
||||||
-s'[Sign the release tag cryptographically]'\
|
|
||||||
-u'[Use the given GPG-key for the digital signature (implies -s)]'\
|
|
||||||
-m'[Use the given tag message]'\
|
|
||||||
-p'[Push to $ORIGIN after performing finish]'\
|
|
||||||
':hotfix:__git_flow_hotfix_list'
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
__git-flow-feature ()
|
|
||||||
{
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
|
|
||||||
local -a subcommands
|
|
||||||
subcommands=(
|
|
||||||
'start:Start a new feature branch.'
|
|
||||||
'finish:Finish a feature branch.'
|
|
||||||
'list:List all your feature branches. (Alias to `git flow feature`)'
|
|
||||||
'publish: public'
|
|
||||||
'track: track'
|
|
||||||
'diff: diff'
|
|
||||||
'rebase: rebase'
|
|
||||||
'checkout: checkout'
|
|
||||||
'pull: pull'
|
|
||||||
)
|
|
||||||
_describe -t commands 'git flow feature' subcommands
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
|
|
||||||
(start)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]'\
|
|
||||||
':feature:__git_flow_feature_list'\
|
|
||||||
':branch-name:__git_branch_names'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(finish)
|
|
||||||
_arguments \
|
|
||||||
-F'[Fetch from origin before performing finish]' \
|
|
||||||
-r'[Rebase instead of merge]'\
|
|
||||||
':feature:__git_flow_feature_list'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(publish)
|
|
||||||
_arguments \
|
|
||||||
':feature:__git_flow_feature_list'\
|
|
||||||
;;
|
|
||||||
|
|
||||||
(track)
|
|
||||||
_arguments \
|
|
||||||
':feature:__git_flow_feature_list'\
|
|
||||||
;;
|
|
||||||
|
|
||||||
(diff)
|
|
||||||
_arguments \
|
|
||||||
':branch:__git_branch_names'\
|
|
||||||
;;
|
|
||||||
|
|
||||||
(rebase)
|
|
||||||
_arguments \
|
|
||||||
-i'[Do an interactive rebase]' \
|
|
||||||
':branch:__git_branch_names'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(checkout)
|
|
||||||
_arguments \
|
|
||||||
':branch:__git_flow_feature_list'\
|
|
||||||
;;
|
|
||||||
|
|
||||||
(pull)
|
|
||||||
_arguments \
|
|
||||||
':remote:__git_remotes'\
|
|
||||||
':branch:__git_branch_names'
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
_arguments \
|
|
||||||
-v'[Verbose (more) output]'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_flow_version_list ()
|
|
||||||
{
|
|
||||||
local expl
|
|
||||||
declare -a versions
|
|
||||||
|
|
||||||
versions=(${${(f)"$(_call_program versions git flow release list 2> /dev/null | tr -d ' |*')"}})
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
_wanted versions expl 'version' compadd $versions
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_flow_feature_list ()
|
|
||||||
{
|
|
||||||
local expl
|
|
||||||
declare -a features
|
|
||||||
|
|
||||||
features=(${${(f)"$(_call_program features git flow feature list 2> /dev/null | tr -d ' |*')"}})
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
_wanted features expl 'feature' compadd $features
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_remotes () {
|
|
||||||
local expl gitdir remotes
|
|
||||||
|
|
||||||
gitdir=$(_call_program gitdir git rev-parse --git-dir 2>/dev/null)
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
remotes=(${${(f)"$(_call_program remotes git config --get-regexp '"^remote\..*\.url$"')"}//#(#b)remote.(*).url */$match[1]})
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
# TODO: Should combine the two instead of either or.
|
|
||||||
if (( $#remotes > 0 )); then
|
|
||||||
_wanted remotes expl remote compadd $* - $remotes
|
|
||||||
else
|
|
||||||
_wanted remotes expl remote _files $* - -W "($gitdir/remotes)" -g "$gitdir/remotes/*"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_flow_hotfix_list ()
|
|
||||||
{
|
|
||||||
local expl
|
|
||||||
declare -a hotfixes
|
|
||||||
|
|
||||||
hotfixes=(${${(f)"$(_call_program hotfixes git flow hotfix list 2> /dev/null | tr -d ' |*')"}})
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
_wanted hotfixes expl 'hotfix' compadd $hotfixes
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_branch_names () {
|
|
||||||
local expl
|
|
||||||
declare -a branch_names
|
|
||||||
|
|
||||||
branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads 2>/dev/null)"}#refs/heads/})
|
|
||||||
__git_command_successful || return
|
|
||||||
|
|
||||||
_wanted branch-names expl branch-name compadd $* - $branch_names
|
|
||||||
}
|
|
||||||
|
|
||||||
__git_command_successful () {
|
|
||||||
if (( ${#pipestatus:#0} > 0 )); then
|
|
||||||
_message 'not a git repository'
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
zstyle ':completion:*:*:git:*' user-commands flow:'description for foo'
|
|
||||||
|
|
@ -1,80 +0,0 @@
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
# FILE: gnu-utils.plugin.zsh
|
|
||||||
# DESCRIPTION: oh-my-zsh plugin file.
|
|
||||||
# AUTHOR: Sorin Ionescu (sorin.ionescu@gmail.com)
|
|
||||||
# VERSION: 1.0.0
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
if [[ -x "${commands[gwhoami]}" ]]; then
|
|
||||||
__gnu_utils() {
|
|
||||||
emulate -L zsh
|
|
||||||
local gcmds
|
|
||||||
local gcmd
|
|
||||||
local cmd
|
|
||||||
local prefix
|
|
||||||
|
|
||||||
# coreutils
|
|
||||||
gcmds=('g[' 'gbase64' 'gbasename' 'gcat' 'gchcon' 'gchgrp' 'gchmod'
|
|
||||||
'gchown' 'gchroot' 'gcksum' 'gcomm' 'gcp' 'gcsplit' 'gcut' 'gdate'
|
|
||||||
'gdd' 'gdf' 'gdir' 'gdircolors' 'gdirname' 'gdu' 'gecho' 'genv' 'gexpand'
|
|
||||||
'gexpr' 'gfactor' 'gfalse' 'gfmt' 'gfold' 'ggroups' 'ghead' 'ghostid'
|
|
||||||
'gid' 'ginstall' 'gjoin' 'gkill' 'glink' 'gln' 'glogname' 'gls' 'gmd5sum'
|
|
||||||
'gmkdir' 'gmkfifo' 'gmknod' 'gmktemp' 'gmv' 'gnice' 'gnl' 'gnohup' 'gnproc'
|
|
||||||
'god' 'gpaste' 'gpathchk' 'gpinky' 'gpr' 'gprintenv' 'gprintf' 'gptx' 'gpwd'
|
|
||||||
'greadlink' 'grm' 'grmdir' 'gruncon' 'gseq' 'gsha1sum' 'gsha224sum'
|
|
||||||
'gsha256sum' 'gsha384sum' 'gsha512sum' 'gshred' 'gshuf' 'gsleep' 'gsort'
|
|
||||||
'gsplit' 'gstat' 'gstty' 'gsum' 'gsync' 'gtac' 'gtail' 'gtee' 'gtest'
|
|
||||||
'gtimeout' 'gtouch' 'gtr' 'gtrue' 'gtruncate' 'gtsort' 'gtty' 'guname'
|
|
||||||
'gunexpand' 'guniq' 'gunlink' 'guptime' 'gusers' 'gvdir' 'gwc' 'gwho'
|
|
||||||
'gwhoami' 'gyes')
|
|
||||||
|
|
||||||
# Not part of coreutils, installed separately.
|
|
||||||
gcmds+=('gsed' 'gtar' 'gtime')
|
|
||||||
|
|
||||||
for gcmd in "${gcmds[@]}"; do
|
|
||||||
#
|
|
||||||
# This method allows for builtin commands to be primary but it's
|
|
||||||
# lost if hash -r or rehash -f is executed. Thus, those two
|
|
||||||
# functions have to be wrapped.
|
|
||||||
#
|
|
||||||
(( ${+commands[$gcmd]} )) && hash ${gcmd[2,-1]}=${commands[$gcmd]}
|
|
||||||
|
|
||||||
#
|
|
||||||
# This method generates wrapper functions.
|
|
||||||
# It will override shell builtins.
|
|
||||||
#
|
|
||||||
# (( ${+commands[$gcmd]} )) && \
|
|
||||||
# eval "function $gcmd[2,-1]() { \"${prefix}/${gcmd//"["/"\\["}\" \"\$@\"; }"
|
|
||||||
|
|
||||||
#
|
|
||||||
# This method is inflexible since the aliases are at risk of being
|
|
||||||
# overriden resulting in the BSD coreutils being called.
|
|
||||||
#
|
|
||||||
# (( ${+commands[$gcmd]} )) && \
|
|
||||||
# alias "$gcmd[2,-1]"="${prefix}/${gcmd//"["/"\\["}"
|
|
||||||
done
|
|
||||||
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
__gnu_utils;
|
|
||||||
|
|
||||||
function hash() {
|
|
||||||
if [[ "$*" =~ "-(r|f)" ]]; then
|
|
||||||
builtin hash "$@"
|
|
||||||
__gnu_utils
|
|
||||||
else
|
|
||||||
builtin hash "$@"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function rehash() {
|
|
||||||
if [[ "$*" =~ "-f" ]]; then
|
|
||||||
builtin rehash "$@"
|
|
||||||
__gnu_utils
|
|
||||||
else
|
|
||||||
builtin rehash "$@"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
@ -1,26 +0,0 @@
|
||||||
# Based on ssh-agent code
|
|
||||||
|
|
||||||
local GPG_ENV=$HOME/.gnupg/gpg-agent.env
|
|
||||||
|
|
||||||
function start_agent {
|
|
||||||
/usr/bin/env gpg-agent --daemon --enable-ssh-support --write-env-file ${GPG_ENV} > /dev/null
|
|
||||||
chmod 600 ${GPG_ENV}
|
|
||||||
. ${GPG_ENV} > /dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
# Source GPG agent settings, if applicable
|
|
||||||
if [ -f "${GPG_ENV}" ]; then
|
|
||||||
. ${GPG_ENV} > /dev/null
|
|
||||||
ps -ef | grep ${SSH_AGENT_PID} | grep gpg-agent > /dev/null || {
|
|
||||||
start_agent;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
start_agent;
|
|
||||||
fi
|
|
||||||
|
|
||||||
export GPG_AGENT_INFO
|
|
||||||
export SSH_AUTH_SOCK
|
|
||||||
export SSH_AGENT_PID
|
|
||||||
|
|
||||||
GPG_TTY=$(tty)
|
|
||||||
export GPG_TTY
|
|
||||||
|
|
@ -1,119 +0,0 @@
|
||||||
#!zsh
|
|
||||||
##############################################################################
|
|
||||||
# A descriptive listing of core Gradle commands
|
|
||||||
############################################################################
|
|
||||||
function _gradle_core_commands() {
|
|
||||||
local ret=1 state
|
|
||||||
_arguments ':subcommand:->subcommand' && ret=0
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
subcommand)
|
|
||||||
subcommands=(
|
|
||||||
"properties:Display all project properties"
|
|
||||||
"tasks:Calculate and display all tasks"
|
|
||||||
"dependencies:Calculate and display all dependencies"
|
|
||||||
"projects:Discover and display all sub-projects"
|
|
||||||
"build:Build the project"
|
|
||||||
"help:Display help"
|
|
||||||
)
|
|
||||||
_describe -t subcommands 'gradle subcommands' subcommands && ret=0
|
|
||||||
esac
|
|
||||||
|
|
||||||
return ret
|
|
||||||
}
|
|
||||||
|
|
||||||
function _gradle_arguments() {
|
|
||||||
_arguments -C \
|
|
||||||
'-a[Do not rebuild project dependencies]' \
|
|
||||||
'-h[Help]' \
|
|
||||||
'-D[System property]' \
|
|
||||||
'-d[Log at the debug level]' \
|
|
||||||
'--gui[Launches the Gradle GUI app]' \
|
|
||||||
'--stop[Stop the Gradle daemon]' \
|
|
||||||
'--daemon[Use the Gradle daemon]' \
|
|
||||||
'--no-daemon[Do not use the Gradle daemon]' \
|
|
||||||
'--no-opt[Do not perform any task optimization]' \
|
|
||||||
'-i[Log at the info level]' \
|
|
||||||
'-m[Dry run]' \
|
|
||||||
'-P[Set a project property]' \
|
|
||||||
'--profile[Profile the build time]' \
|
|
||||||
'-q[Log at the quiet level (only show errors)]' \
|
|
||||||
'-v[Print the Gradle version info]' \
|
|
||||||
'-x[Specify a task to be excluded]' \
|
|
||||||
'*::command:->command' \
|
|
||||||
&& return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
# Are we in a directory containing a build.gradle file?
|
|
||||||
############################################################################
|
|
||||||
function in_gradle() {
|
|
||||||
if [[ -f build.gradle ]]; then
|
|
||||||
echo 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
############################################################################
|
|
||||||
# Define the stat_cmd command based on platform behavior
|
|
||||||
##########################################################################
|
|
||||||
stat -f%m . > /dev/null 2>&1
|
|
||||||
if [ "$?" = 0 ]; then
|
|
||||||
stat_cmd=(stat -f%m)
|
|
||||||
else
|
|
||||||
stat_cmd=(stat -L --format=%Y)
|
|
||||||
fi
|
|
||||||
|
|
||||||
############################################################################## Examine the build.gradle file to see if its
|
|
||||||
# timestamp has changed, and if so, regen
|
|
||||||
# the .gradle_tasks cache file
|
|
||||||
############################################################################
|
|
||||||
_gradle_does_task_list_need_generating () {
|
|
||||||
if [ ! -f .gradletasknamecache ]; then return 0;
|
|
||||||
else
|
|
||||||
accurate=$($stat_cmd .gradletasknamecache)
|
|
||||||
changed=$($stat_cmd build.gradle)
|
|
||||||
return $(expr $accurate '>=' $changed)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
# Discover the gradle tasks by running "gradle tasks --all"
|
|
||||||
############################################################################
|
|
||||||
_gradle_tasks () {
|
|
||||||
if [ in_gradle ]; then
|
|
||||||
_gradle_arguments
|
|
||||||
if _gradle_does_task_list_need_generating; then
|
|
||||||
gradle tasks --all | grep "^[ ]*[a-zA-Z0-9]*\ -\ " | sed "s/ - .*$//" | sed "s/[\ ]*//" > .gradletasknamecache
|
|
||||||
fi
|
|
||||||
compadd -X "==== Gradle Tasks ====" `cat .gradletasknamecache`
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_gradlew_tasks () {
|
|
||||||
if [ in_gradle ]; then
|
|
||||||
_gradle_arguments
|
|
||||||
if _gradle_does_task_list_need_generating; then
|
|
||||||
gradlew tasks --all | grep "^[ ]*[a-zA-Z0-9]*\ -\ " | sed "s/ - .*$//" | sed "s/[\ ]*//" > .gradletasknamecache
|
|
||||||
fi
|
|
||||||
compadd -X "==== Gradlew Tasks ====" `cat .gradletasknamecache`
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
# Register the completions against the gradle and gradlew commands
|
|
||||||
############################################################################
|
|
||||||
compdef _gradle_tasks gradle
|
|
||||||
compdef _gradlew_tasks gradlew
|
|
||||||
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
# Open questions for future improvements:
|
|
||||||
# 1) Should 'gradle tasks' use --all or just the regular set?
|
|
||||||
# 2) Should gradlew use the same approach as gradle?
|
|
||||||
# 3) Should only the " - " be replaced with a colon so it can work
|
|
||||||
# with the richer descriptive method of _arguments?
|
|
||||||
# gradle tasks | grep "^[a-zA-Z0-9]*\ -\ " | sed "s/ - /\:/"
|
|
||||||
#############################################################################
|
|
||||||
|
|
@ -1,54 +0,0 @@
|
||||||
_enumerateGrailsScripts() {
|
|
||||||
# Default directoryies
|
|
||||||
directories=($GRAILS_HOME/scripts ~/.grails/scripts ./scripts)
|
|
||||||
|
|
||||||
# Check all of the plugins directories, if they exist
|
|
||||||
if [ -d plugins ]
|
|
||||||
then
|
|
||||||
directories+=(plugins/*/scripts)
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Enumerate all of the Groovy files
|
|
||||||
files=()
|
|
||||||
for dir in $directories;
|
|
||||||
do
|
|
||||||
if [ -d $dir ]
|
|
||||||
then
|
|
||||||
files+=($dir/[^_]*.groovy)
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Don't try to basename ()
|
|
||||||
if [ ${#files} -eq 0 ];
|
|
||||||
then
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
# - Strip the path
|
|
||||||
# - Remove all scripts with a leading '_'
|
|
||||||
# - PackagePlugin_.groovy -> PackagePlugin
|
|
||||||
# - PackagePlugin -> Package-Plugin
|
|
||||||
# - Package-Plugin -> package-plugin
|
|
||||||
basename $files \
|
|
||||||
| sed -E -e 's/^_?([^_]+)_?.groovy/\1/'\
|
|
||||||
-e 's/([a-z])([A-Z])/\1-\2/g' \
|
|
||||||
| tr "[:upper:]" "[:lower:]" \
|
|
||||||
| sort \
|
|
||||||
| uniq
|
|
||||||
}
|
|
||||||
|
|
||||||
_grails() {
|
|
||||||
if (( CURRENT == 2 )); then
|
|
||||||
scripts=( $(_enumerateGrailsScripts) )
|
|
||||||
|
|
||||||
if [ ${#scripts} -ne 0 ];
|
|
||||||
then
|
|
||||||
_multi_parts / scripts
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
_files
|
|
||||||
}
|
|
||||||
|
|
||||||
compdef _grails grails
|
|
||||||
|
|
@ -1,158 +0,0 @@
|
||||||
#compdef heroku
|
|
||||||
|
|
||||||
# Heroku Autocomplete plugin for Oh-My-Zsh
|
|
||||||
# Requires: The Heroku client gem (https://github.com/heroku/heroku)
|
|
||||||
# Author: Ali B. (http://awhitebox.com)
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
"account\:confirm_billing":"Confirm that your account can be billed at the end of the month"
|
|
||||||
"addons":"list installed addons"
|
|
||||||
"addons\:list":"list all available addons"
|
|
||||||
"addons\:add":"install an addon"
|
|
||||||
"addons\:upgrade":"upgrade an existing addon"
|
|
||||||
"addons\:downgrade":"downgrade an existing addon"
|
|
||||||
"addons\:remove":"uninstall an addon"
|
|
||||||
"addons\:open":"open an addon's dashboard in your browser"
|
|
||||||
"apps":"list your apps"
|
|
||||||
"apps\:info":"show detailed app information"
|
|
||||||
"apps\:create":"create a new app"
|
|
||||||
"apps\:rename":"rename the app"
|
|
||||||
"apps\:open":"open the app in a web browser"
|
|
||||||
"apps\:destroy":"permanently destroy an app"
|
|
||||||
"auth\:login":"log in with your heroku credentials"
|
|
||||||
"auth\:logout":"clear local authentication credentials"
|
|
||||||
"config":"display the config vars for an app"
|
|
||||||
"config\:add":"add one or more config vars"
|
|
||||||
"config\:remove":"remove a config var"
|
|
||||||
"db\:push":"push local data up to your app"
|
|
||||||
"db\:pull":"pull heroku data down into your local database"
|
|
||||||
"domains":"list custom domains for an app"
|
|
||||||
"domains\:add":"add a custom domain to an app"
|
|
||||||
"domains\:remove":"remove a custom domain from an app"
|
|
||||||
"domains\:clear":"remove all custom domains from an app"
|
|
||||||
"help":"list available commands or display help for a specific command"
|
|
||||||
"keys":"display keys for the current user"
|
|
||||||
"keys\:add":"add a key for the current user"
|
|
||||||
"keys\:remove":"remove a key from the current user"
|
|
||||||
"keys\:clear":"remove all authentication keys from the current user"
|
|
||||||
"logs":"display recent log output"
|
|
||||||
"logs\:cron":"DEPRECATED: display cron logs from legacy logging"
|
|
||||||
"logs\:drains":"manage syslog drains"
|
|
||||||
"maintenance\:on":"put the app into maintenance mode"
|
|
||||||
"maintenance\:off":"take the app out of maintenance mode"
|
|
||||||
"pg\:info":"display database information"
|
|
||||||
"pg\:ingress":"allow direct connections to the database from this IP for one minute"
|
|
||||||
"pg\:promote":"sets DATABASE as your DATABASE_URL"
|
|
||||||
"pg\:psql":"open a psql shell to the database"
|
|
||||||
"pg\:reset":"delete all data in DATABASE"
|
|
||||||
"pg\:unfollow":"stop a replica from following and make it a read/write database"
|
|
||||||
"pg\:wait":"monitor database creation, exit when complete"
|
|
||||||
"pgbackups":"list captured backups"
|
|
||||||
"pgbackups\:url":"get a temporary URL for a backup"
|
|
||||||
"pgbackups\:capture":"capture a backup from a database id"
|
|
||||||
"pgbackups\:restore":"restore a backup to a database"
|
|
||||||
"pgbackups\:destroy":"destroys a backup"
|
|
||||||
"plugins":"list installed plugins"
|
|
||||||
"plugins\:install":"install a plugin"
|
|
||||||
"plugins\:uninstall":"uninstall a plugin"
|
|
||||||
"ps\:dynos":"scale to QTY web processes"
|
|
||||||
"ps\:workers":"scale to QTY background processes"
|
|
||||||
"ps":"list processes for an app"
|
|
||||||
"ps\:restart":"restart an app process"
|
|
||||||
"ps\:scale":"scale processes by the given amount"
|
|
||||||
"releases":"list releases"
|
|
||||||
"releases\:info":"view detailed information for a release"
|
|
||||||
"rollback":"roll back to an older release"
|
|
||||||
"run":"run an attached process"
|
|
||||||
"run\:rake":"remotely execute a rake command"
|
|
||||||
"run\:console":"open a remote console session"
|
|
||||||
"sharing":"list collaborators on an app"
|
|
||||||
"sharing\:add":"add a collaborator to an app"
|
|
||||||
"sharing\:remove":"remove a collaborator from an app"
|
|
||||||
"sharing\:transfer":"transfer an app to a new owner"
|
|
||||||
"ssl":"list certificates for an app"
|
|
||||||
"ssl\:add":"add an ssl certificate to an app"
|
|
||||||
"ssl\:remove":"remove an ssl certificate from an app"
|
|
||||||
"ssl\:clear":"remove all ssl certificates from an app"
|
|
||||||
"stack":"show the list of available stacks"
|
|
||||||
"stack\:migrate":"prepare migration of this app to a new stack"
|
|
||||||
"version":"show heroku client version"
|
|
||||||
)
|
|
||||||
|
|
||||||
_arguments '*:: :->command'
|
|
||||||
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
_describe -t commands "heroku command" _1st_arguments
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
local -a _command_args
|
|
||||||
case "$words[1]" in
|
|
||||||
apps:info)
|
|
||||||
_command_args=(
|
|
||||||
'(-r|--raw)'{-r,--raw}'[output info as raw key/value pairs]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
apps:create)
|
|
||||||
_command_args=(
|
|
||||||
'(-a|--addons)'{-a,--addons}'[a list of addons to install]' \
|
|
||||||
'(-r|--remote)'{-r,--remote}'[the git remote to create, default "heroku"]' \
|
|
||||||
'(-s|--stack)'{-s,--stack}'[the stack on which to create the app]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
config)
|
|
||||||
_command_args=(
|
|
||||||
'(-s|--shell)'{-s,--shell}'[output config vars in shell format]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
db:push)
|
|
||||||
_command_args=(
|
|
||||||
'(-c|--chunksize)'{-c,--chunksize}'[specify the number of rows to send in each batch]' \
|
|
||||||
'(-d|--debug)'{-d,--debug}'[enable debugging output]' \
|
|
||||||
'(-e|--exclude)'{-e,--exclude}'[exclude the specified tables from the push]' \
|
|
||||||
'(-f|--filter)'{-f,--filter}'[only push certain tables]' \
|
|
||||||
'(-r|--resume)'{-r,--resume}'[resume transfer described by a .dat file]' \
|
|
||||||
'(-t|--tables)'{-t,--tables}'[only push the specified tables]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
db:pull)
|
|
||||||
_command_args=(
|
|
||||||
'(-c|--chunksize)'{-c,--chunksize}'[specify the number of rows to send in each batch]' \
|
|
||||||
'(-d|--debug)'{-d,--debug}'[enable debugging output]' \
|
|
||||||
'(-e|--exclude)'{-e,--exclude}'[exclude the specified tables from the pull]' \
|
|
||||||
'(-f|--filter)'{-f,--filter}'[only pull certain tables]' \
|
|
||||||
'(-r|--resume)'{-r,--resume}'[resume transfer described by a .dat file]' \
|
|
||||||
'(-t|--tables)'{-t,--tables}'[only pull the specified tables]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
keys)
|
|
||||||
_command_args=(
|
|
||||||
'(-l|--long)'{-l,--long}'[display extended information for each key]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
logs)
|
|
||||||
_command_args=(
|
|
||||||
'(-n|--num)'{-n,--num}'[the number of lines to display]' \
|
|
||||||
'(-p|--ps)'{-p,--ps}'[only display logs from the given process]' \
|
|
||||||
'(-s|--source)'{-s,--source}'[only display logs from the given source]' \
|
|
||||||
'(-t|--tail)'{-t,--tail}'[continually stream logs]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
pgbackups:capture)
|
|
||||||
_command_args=(
|
|
||||||
'(-e|--expire)'{-e,--expire}'[if no slots are available to capture, delete the oldest backup to make room]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
stack)
|
|
||||||
_command_args=(
|
|
||||||
'(-a|--all)'{-a,--all}'[include deprecated stacks]' \
|
|
||||||
)
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
$_command_args \
|
|
||||||
'(--app)--app[the app name]' \
|
|
||||||
&& return 0
|
|
||||||
|
|
||||||
|
|
@ -1,7 +0,0 @@
|
||||||
To activate this script, load it into an interactive ZSH session:
|
|
||||||
|
|
||||||
% source history-substring-search.zsh
|
|
||||||
|
|
||||||
See the "history-substring-search.zsh" file for more information:
|
|
||||||
|
|
||||||
% sed -n '2,/^$/s/^#//p' history-substring-search.zsh | more
|
|
||||||
|
|
@ -1,12 +0,0 @@
|
||||||
# This file integrates the history-substring-search script into oh-my-zsh.
|
|
||||||
|
|
||||||
source "$ZSH/plugins/history-substring-search/history-substring-search.zsh"
|
|
||||||
|
|
||||||
if test "$CASE_SENSITIVE" = true; then
|
|
||||||
unset HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$DISABLE_COLOR" = true; then
|
|
||||||
unset HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
unset HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
|
||||||
fi
|
|
||||||
|
|
@ -1,642 +0,0 @@
|
||||||
#!/usr/bin/env zsh
|
|
||||||
#
|
|
||||||
# This is a clean-room implementation of the Fish[1] shell's history search
|
|
||||||
# feature, where you can type in any part of any previously entered command
|
|
||||||
# and press the UP and DOWN arrow keys to cycle through the matching commands.
|
|
||||||
#
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# Usage
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# 1. Load this script into your interactive ZSH session:
|
|
||||||
#
|
|
||||||
# % source history-substring-search.zsh
|
|
||||||
#
|
|
||||||
# If you want to use the zsh-syntax-highlighting[6] script along with this
|
|
||||||
# script, then make sure that you load it *before* you load this script:
|
|
||||||
#
|
|
||||||
# % source zsh-syntax-highlighting.zsh
|
|
||||||
# % source history-substring-search.zsh
|
|
||||||
#
|
|
||||||
# 2. Type any part of any previous command and then:
|
|
||||||
#
|
|
||||||
# * Press the UP arrow key to select the nearest command that (1) contains
|
|
||||||
# your query and (2) is older than the current command in the command
|
|
||||||
# history.
|
|
||||||
#
|
|
||||||
# * Press the DOWN arrow key to select the nearest command that (1)
|
|
||||||
# contains your query and (2) is newer than the current command in the
|
|
||||||
# command history.
|
|
||||||
#
|
|
||||||
# * Press ^U (the Control and U keys simultaneously) to abort the search.
|
|
||||||
#
|
|
||||||
# 3. If a matching command spans more than one line of text, press the LEFT
|
|
||||||
# arrow key to move the cursor away from the end of the command, and then:
|
|
||||||
#
|
|
||||||
# * Press the UP arrow key to move the cursor to the line above. When the
|
|
||||||
# cursor reaches the first line of the command, pressing the UP arrow
|
|
||||||
# key again will cause this script to perform another search.
|
|
||||||
#
|
|
||||||
# * Press the DOWN arrow key to move the cursor to the line below. When
|
|
||||||
# the cursor reaches the last line of the command, pressing the DOWN
|
|
||||||
# arrow key again will cause this script to perform another search.
|
|
||||||
#
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# Configuration
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# This script defines the following global variables. You may override their
|
|
||||||
# default values only after having loaded this script into your ZSH session.
|
|
||||||
#
|
|
||||||
# * HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND is a global variable that defines
|
|
||||||
# how the query should be highlighted inside a matching command. Its default
|
|
||||||
# value causes this script to highlight using bold, white text on a magenta
|
|
||||||
# background. See the "Character Highlighting" section in the zshzle(1) man
|
|
||||||
# page to learn about the kinds of values you may assign to this variable.
|
|
||||||
#
|
|
||||||
# * HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND is a global variable that
|
|
||||||
# defines how the query should be highlighted when no commands in the
|
|
||||||
# history match it. Its default value causes this script to highlight using
|
|
||||||
# bold, white text on a red background. See the "Character Highlighting"
|
|
||||||
# section in the zshzle(1) man page to learn about the kinds of values you
|
|
||||||
# may assign to this variable.
|
|
||||||
#
|
|
||||||
# * HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS is a global variable that defines
|
|
||||||
# how the command history will be searched for your query. Its default value
|
|
||||||
# causes this script to perform a case-insensitive search. See the "Globbing
|
|
||||||
# Flags" section in the zshexpn(1) man page to learn about the kinds of
|
|
||||||
# values you may assign to this variable.
|
|
||||||
#
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# History
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# This script was originally written by Peter Stephenson[2], who published it
|
|
||||||
# to the ZSH users mailing list (thereby making it public domain) in September
|
|
||||||
# 2009. It was later revised by Guido van Steen and released under the BSD
|
|
||||||
# license (see below) as part of the fizsh[3] project in January 2011.
|
|
||||||
#
|
|
||||||
# It was later extracted from fizsh[3] release 1.0.1, refactored heavily, and
|
|
||||||
# repackaged as both an oh-my-zsh plugin[4] and as an independently loadable
|
|
||||||
# ZSH script[5] by Suraj N. Kurapati in 2011.
|
|
||||||
#
|
|
||||||
# It was further developed[4] by Guido van Steen, Suraj N. Kurapati, Sorin
|
|
||||||
# Ionescu, and Vincent Guerci in 2011.
|
|
||||||
#
|
|
||||||
# [1]: http://fishshell.com
|
|
||||||
# [2]: http://www.zsh.org/mla/users/2009/msg00818.html
|
|
||||||
# [3]: http://sourceforge.net/projects/fizsh/
|
|
||||||
# [4]: https://github.com/robbyrussell/oh-my-zsh/pull/215
|
|
||||||
# [5]: https://github.com/sunaku/zsh-history-substring-search
|
|
||||||
# [6]: https://github.com/nicoulaj/zsh-syntax-highlighting
|
|
||||||
#
|
|
||||||
##############################################################################
|
|
||||||
#
|
|
||||||
# Copyright (c) 2009 Peter Stephenson
|
|
||||||
# Copyright (c) 2011 Guido van Steen
|
|
||||||
# Copyright (c) 2011 Suraj N. Kurapati
|
|
||||||
# Copyright (c) 2011 Sorin Ionescu
|
|
||||||
# Copyright (c) 2011 Vincent Guerci
|
|
||||||
# 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 FIZSH 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 THE COPYRIGHT HOLDER OR CONTRIBUTORS 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.
|
|
||||||
#
|
|
||||||
##############################################################################
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# configuration variables
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND='bg=magenta,fg=white,bold'
|
|
||||||
HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND='bg=red,fg=white,bold'
|
|
||||||
HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS='i'
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# the main ZLE widgets
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
function history-substring-search-up() {
|
|
||||||
_history-substring-search-begin
|
|
||||||
|
|
||||||
_history-substring-search-up-history ||
|
|
||||||
_history-substring-search-up-buffer ||
|
|
||||||
_history-substring-search-up-search
|
|
||||||
|
|
||||||
_history-substring-search-end
|
|
||||||
}
|
|
||||||
|
|
||||||
function history-substring-search-down() {
|
|
||||||
_history-substring-search-begin
|
|
||||||
|
|
||||||
_history-substring-search-down-history ||
|
|
||||||
_history-substring-search-down-buffer ||
|
|
||||||
_history-substring-search-down-search
|
|
||||||
|
|
||||||
_history-substring-search-end
|
|
||||||
}
|
|
||||||
|
|
||||||
zle -N history-substring-search-up
|
|
||||||
zle -N history-substring-search-down
|
|
||||||
|
|
||||||
bindkey '\e[A' history-substring-search-up
|
|
||||||
bindkey '\e[B' history-substring-search-down
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
# implementation details
|
|
||||||
#-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
setopt extendedglob
|
|
||||||
zmodload -F zsh/parameter
|
|
||||||
|
|
||||||
#
|
|
||||||
# We have to "override" some keys and widgets if the
|
|
||||||
# zsh-syntax-highlighting plugin has not been loaded:
|
|
||||||
#
|
|
||||||
# https://github.com/nicoulaj/zsh-syntax-highlighting
|
|
||||||
#
|
|
||||||
if [[ $+functions[_zsh_highlight] -eq 0 ]]; then
|
|
||||||
#
|
|
||||||
# Dummy implementation of _zsh_highlight()
|
|
||||||
# that simply removes existing highlights
|
|
||||||
#
|
|
||||||
function _zsh_highlight() {
|
|
||||||
region_highlight=()
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
|
||||||
# Remove existing highlights when the user
|
|
||||||
# inserts printable characters into $BUFFER
|
|
||||||
#
|
|
||||||
function ordinary-key-press() {
|
|
||||||
if [[ $KEYS == [[:print:]] ]]; then
|
|
||||||
region_highlight=()
|
|
||||||
fi
|
|
||||||
zle .self-insert
|
|
||||||
}
|
|
||||||
zle -N self-insert ordinary-key-press
|
|
||||||
|
|
||||||
#
|
|
||||||
# Override ZLE widgets to invoke _zsh_highlight()
|
|
||||||
#
|
|
||||||
# https://github.com/nicoulaj/zsh-syntax-highlighting/blob/
|
|
||||||
# bb7fcb79fad797a40077bebaf6f4e4a93c9d8163/zsh-syntax-highlighting.zsh#L121
|
|
||||||
#
|
|
||||||
#--------------8<-------------------8<-------------------8<-----------------
|
|
||||||
#
|
|
||||||
# Copyright (c) 2010-2011 zsh-syntax-highlighting contributors
|
|
||||||
# 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-syntax-highlighting contributors 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 THE COPYRIGHT HOLDER OR
|
|
||||||
# CONTRIBUTORS 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.
|
|
||||||
|
|
||||||
# Load ZSH module zsh/zleparameter, needed to override user defined widgets.
|
|
||||||
zmodload zsh/zleparameter 2>/dev/null || {
|
|
||||||
echo 'zsh-syntax-highlighting: failed loading zsh/zleparameter, exiting.' >&2
|
|
||||||
return -1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Override ZLE widgets to make them invoke _zsh_highlight.
|
|
||||||
for event in ${${(f)"$(zle -la)"}:#(_*|orig-*|.run-help|.which-command)}; do
|
|
||||||
if [[ "$widgets[$event]" == completion:* ]]; then
|
|
||||||
eval "zle -C orig-$event ${${${widgets[$event]}#*:}/:/ } ; $event() { builtin zle orig-$event && _zsh_highlight } ; zle -N $event"
|
|
||||||
else
|
|
||||||
case $event in
|
|
||||||
accept-and-menu-complete)
|
|
||||||
eval "$event() { builtin zle .$event && _zsh_highlight } ; zle -N $event"
|
|
||||||
;;
|
|
||||||
|
|
||||||
# The following widgets should NOT remove any previously
|
|
||||||
# applied highlighting. Therefore we do not remap them.
|
|
||||||
.forward-char|.backward-char|.up-line-or-history|.down-line-or-history)
|
|
||||||
;;
|
|
||||||
|
|
||||||
.*)
|
|
||||||
clean_event=$event[2,${#event}] # Remove the leading dot in the event name
|
|
||||||
case ${widgets[$clean_event]-} in
|
|
||||||
(completion|user):*)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
eval "$clean_event() { builtin zle $event && _zsh_highlight } ; zle -N $clean_event"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
unset event clean_event
|
|
||||||
#-------------->8------------------->8------------------->8-----------------
|
|
||||||
fi
|
|
||||||
|
|
||||||
function _history-substring-search-begin() {
|
|
||||||
_history_substring_search_move_cursor_eol=false
|
|
||||||
_history_substring_search_query_highlight=
|
|
||||||
|
|
||||||
#
|
|
||||||
# Continue using the previous $_history_substring_search_result by default,
|
|
||||||
# unless the current query was cleared or a new/different query was entered.
|
|
||||||
#
|
|
||||||
if [[ -z $BUFFER || $BUFFER != $_history_substring_search_result ]]; then
|
|
||||||
#
|
|
||||||
# For the purpose of highlighting we will also keep
|
|
||||||
# a version without doubly-escaped meta characters.
|
|
||||||
#
|
|
||||||
_history_substring_search_query=$BUFFER
|
|
||||||
|
|
||||||
#
|
|
||||||
# $BUFFER contains the text that is in the command-line currently.
|
|
||||||
# we put an extra "\\" before meta characters such as "\(" and "\)",
|
|
||||||
# so that they become "\\\(" and "\\\)".
|
|
||||||
#
|
|
||||||
_history_substring_search_query_escaped=${BUFFER//(#m)[\][()|\\*?#<>~^]/\\$MATCH}
|
|
||||||
|
|
||||||
#
|
|
||||||
# Find all occurrences of the search query in the history file.
|
|
||||||
#
|
|
||||||
# (k) turns it an array of line numbers.
|
|
||||||
#
|
|
||||||
# (on) seems to remove duplicates, which are default
|
|
||||||
# options. They can be turned off by (ON).
|
|
||||||
#
|
|
||||||
_history_substring_search_matches=(${(kon)history[(R)(#$HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS)*${_history_substring_search_query_escaped}*]})
|
|
||||||
|
|
||||||
#
|
|
||||||
# Define the range of values that $_history_substring_search_match_index
|
|
||||||
# can take: [0, $_history_substring_search_matches_count_plus].
|
|
||||||
#
|
|
||||||
_history_substring_search_matches_count=$#_history_substring_search_matches
|
|
||||||
_history_substring_search_matches_count_plus=$(( _history_substring_search_matches_count + 1 ))
|
|
||||||
_history_substring_search_matches_count_sans=$(( _history_substring_search_matches_count - 1 ))
|
|
||||||
|
|
||||||
#
|
|
||||||
# If $_history_substring_search_match_index is equal to
|
|
||||||
# $_history_substring_search_matches_count_plus, this indicates that we
|
|
||||||
# are beyond the beginning of $_history_substring_search_matches.
|
|
||||||
#
|
|
||||||
# If $_history_substring_search_match_index is equal to 0, this indicates
|
|
||||||
# that we are beyond the end of $_history_substring_search_matches.
|
|
||||||
#
|
|
||||||
# If we have initially pressed "up" we have to initialize
|
|
||||||
# $_history_substring_search_match_index to
|
|
||||||
# $_history_substring_search_matches_count_plus so that it will be
|
|
||||||
# decreased to $_history_substring_search_matches_count.
|
|
||||||
#
|
|
||||||
# If we have initially pressed "down" we have to initialize
|
|
||||||
# $_history_substring_search_match_index to
|
|
||||||
# $_history_substring_search_matches_count so that it will be increased to
|
|
||||||
# $_history_substring_search_matches_count_plus.
|
|
||||||
#
|
|
||||||
if [[ $WIDGET == history-substring-search-down ]]; then
|
|
||||||
_history_substring_search_match_index=$_history_substring_search_matches_count
|
|
||||||
else
|
|
||||||
_history_substring_search_match_index=$_history_substring_search_matches_count_plus
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-end() {
|
|
||||||
_history_substring_search_result=$BUFFER
|
|
||||||
|
|
||||||
# move the cursor to the end of the command line
|
|
||||||
if [[ $_history_substring_search_move_cursor_eol == true ]]; then
|
|
||||||
CURSOR=${#BUFFER}
|
|
||||||
fi
|
|
||||||
|
|
||||||
# highlight command line using zsh-syntax-highlighting
|
|
||||||
_zsh_highlight
|
|
||||||
|
|
||||||
# highlight the search query inside the command line
|
|
||||||
if [[ -n $_history_substring_search_query_highlight && -n $_history_substring_search_query ]]; then
|
|
||||||
#
|
|
||||||
# The following expression yields a variable $MBEGIN, which
|
|
||||||
# indicates the begin position + 1 of the first occurrence
|
|
||||||
# of _history_substring_search_query_escaped in $BUFFER.
|
|
||||||
#
|
|
||||||
: ${(S)BUFFER##(#m$HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS)($_history_substring_search_query##)}
|
|
||||||
local begin=$(( MBEGIN - 1 ))
|
|
||||||
local end=$(( begin + $#_history_substring_search_query ))
|
|
||||||
region_highlight+=("$begin $end $_history_substring_search_query_highlight")
|
|
||||||
fi
|
|
||||||
|
|
||||||
# For debugging purposes:
|
|
||||||
# zle -R "mn: "$_history_substring_search_match_index" m#: "${#_history_substring_search_matches}
|
|
||||||
# read -k -t 200 && zle -U $REPLY
|
|
||||||
|
|
||||||
# Exit successfully from the history-substring-search-* widgets.
|
|
||||||
true
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-up-buffer() {
|
|
||||||
#
|
|
||||||
# Check if the UP arrow was pressed to move the cursor within a multi-line
|
|
||||||
# buffer. This amounts to three tests:
|
|
||||||
#
|
|
||||||
# 1. $#buflines -gt 1.
|
|
||||||
#
|
|
||||||
# 2. $CURSOR -ne $#BUFFER.
|
|
||||||
#
|
|
||||||
# 3. Check if we are on the first line of the current multi-line buffer.
|
|
||||||
# If so, pressing UP would amount to leaving the multi-line buffer.
|
|
||||||
#
|
|
||||||
# We check this by adding an extra "x" to $LBUFFER, which makes
|
|
||||||
# sure that xlbuflines is always equal to the number of lines
|
|
||||||
# until $CURSOR (including the line with the cursor on it).
|
|
||||||
#
|
|
||||||
local buflines XLBUFFER xlbuflines
|
|
||||||
buflines=(${(f)BUFFER})
|
|
||||||
XLBUFFER=$LBUFFER"x"
|
|
||||||
xlbuflines=(${(f)XLBUFFER})
|
|
||||||
|
|
||||||
if [[ $#buflines -gt 1 && $CURSOR -ne $#BUFFER && $#xlbuflines -ne 1 ]]; then
|
|
||||||
zle up-line-or-history
|
|
||||||
return true
|
|
||||||
fi
|
|
||||||
|
|
||||||
false
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-down-buffer() {
|
|
||||||
#
|
|
||||||
# Check if the DOWN arrow was pressed to move the cursor within a multi-line
|
|
||||||
# buffer. This amounts to three tests:
|
|
||||||
#
|
|
||||||
# 1. $#buflines -gt 1.
|
|
||||||
#
|
|
||||||
# 2. $CURSOR -ne $#BUFFER.
|
|
||||||
#
|
|
||||||
# 3. Check if we are on the last line of the current multi-line buffer.
|
|
||||||
# If so, pressing DOWN would amount to leaving the multi-line buffer.
|
|
||||||
#
|
|
||||||
# We check this by adding an extra "x" to $RBUFFER, which makes
|
|
||||||
# sure that xrbuflines is always equal to the number of lines
|
|
||||||
# from $CURSOR (including the line with the cursor on it).
|
|
||||||
#
|
|
||||||
local buflines XRBUFFER xrbuflines
|
|
||||||
buflines=(${(f)BUFFER})
|
|
||||||
XRBUFFER="x"$RBUFFER
|
|
||||||
xrbuflines=(${(f)XRBUFFER})
|
|
||||||
|
|
||||||
if [[ $#buflines -gt 1 && $CURSOR -ne $#BUFFER && $#xrbuflines -ne 1 ]]; then
|
|
||||||
zle down-line-or-history
|
|
||||||
return true
|
|
||||||
fi
|
|
||||||
|
|
||||||
false
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-up-history() {
|
|
||||||
#
|
|
||||||
# Behave like up in ZSH, except clear the $BUFFER
|
|
||||||
# when beginning of history is reached like in Fish.
|
|
||||||
#
|
|
||||||
if [[ -z $_history_substring_search_query ]]; then
|
|
||||||
|
|
||||||
# we have reached the absolute top of history
|
|
||||||
if [[ $HISTNO -eq 1 ]]; then
|
|
||||||
BUFFER=
|
|
||||||
|
|
||||||
# going up from somewhere below the top of history
|
|
||||||
else
|
|
||||||
zle up-history
|
|
||||||
fi
|
|
||||||
|
|
||||||
return true
|
|
||||||
fi
|
|
||||||
|
|
||||||
false
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-down-history() {
|
|
||||||
#
|
|
||||||
# Behave like down-history in ZSH, except clear the
|
|
||||||
# $BUFFER when end of history is reached like in Fish.
|
|
||||||
#
|
|
||||||
if [[ -z $_history_substring_search_query ]]; then
|
|
||||||
|
|
||||||
# going down from the absolute top of history
|
|
||||||
if [[ $HISTNO -eq 1 && -z $BUFFER ]]; then
|
|
||||||
BUFFER=${history[1]}
|
|
||||||
_history_substring_search_move_cursor_eol=true
|
|
||||||
|
|
||||||
# going down from somewhere above the bottom of history
|
|
||||||
else
|
|
||||||
zle down-history
|
|
||||||
fi
|
|
||||||
|
|
||||||
return true
|
|
||||||
fi
|
|
||||||
|
|
||||||
false
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-up-search() {
|
|
||||||
_history_substring_search_move_cursor_eol=true
|
|
||||||
|
|
||||||
#
|
|
||||||
# Highlight matches during history-substring-up-search:
|
|
||||||
#
|
|
||||||
# The following constants have been initialized in
|
|
||||||
# _history-substring-search-up/down-search():
|
|
||||||
#
|
|
||||||
# $_history_substring_search_matches is the current list of matches
|
|
||||||
# $_history_substring_search_matches_count is the current number of matches
|
|
||||||
# $_history_substring_search_matches_count_plus is the current number of matches + 1
|
|
||||||
# $_history_substring_search_matches_count_sans is the current number of matches - 1
|
|
||||||
# $_history_substring_search_match_index is the index of the current match
|
|
||||||
#
|
|
||||||
# The range of values that $_history_substring_search_match_index can take
|
|
||||||
# is: [0, $_history_substring_search_matches_count_plus]. A value of 0
|
|
||||||
# indicates that we are beyond the end of
|
|
||||||
# $_history_substring_search_matches. A value of
|
|
||||||
# $_history_substring_search_matches_count_plus indicates that we are beyond
|
|
||||||
# the beginning of $_history_substring_search_matches.
|
|
||||||
#
|
|
||||||
# In _history-substring-search-up-search() the initial value of
|
|
||||||
# $_history_substring_search_match_index is
|
|
||||||
# $_history_substring_search_matches_count_plus. This value is set in
|
|
||||||
# _history-substring-search-begin(). _history-substring-search-up-search()
|
|
||||||
# will initially decrease it to $_history_substring_search_matches_count.
|
|
||||||
#
|
|
||||||
if [[ $_history_substring_search_match_index -ge 2 ]]; then
|
|
||||||
#
|
|
||||||
# Highlight the next match:
|
|
||||||
#
|
|
||||||
# 1. Decrease the value of $_history_substring_search_match_index.
|
|
||||||
#
|
|
||||||
# 2. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index-- ))
|
|
||||||
BUFFER=$history[$_history_substring_search_matches[$_history_substring_search_match_index]]
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
|
|
||||||
elif [[ $_history_substring_search_match_index -eq 1 ]]; then
|
|
||||||
#
|
|
||||||
# We will move beyond the end of $_history_substring_search_matches:
|
|
||||||
#
|
|
||||||
# 1. Decrease the value of $_history_substring_search_match_index.
|
|
||||||
#
|
|
||||||
# 2. Save the current buffer in $_history_substring_search_old_buffer,
|
|
||||||
# so that it can be retrieved by
|
|
||||||
# _history-substring-search-down-search() later.
|
|
||||||
#
|
|
||||||
# 3. Make $BUFFER equal to $_history_substring_search_query.
|
|
||||||
#
|
|
||||||
# 4. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index-- ))
|
|
||||||
_history_substring_search_old_buffer=$BUFFER
|
|
||||||
BUFFER=$_history_substring_search_query
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
|
||||||
|
|
||||||
elif [[ $_history_substring_search_match_index -eq $_history_substring_search_matches_count_plus ]]; then
|
|
||||||
#
|
|
||||||
# We were beyond the beginning of $_history_substring_search_matches but
|
|
||||||
# UP makes us move back to $_history_substring_search_matches:
|
|
||||||
#
|
|
||||||
# 1. Decrease the value of $_history_substring_search_match_index.
|
|
||||||
#
|
|
||||||
# 2. Restore $BUFFER from $_history_substring_search_old_buffer.
|
|
||||||
#
|
|
||||||
# 3. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index-- ))
|
|
||||||
BUFFER=$_history_substring_search_old_buffer
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function _history-substring-search-down-search() {
|
|
||||||
_history_substring_search_move_cursor_eol=true
|
|
||||||
|
|
||||||
#
|
|
||||||
# Highlight matches during history-substring-up-search:
|
|
||||||
#
|
|
||||||
# The following constants have been initialized in
|
|
||||||
# _history-substring-search-up/down-search():
|
|
||||||
#
|
|
||||||
# $_history_substring_search_matches is the current list of matches
|
|
||||||
# $_history_substring_search_matches_count is the current number of matches
|
|
||||||
# $_history_substring_search_matches_count_plus is the current number of matches + 1
|
|
||||||
# $_history_substring_search_matches_count_sans is the current number of matches - 1
|
|
||||||
# $_history_substring_search_match_index is the index of the current match
|
|
||||||
#
|
|
||||||
# The range of values that $_history_substring_search_match_index can take
|
|
||||||
# is: [0, $_history_substring_search_matches_count_plus]. A value of 0
|
|
||||||
# indicates that we are beyond the end of
|
|
||||||
# $_history_substring_search_matches. A value of
|
|
||||||
# $_history_substring_search_matches_count_plus indicates that we are beyond
|
|
||||||
# the beginning of $_history_substring_search_matches.
|
|
||||||
#
|
|
||||||
# In _history-substring-search-down-search() the initial value of
|
|
||||||
# $_history_substring_search_match_index is
|
|
||||||
# $_history_substring_search_matches_count. This value is set in
|
|
||||||
# _history-substring-search-begin().
|
|
||||||
# _history-substring-search-down-search() will initially increase it to
|
|
||||||
# $_history_substring_search_matches_count_plus.
|
|
||||||
#
|
|
||||||
if [[ $_history_substring_search_match_index -le $_history_substring_search_matches_count_sans ]]; then
|
|
||||||
#
|
|
||||||
# Highlight the next match:
|
|
||||||
#
|
|
||||||
# 1. Increase $_history_substring_search_match_index by 1.
|
|
||||||
#
|
|
||||||
# 2. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index++ ))
|
|
||||||
BUFFER=$history[$_history_substring_search_matches[$_history_substring_search_match_index]]
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
|
|
||||||
elif [[ $_history_substring_search_match_index -eq $_history_substring_search_matches_count ]]; then
|
|
||||||
#
|
|
||||||
# We will move beyond the beginning of $_history_substring_search_matches:
|
|
||||||
#
|
|
||||||
# 1. Increase $_history_substring_search_match_index by 1.
|
|
||||||
#
|
|
||||||
# 2. Save the current buffer in $_history_substring_search_old_buffer, so
|
|
||||||
# that it can be retrieved by _history-substring-search-up-search()
|
|
||||||
# later.
|
|
||||||
#
|
|
||||||
# 3. Make $BUFFER equal to $_history_substring_search_query.
|
|
||||||
#
|
|
||||||
# 4. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index++ ))
|
|
||||||
_history_substring_search_old_buffer=$BUFFER
|
|
||||||
BUFFER=$_history_substring_search_query
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND
|
|
||||||
|
|
||||||
elif [[ $_history_substring_search_match_index -eq 0 ]]; then
|
|
||||||
#
|
|
||||||
# We were beyond the end of $_history_substring_search_matches but DOWN
|
|
||||||
# makes us move back to the $_history_substring_search_matches:
|
|
||||||
#
|
|
||||||
# 1. Increase $_history_substring_search_match_index by 1.
|
|
||||||
#
|
|
||||||
# 2. Restore $BUFFER from $_history_substring_search_old_buffer.
|
|
||||||
#
|
|
||||||
# 3. Use $HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
# to highlight the current buffer.
|
|
||||||
#
|
|
||||||
(( _history_substring_search_match_index++ ))
|
|
||||||
BUFFER=$_history_substring_search_old_buffer
|
|
||||||
_history_substring_search_query_highlight=$HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*-
|
|
||||||
# vim: ft=zsh sw=2 ts=2 et
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
|
|
||||||
# Kate
|
|
||||||
# Start kate always silent
|
|
||||||
alias kate='kate >/dev/null 2>&1'
|
|
||||||
|
|
||||||
function kt () {
|
|
||||||
cd $1
|
|
||||||
kate $1
|
|
||||||
}
|
|
||||||
|
|
@ -1,174 +0,0 @@
|
||||||
#compdef knife
|
|
||||||
|
|
||||||
# These flags should be available everywhere according to man knife
|
|
||||||
knife_general_flags=( --help --server-url --key --config --editor --format --log_level --logfile --no-editor --user --print-after --version --yes )
|
|
||||||
|
|
||||||
# knife has a very special syntax, some example calls are:
|
|
||||||
# knife status
|
|
||||||
# knife cookbook list
|
|
||||||
# knife role show ROLENAME
|
|
||||||
# knife data bag show DATABAGNAME
|
|
||||||
# knife role show ROLENAME --attribute ATTRIBUTENAME
|
|
||||||
# knife cookbook show COOKBOOKNAME COOKBOOKVERSION recipes
|
|
||||||
|
|
||||||
# The -Q switch in compadd allow for completions of things like "data bag" without having to go through two rounds of completion and avoids zsh inserting a \ for escaping spaces
|
|
||||||
_knife() {
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
cloudproviders=(bluebox ec2 rackspace slicehost terremark)
|
|
||||||
_arguments \
|
|
||||||
'1: :->knifecmd'\
|
|
||||||
'2: :->knifesubcmd'\
|
|
||||||
'3: :->knifesubcmd2' \
|
|
||||||
'4: :->knifesubcmd3' \
|
|
||||||
'5: :->knifesubcmd4' \
|
|
||||||
'6: :->knifesubcmd5'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
knifecmd)
|
|
||||||
compadd -Q "$@" bootstrap client configure cookbook "cookbook site" "data bag" exec index node recipe role search ssh status windows $cloudproviders
|
|
||||||
;;
|
|
||||||
knifesubcmd)
|
|
||||||
case $words[2] in
|
|
||||||
(bluebox|ec2|rackspace|slicehost|terremark)
|
|
||||||
compadd "$@" server images
|
|
||||||
;;
|
|
||||||
client)
|
|
||||||
compadd -Q "$@" "bulk delete" list create show delete edit reregister
|
|
||||||
;;
|
|
||||||
configure)
|
|
||||||
compadd "$@" client
|
|
||||||
;;
|
|
||||||
cookbook)
|
|
||||||
compadd -Q "$@" test list create download delete "metadata from" show "bulk delete" metadata upload
|
|
||||||
;;
|
|
||||||
node)
|
|
||||||
compadd -Q "$@" "from file" create show edit delete list run_list "bulk delete"
|
|
||||||
;;
|
|
||||||
recipe)
|
|
||||||
compadd "$@" list
|
|
||||||
;;
|
|
||||||
role)
|
|
||||||
compadd -Q "$@" "bulk delete" create delete edit "from file" list show
|
|
||||||
;;
|
|
||||||
windows)
|
|
||||||
compadd "$@" bootstrap
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
_arguments '2:Subsubcommands:($(_knife_options1))'
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
knifesubcmd2)
|
|
||||||
case $words[3] in
|
|
||||||
server)
|
|
||||||
compadd "$@" list create delete
|
|
||||||
;;
|
|
||||||
images)
|
|
||||||
compadd "$@" list
|
|
||||||
;;
|
|
||||||
site)
|
|
||||||
compadd "$@" vendor show share search download list unshare
|
|
||||||
;;
|
|
||||||
(show|delete|edit)
|
|
||||||
_arguments '3:Subsubcommands:($(_chef_$words[2]s_remote))'
|
|
||||||
;;
|
|
||||||
(upload|test)
|
|
||||||
_arguments '3:Subsubcommands:($(_chef_$words[2]s_local) --all)'
|
|
||||||
;;
|
|
||||||
list)
|
|
||||||
compadd -a "$@" knife_general_flags
|
|
||||||
;;
|
|
||||||
bag)
|
|
||||||
compadd -Q "$@" show edit list "from file" create delete
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
_arguments '3:Subsubcommands:($(_knife_options2))'
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
knifesubcmd3)
|
|
||||||
case $words[3] in
|
|
||||||
show)
|
|
||||||
case $words[2] in
|
|
||||||
cookbook)
|
|
||||||
versioncomp=1
|
|
||||||
_arguments '4:Cookbookversions:($(_cookbook_versions) latest)'
|
|
||||||
;;
|
|
||||||
(node|client|role)
|
|
||||||
compadd "$@" --attribute
|
|
||||||
esac
|
|
||||||
esac
|
|
||||||
case $words[4] in
|
|
||||||
(show|edit)
|
|
||||||
_arguments '4:Subsubsubcommands:($(_chef_$words[2]_$words[3]s_remote))'
|
|
||||||
;;
|
|
||||||
file)
|
|
||||||
_arguments '*:file or directory:_files -g "*.(rb|json)"'
|
|
||||||
;;
|
|
||||||
list)
|
|
||||||
compadd -a "$@" knife_general_flags
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
_arguments '*:Subsubcommands:($(_knife_options3))'
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
knifesubcmd4)
|
|
||||||
if (( versioncomp > 0 )); then
|
|
||||||
compadd "$@" attributes definitions files libraries providers recipes resources templates
|
|
||||||
else
|
|
||||||
_arguments '*:Subsubcommands:($(_knife_options2))'
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
knifesubcmd5)
|
|
||||||
_arguments '*:Subsubcommands:($(_knife_options3))'
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# Helper functions to provide the argument completion for several depths of commands
|
|
||||||
_knife_options1() {
|
|
||||||
( for line in $( knife $words[2] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
|
||||||
}
|
|
||||||
|
|
||||||
_knife_options2() {
|
|
||||||
( for line in $( knife $words[2] $words[3] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
|
||||||
}
|
|
||||||
|
|
||||||
_knife_options3() {
|
|
||||||
( for line in $( knife $words[2] $words[3] $words[4] --help | grep -v "^knife" ); do echo $line | grep "\-\-"; done )
|
|
||||||
}
|
|
||||||
|
|
||||||
# The chef_x_remote functions use knife to get a list of objects of type x on the server
|
|
||||||
_chef_roles_remote() {
|
|
||||||
(knife role list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
_chef_clients_remote() {
|
|
||||||
(knife client list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
_chef_nodes_remote() {
|
|
||||||
(knife node list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
_chef_cookbooks_remote() {
|
|
||||||
(knife cookbook list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
_chef_sitecookbooks_remote() {
|
|
||||||
(knife cookbook site list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
_chef_data_bags_remote() {
|
|
||||||
(knife data bag list | grep \" | awk '{print $1}' | awk -F"," '{print $1}' | awk -F"\"" '{print $2}')
|
|
||||||
}
|
|
||||||
|
|
||||||
# The chef_x_local functions use the knife config to find the paths of relevant objects x to be uploaded to the server
|
|
||||||
_chef_cookbooks_local() {
|
|
||||||
(for i in $( grep cookbook_path $HOME/.chef/knife.rb | awk 'BEGIN {FS = "[" }; {print $2}' | sed 's/\,//g' | sed "s/'//g" | sed 's/\(.*\)]/\1/' ); do ls $i; done)
|
|
||||||
}
|
|
||||||
|
|
||||||
# This function extracts the available cookbook versions on the chef server
|
|
||||||
_cookbook_versions() {
|
|
||||||
(knife cookbook show $words[4] | grep -v $words[4] | grep -v -E '\]|\[|\{|\}' | sed 's/ //g' | sed 's/"//g')
|
|
||||||
}
|
|
||||||
|
|
||||||
_knife "$@"
|
|
||||||
|
|
@ -1,27 +0,0 @@
|
||||||
function _lein_commands() {
|
|
||||||
local ret=1 state
|
|
||||||
_arguments ':subcommand:->subcommand' && ret=0
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
subcommand)
|
|
||||||
subcommands=(
|
|
||||||
"clean:remove compiled files and dependencies from project"
|
|
||||||
"compile:ahead-of-time compile the project"
|
|
||||||
"deps:download and install all dependencies"
|
|
||||||
"help:display a list of tasks or help for a given task"
|
|
||||||
"install:install the project and its dependencies in your local repository"
|
|
||||||
"jar:create a jar file containing the compiled .class files"
|
|
||||||
"new:create a new project skeleton"
|
|
||||||
"pom:write a pom.xml file to disk for maven interop"
|
|
||||||
"test:run the project's tests"
|
|
||||||
"uberjar:Create a jar including the contents of each of deps"
|
|
||||||
"upgrade:upgrade leiningen to the latest stable release"
|
|
||||||
"version:print leiningen's version"
|
|
||||||
)
|
|
||||||
_describe -t subcommands 'leiningen subcommands' subcommands && ret=0
|
|
||||||
esac
|
|
||||||
|
|
||||||
return ret
|
|
||||||
}
|
|
||||||
|
|
||||||
compdef _lein_commands lein
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
# To use: add a .lighthouse file into your directory with the URL to the
|
|
||||||
# individual project. For example:
|
|
||||||
# https://rails.lighthouseapp.com/projects/8994
|
|
||||||
# Example usage: http://screencast.com/t/ZDgwNDUwNT
|
|
||||||
open_lighthouse_ticket () {
|
|
||||||
if [ ! -f .lighthouse-url ]; then
|
|
||||||
echo "There is no .lighthouse-url file in the current directory..."
|
|
||||||
return 0;
|
|
||||||
else
|
|
||||||
lighthouse_url=$(cat .lighthouse-url);
|
|
||||||
echo "Opening ticket #$1";
|
|
||||||
`open $lighthouse_url/tickets/$1`;
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
alias lho='open_lighthouse_ticket'
|
|
||||||
|
|
@ -1,37 +0,0 @@
|
||||||
# LOL!!1
|
|
||||||
# Source: http://aur.archlinux.org/packages/lolbash/lolbash/lolbash.sh
|
|
||||||
|
|
||||||
alias wtf='dmesg'
|
|
||||||
alias onoz='cat /var/log/errors.log'
|
|
||||||
alias rtfm='man'
|
|
||||||
|
|
||||||
alias visible='echo'
|
|
||||||
alias invisible='cat'
|
|
||||||
alias moar='more'
|
|
||||||
alias tldr='less'
|
|
||||||
alias alwayz='tail -f'
|
|
||||||
|
|
||||||
alias icanhas='mkdir'
|
|
||||||
alias gimmeh='touch'
|
|
||||||
alias donotwant='rm'
|
|
||||||
alias dowant='cp'
|
|
||||||
alias gtfo='mv'
|
|
||||||
alias nowai='chmod'
|
|
||||||
|
|
||||||
alias hai='cd'
|
|
||||||
alias iz='ls'
|
|
||||||
alias plz='pwd'
|
|
||||||
alias ihasbucket='df -h'
|
|
||||||
|
|
||||||
alias inur='locate'
|
|
||||||
alias iminurbase='finger'
|
|
||||||
|
|
||||||
alias btw='nice'
|
|
||||||
alias obtw='nohup'
|
|
||||||
|
|
||||||
alias nomz='ps -aux'
|
|
||||||
alias nomnom='killall'
|
|
||||||
|
|
||||||
alias byes='exit'
|
|
||||||
alias cya='reboot'
|
|
||||||
alias kthxbai='halt'
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
||||||
|
|
||||||
# Mercurial
|
|
||||||
alias hgc='hg commit -v'
|
|
||||||
alias hgb='hg branch -v'
|
|
||||||
alias hgba='hg branches'
|
|
||||||
alias hgco='hg checkout'
|
|
||||||
alias hgd='hg diff'
|
|
||||||
alias hged='hg diffmerge'
|
|
||||||
# pull and update
|
|
||||||
alias hgl='hg pull -u -v'
|
|
||||||
alias hgp='hg push -v'
|
|
||||||
alias hgs='hg status -v'
|
|
||||||
# this is the 'git commit --amend' equivalent
|
|
||||||
alias hgca='hg qimport -r tip ; hg qrefresh -e ; hg qfinish tip'
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
# Open the node api for your current version to the optional section.
|
|
||||||
# TODO: Make the section part easier to use.
|
|
||||||
function node-docs {
|
|
||||||
open "http://nodejs.org/docs/$(node --version)/api/all.html#$1"
|
|
||||||
}
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
eval "$(npm completion 2>/dev/null)"
|
|
||||||
|
|
@ -1,62 +0,0 @@
|
||||||
# https://github.com/dbbolton
|
|
||||||
#
|
|
||||||
# Below are some useful Perl-related aliases/functions that I use with zsh.
|
|
||||||
|
|
||||||
|
|
||||||
# Aliases ###################################################################
|
|
||||||
|
|
||||||
# perlbrew ########
|
|
||||||
alias pbi='perlbrew install'
|
|
||||||
alias pbl='perlbrew list'
|
|
||||||
alias pbo='perlbrew off'
|
|
||||||
alias pbs='perlbrew switch'
|
|
||||||
alias pbu='perlbrew use'
|
|
||||||
|
|
||||||
# Perl ############
|
|
||||||
|
|
||||||
# perldoc`
|
|
||||||
alias pd='perldoc'
|
|
||||||
|
|
||||||
# use perl like awk/sed
|
|
||||||
alias ple='perl -wlne'
|
|
||||||
|
|
||||||
# show the latest stable release of Perl
|
|
||||||
alias latest-perl='curl -s http://www.perl.org/get.html | perl -wlne '\''if (/perl\-([\d\.]+)\.tar\.gz/) { print $1; exit;}'\'
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Functions #################################################################
|
|
||||||
|
|
||||||
# newpl - creates a basic Perl script file and opens it with $EDITOR
|
|
||||||
newpl () {
|
|
||||||
# set $EDITOR to 'vim' if it is undefined
|
|
||||||
[[ -z $EDITOR ]] && EDITOR=vim
|
|
||||||
|
|
||||||
# if the file exists, just open it
|
|
||||||
[[ -e $1 ]] && print "$1 exists; not modifying.\n" && $EDITOR $1
|
|
||||||
|
|
||||||
# if it doesn't, make it, and open it
|
|
||||||
[[ ! -e $1 ]] && print '#!/usr/bin/perl'"\n"'use strict;'"\n"'use warnings;'\
|
|
||||||
"\n\n" > $1 && $EDITOR $1
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# pgs - Perl Global Substitution
|
|
||||||
# find pattern = 1st arg
|
|
||||||
# replace pattern = 2nd arg
|
|
||||||
# filename = 3rd arg
|
|
||||||
pgs() { # [find] [replace] [filename]
|
|
||||||
perl -i.orig -pe 's/'"$1"'/'"$2"'/g' "$3"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# Perl grep, because 'grep -P' is terrible. Lets you work with pipes or files.
|
|
||||||
prep() { # [pattern] [filename unless STDOUT]
|
|
||||||
perl -nle 'print if /'"$1"'/;' $2
|
|
||||||
}
|
|
||||||
|
|
||||||
# say - append a newline to 'print'
|
|
||||||
say() {
|
|
||||||
print "$1\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@ -1,19 +0,0 @@
|
||||||
_phing_does_target_list_need_generating () {
|
|
||||||
if [ ! -f .phing_targets ]; then return 0;
|
|
||||||
else
|
|
||||||
accurate=$(stat -f%m .phing_targets)
|
|
||||||
changed=$(stat -f%m build.xml)
|
|
||||||
return $(expr $accurate '>=' $changed)
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_phing () {
|
|
||||||
if [ -f build.xml ]; then
|
|
||||||
if _phing_does_target_list_need_generating; then
|
|
||||||
phing -l |grep -v ":" |grep -v "^$"|grep -v "\-" > .phing_targets
|
|
||||||
fi
|
|
||||||
compadd `cat .phing_targets`
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compdef _phing phing
|
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
#compdef pip
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
# pip zsh completion, based on homebrew completion
|
|
||||||
|
|
||||||
_pip_installed() {
|
|
||||||
installed_pkgs=(`pip freeze`)
|
|
||||||
}
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
'bundle:Create pybundles (archives containing multiple packages)'
|
|
||||||
'freeze:Output all currently installed packages (exact versions) to stdout'
|
|
||||||
'help:Show available commands'
|
|
||||||
'install:Install packages'
|
|
||||||
'search:Search PyPI'
|
|
||||||
'uninstall:Uninstall packages'
|
|
||||||
'unzip:Unzip individual packages'
|
|
||||||
'zip:Zip individual packages'
|
|
||||||
)
|
|
||||||
|
|
||||||
local expl
|
|
||||||
local -a pkgs installed_pkgs
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
'(--version)--version[Show version number of program and exit]' \
|
|
||||||
'(-v --verbose)'{-v,--verbose}'[Give more output]' \
|
|
||||||
'(-q --quiet)'{-q,--quiet}'[Give less output]' \
|
|
||||||
'(-h --help)'{-h,--help}'[Show help]' \
|
|
||||||
'*:: :->subcmds' && return 0
|
|
||||||
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
_describe -t commands "pip subcommand" _1st_arguments
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$words[1]" in
|
|
||||||
list)
|
|
||||||
if [[ "$state" == forms ]]; then
|
|
||||||
_pip_installed
|
|
||||||
_requested installed_pkgs expl 'installed packages' compadd -a installed_pkgs
|
|
||||||
fi ;;
|
|
||||||
uninstall)
|
|
||||||
_pip_installed
|
|
||||||
_wanted installed_pkgs expl 'installed packages' compadd -a installed_pkgs ;;
|
|
||||||
esac
|
|
||||||
|
|
@ -1,10 +0,0 @@
|
||||||
# Thanks to Christopher Sexton
|
|
||||||
# https://gist.github.com/965032
|
|
||||||
function kapow {
|
|
||||||
touch ~/.pow/$1/tmp/restart.txt
|
|
||||||
if [ $? -eq 0 ]; then
|
|
||||||
echo "$fg[yellow]Pow restarting $1...$reset_color"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compctl -W ~/.pow -/ kapow
|
|
||||||
|
|
@ -1,4 +0,0 @@
|
||||||
#compdef powder
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
compadd `powder help | grep powder | cut -d " " -f 4`
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
# Find python file
|
|
||||||
alias pyfind='find . -name "*.py"'
|
|
||||||
|
|
||||||
# Remove python compiled byte-code
|
|
||||||
alias pyclean='find . -type f -name "*.py[co]" -exec rm -f \{\} \;'
|
|
||||||
|
|
@ -1,13 +0,0 @@
|
||||||
alias ss='thin --stats "/thin/stats" start'
|
|
||||||
alias sg='ruby script/generate'
|
|
||||||
alias sd='ruby script/destroy'
|
|
||||||
alias sp='ruby script/plugin'
|
|
||||||
alias ssp='ruby script/spec'
|
|
||||||
alias rdbm='rake db:migrate'
|
|
||||||
alias sc='ruby script/console'
|
|
||||||
alias sd='ruby script/server --debugger'
|
|
||||||
alias devlog='tail -f log/development.log'
|
|
||||||
|
|
||||||
function remote_console() {
|
|
||||||
/usr/bin/env ssh $1 "( cd $2 && ruby script/console production )"
|
|
||||||
}
|
|
||||||
|
|
@ -1,19 +0,0 @@
|
||||||
# Rails 3 aliases, backwards-compatible with Rails 2.
|
|
||||||
|
|
||||||
function _rails_command () {
|
|
||||||
if [ -e "script/server" ]; then
|
|
||||||
ruby script/$@
|
|
||||||
else
|
|
||||||
ruby script/rails $@
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
alias rc='_rails_command console'
|
|
||||||
alias rd='_rails_command destroy'
|
|
||||||
alias rdb='_rails_command dbconsole'
|
|
||||||
alias rdbm='rake db:migrate db:test:clone'
|
|
||||||
alias rg='_rails_command generate'
|
|
||||||
alias rp='_rails_command plugin'
|
|
||||||
alias rs='_rails_command server'
|
|
||||||
alias rsd='_rails_command server --debugger'
|
|
||||||
alias devlog='tail -f log/development.log'
|
|
||||||
|
|
@ -1,142 +0,0 @@
|
||||||
#compdef redis-cli rec
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
#redis cli completion, based off homebrew completion (ref. 2011-04-14)
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
'append:append a value to a key'
|
|
||||||
'auth:authenticate to the server'
|
|
||||||
'bgrewriteeaof:asynchronously rewrite the append-only file'
|
|
||||||
'bgsave:asynchornously save the dataset to disk'
|
|
||||||
'blpop:remove and get the first element in a list, or block until one is available'
|
|
||||||
'brpop:remove and get the last element in a list, or block until one is available'
|
|
||||||
'brpoplpush:pop a value from a list, push it to another list and return it; or block until one is available'
|
|
||||||
# 'config get:get the value of a configuration parameter'
|
|
||||||
# 'config set:set a configuration parameter to the given value'
|
|
||||||
# 'config resetstat: reset the stats returned by INFO'
|
|
||||||
'dbsize:return the number of keys in the selected database'
|
|
||||||
# 'debug object:get debugging information about a key'
|
|
||||||
# 'debug setgfault:make the server crash'
|
|
||||||
'decr:decrement the integer value of a key by one'
|
|
||||||
'decrby:decrement the integet value of a key by the given number'
|
|
||||||
'del:delete a key'
|
|
||||||
'discard:discard all commands issued after MULTI'
|
|
||||||
'echo:echo the given string'
|
|
||||||
'exec:execute all commands issued after a MULTI'
|
|
||||||
'exists:determine if a key exists'
|
|
||||||
'expire:set the time to live for a key, in seconds'
|
|
||||||
'expireat:set the expiration for a key as a UNIX timestamp'
|
|
||||||
'flushall:remove all keys from all databases'
|
|
||||||
'flushdb:remove all keys from the current database'
|
|
||||||
'get:get the value of a key'
|
|
||||||
'getbit:returns the bit value at offset in the string value stored at key'
|
|
||||||
'getrange:get a substring of the string stored at a key'
|
|
||||||
'getset:set the string value of a key and return its old value'
|
|
||||||
'hdel:delete a hash field'
|
|
||||||
'hexists:determine if a hash field exists'
|
|
||||||
'hget:get the value of a hash field'
|
|
||||||
'hgetall:get all the fields and values in a hash'
|
|
||||||
'hincrby:increment the integer value of a hash field by the given number'
|
|
||||||
'hkeys:get all the fields in a hash'
|
|
||||||
'hlen:get the number of fields in a hash'
|
|
||||||
'hmget:get the values of all the given hash fields'
|
|
||||||
'hmset:set multiple hash fields to multiple values'
|
|
||||||
'hset:set the string value of a hash field'
|
|
||||||
'hsetnx:set the value of a hash field, only if the field does not exist'
|
|
||||||
'hvals:get all the values in a hash'
|
|
||||||
'incr:increment the integer value of a key by one'
|
|
||||||
'incrby:increment the integer value of a key by the given number'
|
|
||||||
'info:get information and statistics about the server'
|
|
||||||
'keys:find all keys matching the given pattern'
|
|
||||||
'lastsave:get the UNIX timestamp of the last successful save to disk'
|
|
||||||
'lindex:get an element from a list by its index'
|
|
||||||
'linsert:insert an element before or after another element in a list'
|
|
||||||
'llen:get the length of a list'
|
|
||||||
'lpop:remove and get the first element in a list'
|
|
||||||
'lpush:prepend a value to a list'
|
|
||||||
'lpushx:prepend a value to a list, only if the list exists'
|
|
||||||
'lrange:get a range of elements from a list'
|
|
||||||
'lrem:remove elements from a list'
|
|
||||||
'lset:set the value of an element in a list by its index'
|
|
||||||
'ltrim:trim a list to the specified range'
|
|
||||||
'mget:get the values of all the given keys'
|
|
||||||
'monitor:listen for all requests received by the server in real time'
|
|
||||||
'move:move a key to another database'
|
|
||||||
'mset:set multiple keys to muliple values'
|
|
||||||
'msetnx:set multiple keys tom ultiple values, only if none of the keys exist'
|
|
||||||
'multi:mark the start of a transaction block'
|
|
||||||
'object:inspect the internals of Redis objects'
|
|
||||||
'persist:remove the expiration from a key'
|
|
||||||
'ping:ping the server'
|
|
||||||
'psubscribe:listen for messages published to channels matching the given patterns'
|
|
||||||
'publish:post a message to a channel'
|
|
||||||
'punsubscribe:stop listening for messages posted to channels matching the given patterns'
|
|
||||||
'quit:close the connection'
|
|
||||||
'randomkey:return a random key from the keyspace'
|
|
||||||
'rename:rename a key'
|
|
||||||
'renamenx:rename a key, only if the new key does not exist'
|
|
||||||
'rpop:remove and get the last element in a list'
|
|
||||||
'rpoplpush:remove the last element in a list, append it to another list and return it'
|
|
||||||
'rpush:append a value to a list'
|
|
||||||
'rpushx:append a value to a list, only if the list exists'
|
|
||||||
'sadd:add a member to a set'
|
|
||||||
'save:synchronously save the dataset to disk'
|
|
||||||
'scard:get the number of members in a set'
|
|
||||||
'sdiff:subtract multiple sets'
|
|
||||||
'sdiffstore:subtract multiple sets and store the resulting set in a key'
|
|
||||||
'select:change the selected database for the current connection'
|
|
||||||
'set:set the string value of a key'
|
|
||||||
'setbit:sets or clears the bit at offset in the string value stored at key'
|
|
||||||
'setex:set the value and expiration of a key'
|
|
||||||
'setnx:set the value of a key, only if the key does not exist'
|
|
||||||
'setrange:overwrite part of a string at key starting at the specified offset'
|
|
||||||
'shutdown:synchronously save the dataset to disk and then shut down the server'
|
|
||||||
'sinter:intersect multiple sets'
|
|
||||||
'sinterstore:intersect multiple sets and store the resulting set in a key'
|
|
||||||
'sismember:determine if a given value is a member of a set'
|
|
||||||
'slaveof:make the server a slave of another instance, or promote it as master'
|
|
||||||
'smembers:get all the members in a set'
|
|
||||||
'smove:move a member from one set to another'
|
|
||||||
'sort:sort the elements in a list, set or sorted set'
|
|
||||||
'spop:remove and return a random member from a set'
|
|
||||||
'srandmember:get a random member from a set'
|
|
||||||
'srem:remove a member from a set'
|
|
||||||
'strlen:get the length of the value stored in a key'
|
|
||||||
'subscribe:listen for messages published to the given channels'
|
|
||||||
'sunion:add multiple sets'
|
|
||||||
'sunionstore:add multiple sets and store the resulting set in a key'
|
|
||||||
'ttl:get the time to live for a key'
|
|
||||||
'type:determine the type stored at key'
|
|
||||||
'unsubscribe:stop listening for messages posted to the given channels'
|
|
||||||
'unwatch:forget about all watched keys'
|
|
||||||
'watch:watch the given keys to determine execution of the MULTI/EXEC block'
|
|
||||||
'zadd:add a member to a sorted set, or update its score if it already exists'
|
|
||||||
'zcard:get the number of members in a sorted set'
|
|
||||||
'zcount:count the members in a sorted set with scores within the given values'
|
|
||||||
'zincrby:increment the score of a member in a sorted set'
|
|
||||||
'zinterstore:intersect multiple sorted sets and store the resulting sorted set in a new key'
|
|
||||||
'zrange:return a range of members in a sorted set, by index'
|
|
||||||
'zrangebyscore:return a range of members in a sorted set, by score'
|
|
||||||
'zrank:determine the index of a member in a sorted set'
|
|
||||||
'zrem:remove a member from a sorted set'
|
|
||||||
'zremrangebyrank:remove all members in a sorted set within the given indexes'
|
|
||||||
'zremrangebyscore:remove all members in a sorted set within the given scores'
|
|
||||||
'zrevrange:return a range of membrs in a sorted set, by index, with scores ordered from high to low'
|
|
||||||
'zrevrangebyscore:return a range of members in a sorted set, by score, with scores ordered from high to low'
|
|
||||||
'zrevrank:determine the index of a member in a sorted set, with scores ordered from high to low'
|
|
||||||
'zscore:get the score associated with the given member in a sorted set'
|
|
||||||
'zunionstore:add multiple sorted sets and store te resulting sorted set in a new key'
|
|
||||||
)
|
|
||||||
|
|
||||||
local expl
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
'(-v --version)'{-v,--version}'[show version]' \
|
|
||||||
'(-h --help)'{-h,--help}'[show help]' \
|
|
||||||
'*:: :->subcmds' && return 0
|
|
||||||
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
_describe -t commands "redis-cli subcommand" _1st_arguments
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
# TODO: Make this compatible with rvm.
|
|
||||||
# Run sudo gem on the system ruby, not the active ruby.
|
|
||||||
alias sgem='sudo gem'
|
|
||||||
|
|
||||||
# Find ruby file
|
|
||||||
alias rfind='find . -name *.rb | xargs grep -n'
|
|
||||||
147
plugins/rvm/_rvm
147
plugins/rvm/_rvm
|
|
@ -1,147 +0,0 @@
|
||||||
#compdef rvm
|
|
||||||
|
|
||||||
local curcontext="$curcontext" state line cmds ret=1
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
'(- 1 *)'{-v,--version}'[display version information]' \
|
|
||||||
'(-l|--level)'{-l,--level}'+[patch level to use with rvm use / install]:number' \
|
|
||||||
'(--prefix)--prefix[path for all rvm files (~/.rvm/), with trailing slash!]:path:_files' \
|
|
||||||
'(--bin)--bin[path for binaries to be placed (~/.rvm/bin/)]:path:_files' \
|
|
||||||
'(--source)--source[src directory to use (~/.rvm/src/)]:path:_files' \
|
|
||||||
'(--archives)--archives[directory for downladed files (~/.rvm/archives/)]:path:_files' \
|
|
||||||
'-S[Specify a script file to attempt to load and run (rubydo)]:file:_files' \
|
|
||||||
'-e[Execute code from the command line]:code' \
|
|
||||||
'(-G)-G[root gem path to use]:path:_files' \
|
|
||||||
'(--gems)--gems[Used to set the gems_flag, use with remove to remove gems]' \
|
|
||||||
'(--archive)--archive[Used to set the archive_flag, use with remove to remove archive]' \
|
|
||||||
'(--patch)--patch[With MRI Rubies you may specify one or more full paths to patches]' \
|
|
||||||
'(-C|--configure)'{-C,--configure}'=[custom configure options]' \
|
|
||||||
'(--nice)--nice[process niceness (for slow computers, default 0)]:number' \
|
|
||||||
'(--ree)--ree-options[Options passed directly to ree ./installer on the command line]:options' \
|
|
||||||
'(--head)--head[with update, updates rvm to git head version]' \
|
|
||||||
'(--rubygems)--rubygems[with update, updates rubygems for selected ruby]' \
|
|
||||||
'(--default)--default[with ruby select, sets a default ruby for new shells]' \
|
|
||||||
'(--debug)--debug[Toggle debug mode on for very verbose output]' \
|
|
||||||
'(--trace)--trace[Toggle trace mode on to see EVERYTHING rvm is doing]' \
|
|
||||||
'(--force)--force[Force install, removes old install & source before install]' \
|
|
||||||
'(--summary)--summary[Used with rubydo to print out a summary of the commands run]' \
|
|
||||||
'(--latest)--latest[with gemset --dump skips version strings for latest gem]' \
|
|
||||||
'(--gems)--gems[with uninstall/remove removes gems with the interpreter]' \
|
|
||||||
'(--docs)--docs[with install, attempt to generate ri after installation]' \
|
|
||||||
'(--reconfigure)--reconfigure[Force ./configure on install even if Makefile already exists]' \
|
|
||||||
'1: :->cmds' \
|
|
||||||
'*: :->args' && ret=0
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
cmds)
|
|
||||||
cmds=(
|
|
||||||
"version:show the rvm version installed in rvm_path"
|
|
||||||
"use:setup current shell to use a specific ruby version"
|
|
||||||
"reload:reload rvm source itself (useful after changing rvm source)"
|
|
||||||
"implode:(seppuku) removes the rvm installation completely. This means everything in $rvm_path (~/.rvm)."
|
|
||||||
"update:upgrades rvm to the latest version."
|
|
||||||
"reset:remove current and stored default & system settings."
|
|
||||||
"info :show the *current* environment information for current ruby"
|
|
||||||
"current:print the *current* ruby version and the name of any gemset being used."
|
|
||||||
"debug:show info plus additional information for common issues"
|
|
||||||
"install:install one or many ruby versions"
|
|
||||||
"uninstall:uninstall one or many ruby versions, leaves their sources"
|
|
||||||
"remove:uninstall one or many ruby versions and remove their sources"
|
|
||||||
"migrate:Lets you migrate all gemsets from one ruby to another."
|
|
||||||
"upgrade:Lets you upgrade from one version of a ruby to another, including migrating your gemsets semi-automatically."
|
|
||||||
"wrapper:generates a set of wrapper executables for a given ruby with the specified ruby and gemset combination. Used under the hood for passenger support and the like."
|
|
||||||
"cleanup:Lets you remove stale source folders / archives and other miscellaneous data associated with rvm."
|
|
||||||
"repair:Lets you repair parts of your environment e.g. wrappers, env files and and similar files (e.g. general maintenance)."
|
|
||||||
"snapshot:Lets your backup / restore an rvm installation in a lightweight manner."
|
|
||||||
"disk-usage:Tells you how much disk space rvm install is using."
|
|
||||||
"tools:Provides general information about the ruby environment, primarily useful when scripting rvm."
|
|
||||||
"docs:Tools to make installing ri and rdoc documentation easier."
|
|
||||||
"rvmrc:Tools related to managing rvmrc trust and loading."
|
|
||||||
"exec:runs an arbitrary command as a set operation."
|
|
||||||
"ruby:runs a named ruby file against specified and/or all rubies"
|
|
||||||
"gem:runs a gem command using selected ruby's 'gem'"
|
|
||||||
"rake:runs a rake task against specified and/or all rubies"
|
|
||||||
"tests:runs 'rake test' across selected ruby versions"
|
|
||||||
"specs:runs 'rake spec' across selected ruby versions"
|
|
||||||
"monitor:Monitor cwd for testing, run rake {spec,test} on changes."
|
|
||||||
"gemset:gemsets: http://rvm.beginrescueend.com/gemsets/"
|
|
||||||
"rubygems:Switches the installed version of rubygems for the current ruby."
|
|
||||||
"gemdir:display the path to the current gem directory (GEM_HOME)."
|
|
||||||
"srcdir:display the path to rvm source directory (may be yanked)"
|
|
||||||
"fetch:Performs an archive / src fetch only of the selected ruby."
|
|
||||||
"list:show currently installed rubies, interactive output."
|
|
||||||
"package:Install a dependency package {readline,iconv,zlib,openssl}"
|
|
||||||
"notes:Display notes, with operating system specifics."
|
|
||||||
"export:Temporarily set an environment variable in the current shell."
|
|
||||||
"unexport:Undo changes made to the environment by 'rvm export'."
|
|
||||||
)
|
|
||||||
_describe -t commands 'rvm command' cmds && ret=0
|
|
||||||
;;
|
|
||||||
args)
|
|
||||||
case $line[1] in
|
|
||||||
(use|uninstall|remove|list)
|
|
||||||
_values -S , 'rubies' $(rvm list strings | sed -e 's/ruby-\([^) ]*\)-\([^) ]*\)/ruby-\1-\2 \1-\2 \1/g') default system && ret=0
|
|
||||||
;;
|
|
||||||
(install|fetch)
|
|
||||||
_values -S , 'rubies' $(rvm list known_strings) && ret=0
|
|
||||||
;;
|
|
||||||
gemset)
|
|
||||||
if (( CURRENT == 3 )); then
|
|
||||||
_values 'gemset_commands' \
|
|
||||||
'import' \
|
|
||||||
'export' \
|
|
||||||
'create' \
|
|
||||||
'copy' \
|
|
||||||
'rename' \
|
|
||||||
'empty' \
|
|
||||||
'delete' \
|
|
||||||
'name' \
|
|
||||||
'dir' \
|
|
||||||
'list' \
|
|
||||||
'list_all' \
|
|
||||||
'gemdir' \
|
|
||||||
'install' \
|
|
||||||
'pristine' \
|
|
||||||
'clear' \
|
|
||||||
'use' \
|
|
||||||
'update' \
|
|
||||||
'unpack' \
|
|
||||||
'globalcache'
|
|
||||||
else
|
|
||||||
_values -S , 'gemsets' $(rvm gemset list | grep -v gemset 2>/dev/null)
|
|
||||||
fi
|
|
||||||
ret=0
|
|
||||||
;;
|
|
||||||
package)
|
|
||||||
if (( CURRENT == 3 )); then
|
|
||||||
_values 'package_commands' \
|
|
||||||
'install' \
|
|
||||||
'uninstall'
|
|
||||||
else
|
|
||||||
_values 'packages' \
|
|
||||||
'readline' \
|
|
||||||
'iconv' \
|
|
||||||
'curl' \
|
|
||||||
'openssl' \
|
|
||||||
'zlib' \
|
|
||||||
'autoconf' \
|
|
||||||
'ncurses' \
|
|
||||||
'pkgconfig' \
|
|
||||||
'gettext' \
|
|
||||||
'glib' \
|
|
||||||
'mono' \
|
|
||||||
'llvm' \
|
|
||||||
'libxml2' \
|
|
||||||
'libxslt' \
|
|
||||||
'libyaml'
|
|
||||||
fi
|
|
||||||
ret=0
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
(( ret )) && _message 'no more arguments'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
return ret
|
|
||||||
|
|
@ -1,44 +0,0 @@
|
||||||
alias rubies='rvm list rubies'
|
|
||||||
alias gemsets='rvm gemset list'
|
|
||||||
|
|
||||||
local ruby18='ruby-1.8.7-p334'
|
|
||||||
local ruby19='ruby-1.9.2-p180'
|
|
||||||
|
|
||||||
function rb18 {
|
|
||||||
if [ -z "$1" ]; then
|
|
||||||
rvm use "$ruby18"
|
|
||||||
else
|
|
||||||
rvm use "$ruby18@$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_rb18() {compadd `ls -1 $rvm_path/gems | grep "^$ruby18@" | sed -e "s/^$ruby18@//" | awk '{print $1}'`}
|
|
||||||
compdef _rb18 rb18
|
|
||||||
|
|
||||||
function rb19 {
|
|
||||||
if [ -z "$1" ]; then
|
|
||||||
rvm use "$ruby19"
|
|
||||||
else
|
|
||||||
rvm use "$ruby19@$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_rb19() {compadd `ls -1 $rvm_path/gems | grep "^$ruby19@" | sed -e "s/^$ruby19@//" | awk '{print $1}'`}
|
|
||||||
compdef _rb19 rb19
|
|
||||||
|
|
||||||
function rvm-update {
|
|
||||||
rvm get head
|
|
||||||
rvm reload # TODO: Reload rvm completion?
|
|
||||||
}
|
|
||||||
|
|
||||||
# TODO: Make this usable w/o rvm.
|
|
||||||
function gems {
|
|
||||||
local current_ruby=`rvm-prompt i v p`
|
|
||||||
local current_gemset=`rvm-prompt g`
|
|
||||||
|
|
||||||
gem list $@ | sed \
|
|
||||||
-Ee "s/\([0-9\.]+( .+)?\)/$fg[blue]&$reset_color/g" \
|
|
||||||
-Ee "s|$(echo $rvm_path)|$fg[magenta]\$rvm_path$reset_color|g" \
|
|
||||||
-Ee "s/$current_ruby@global/$fg[yellow]&$reset_color/g" \
|
|
||||||
-Ee "s/$current_ruby$current_gemset$/$fg[green]&$reset_color/g"
|
|
||||||
}
|
|
||||||
|
|
@ -1,62 +0,0 @@
|
||||||
#
|
|
||||||
# INSTRUCTIONS
|
|
||||||
#
|
|
||||||
# To enabled agent forwarding support add the following to
|
|
||||||
# your .zshrc file:
|
|
||||||
#
|
|
||||||
# zstyle :omz:plugins:ssh-agent agent-forwarding on
|
|
||||||
#
|
|
||||||
# To load multiple identies use the identities style, For
|
|
||||||
# example:
|
|
||||||
#
|
|
||||||
# zstyle :omz:plugins:ssh-agent id_rsa id_rsa2 id_github
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# CREDITS
|
|
||||||
#
|
|
||||||
# Based on code from Joseph M. Reagle
|
|
||||||
# http://www.cygwin.com/ml/cygwin/2001-06/msg00537.html
|
|
||||||
#
|
|
||||||
# Agent forwarding support based on ideas from
|
|
||||||
# Florent Thoumie and Jonas Pfenniger
|
|
||||||
#
|
|
||||||
|
|
||||||
local _plugin__ssh_env=$HOME/.ssh/environment-$HOST
|
|
||||||
local _plugin__forwarding
|
|
||||||
|
|
||||||
function _plugin__start_agent()
|
|
||||||
{
|
|
||||||
local -a identities
|
|
||||||
|
|
||||||
# start ssh-agent and setup environment
|
|
||||||
/usr/bin/env ssh-agent | sed 's/^echo/#echo/' > ${_plugin__ssh_env}
|
|
||||||
chmod 600 ${_plugin__ssh_env}
|
|
||||||
. ${_plugin__ssh_env} > /dev/null
|
|
||||||
|
|
||||||
# load identies
|
|
||||||
zstyle -a :omz:plugins:ssh-agent identities identities
|
|
||||||
echo starting...
|
|
||||||
/usr/bin/ssh-add $HOME/.ssh/${^identities}
|
|
||||||
}
|
|
||||||
|
|
||||||
# test if agent-forwarding is enabled
|
|
||||||
zstyle -b :omz:plugins:ssh-agent agent-forwarding _plugin__forwarding
|
|
||||||
if [[ ${_plugin__forwarding} == "yes" && -n "$SSH_AUTH_SOCK" ]]; then
|
|
||||||
# Add a nifty symlink for screen/tmux if agent forwarding
|
|
||||||
[[ -L $SSH_AUTH_SOCK ]] || ln -sf "$SSH_AUTH_SOCK" /tmp/ssh-agent-$USER-screen
|
|
||||||
|
|
||||||
elif [ -f "${_plugin__ssh_env}" ]; then
|
|
||||||
# Source SSH settings, if applicable
|
|
||||||
. ${_plugin__ssh_env} > /dev/null
|
|
||||||
ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent$ > /dev/null || {
|
|
||||||
_plugin__start_agent;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
_plugin__start_agent;
|
|
||||||
fi
|
|
||||||
|
|
||||||
# tidy up after ourselves
|
|
||||||
unfunction _plugin__start_agent
|
|
||||||
unset _plugin__forwarding
|
|
||||||
unset _plugin__ssh_env
|
|
||||||
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
||||||
function svn_prompt_info {
|
|
||||||
if [ $(in_svn) ]; then
|
|
||||||
echo "$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_PREFIX\
|
|
||||||
$ZSH_THEME_REPO_NAME_COLOR$(svn_get_repo_name)$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_SUFFIX$ZSH_PROMPT_BASE_COLOR$(svn_dirty)$ZSH_PROMPT_BASE_COLOR"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function in_svn() {
|
|
||||||
if [[ -d .svn ]]; then
|
|
||||||
echo 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function svn_get_repo_name {
|
|
||||||
if [ $(in_svn) ]; then
|
|
||||||
svn info | sed -n 's/Repository\ Root:\ .*\///p' | read SVN_ROOT
|
|
||||||
|
|
||||||
svn info | sed -n "s/URL:\ .*$SVN_ROOT\///p" | sed "s/\/.*$//"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function svn_get_rev_nr {
|
|
||||||
if [ $(in_svn) ]; then
|
|
||||||
svn info 2> /dev/null | sed -n s/Revision:\ //p
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function svn_dirty_choose {
|
|
||||||
if [ $(in_svn) ]; then
|
|
||||||
s=$(svn status|grep -E '^\s*[ACDIM!?L]' 2>/dev/null)
|
|
||||||
if [ $s ]; then
|
|
||||||
echo $1
|
|
||||||
else
|
|
||||||
echo $2
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function svn_dirty {
|
|
||||||
svn_dirty_choose $ZSH_THEME_SVN_PROMPT_DIRTY $ZSH_THEME_SVN_PROMPT_CLEAN
|
|
||||||
}
|
|
||||||
|
|
@ -1,280 +0,0 @@
|
||||||
#compdef task
|
|
||||||
#
|
|
||||||
# zsh completion for taskwarrior
|
|
||||||
#
|
|
||||||
# Copyright 2010 - 2011 Johannes Schlatow
|
|
||||||
# Copyright 2009 P.C. Shyamshankar
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# This script is part of the taskwarrior project.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify it under
|
|
||||||
# the terms of the GNU General Public License as published by the Free Software
|
|
||||||
# Foundation; either version 2 of the License, or (at your option) any later
|
|
||||||
# version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
||||||
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
||||||
# details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License along with
|
|
||||||
# this program; if not, write to the
|
|
||||||
#
|
|
||||||
# Free Software Foundation, Inc.,
|
|
||||||
# 51 Franklin Street, Fifth Floor,
|
|
||||||
# Boston, MA
|
|
||||||
# 02110-1301
|
|
||||||
# USA
|
|
||||||
#
|
|
||||||
typeset -g _task_cmds _task_projects _task_tags _task_config _task_modifiers
|
|
||||||
_task_projects=($(task _projects))
|
|
||||||
_task_tags=($(task _tags))
|
|
||||||
_task_ids=($(task _ids))
|
|
||||||
_task_config=($(task _config))
|
|
||||||
_task_modifiers=(
|
|
||||||
'before' \
|
|
||||||
'after' \
|
|
||||||
'none' \
|
|
||||||
'any' \
|
|
||||||
'is' \
|
|
||||||
'isnt' \
|
|
||||||
'has' \
|
|
||||||
'hasnt' \
|
|
||||||
'startswith' \
|
|
||||||
'endswith' \
|
|
||||||
'word' \
|
|
||||||
'noword'
|
|
||||||
)
|
|
||||||
_task_cmds=($(task _commands))
|
|
||||||
_task_zshcmds=( ${(f)"$(task _zshcommands)"} )
|
|
||||||
|
|
||||||
|
|
||||||
_task_idCmds=(
|
|
||||||
'append' \
|
|
||||||
'prepend' \
|
|
||||||
'annotate' \
|
|
||||||
'denotate' \
|
|
||||||
'edit' \
|
|
||||||
'duplicate' \
|
|
||||||
'info' \
|
|
||||||
'start' \
|
|
||||||
'stop' \
|
|
||||||
'done'
|
|
||||||
)
|
|
||||||
|
|
||||||
_task_idCmdsDesc=(
|
|
||||||
'append:Appends more description to an existing task.' \
|
|
||||||
'prepend:Prepends more description to an existing task.' \
|
|
||||||
'annotate:Adds an annotation to an existing task.' \
|
|
||||||
'denotate:Deletes an annotation of an existing task.' \
|
|
||||||
'edit:Launches an editor to let you modify a task directly.' \
|
|
||||||
'duplicate:Duplicates the specified task, and allows modifications.' \
|
|
||||||
'info:Shows all data, metadata for specified task.' \
|
|
||||||
'start:Marks specified task as started.' \
|
|
||||||
'stop:Removes the start time from a task.' \
|
|
||||||
'done:Marks the specified task as completed.'
|
|
||||||
)
|
|
||||||
|
|
||||||
_task() {
|
|
||||||
_arguments -s -S \
|
|
||||||
"*::task command:_task_commands"
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
local -a reply args word
|
|
||||||
word=$'[^\0]#\0'
|
|
||||||
|
|
||||||
# priorities
|
|
||||||
local -a task_priorities
|
|
||||||
_regex_words values 'task priorities' \
|
|
||||||
'H:High' \
|
|
||||||
'M:Middle' \
|
|
||||||
'L:Low'
|
|
||||||
task_priorities=("$reply[@]")
|
|
||||||
|
|
||||||
# projects
|
|
||||||
local -a task_projects
|
|
||||||
task_projects=(
|
|
||||||
/"$word"/
|
|
||||||
":values:task projects:compadd -a _task_projects"
|
|
||||||
)
|
|
||||||
|
|
||||||
local -a _task_dates
|
|
||||||
_regex_words values 'task dates' \
|
|
||||||
'tod*ay:Today' \
|
|
||||||
'yes*terday:Yesterday' \
|
|
||||||
'tom*orrow:Tomorrow' \
|
|
||||||
'sow:Start of week' \
|
|
||||||
'soww:Start of work week' \
|
|
||||||
'socw:Start of calendar week' \
|
|
||||||
'som:Start of month' \
|
|
||||||
'soy:Start of year' \
|
|
||||||
'eow:End of week' \
|
|
||||||
'eoww:End of work week' \
|
|
||||||
'eocw:End of calendar week' \
|
|
||||||
'eom:End of month' \
|
|
||||||
'eoy:End of year' \
|
|
||||||
'mon:Monday' \
|
|
||||||
'tue:Tuesday'\
|
|
||||||
'wed:Wednesday' \
|
|
||||||
'thu:Thursday' \
|
|
||||||
'fri:Friday' \
|
|
||||||
'sat:Saturday' \
|
|
||||||
'sun:Sunday'
|
|
||||||
_task_dates=("$reply[@]")
|
|
||||||
|
|
||||||
local -a _task_reldates
|
|
||||||
_regex_words values 'task reldates' \
|
|
||||||
'hrs:n hours' \
|
|
||||||
'day:n days' \
|
|
||||||
'1st:first' \
|
|
||||||
'2nd:second' \
|
|
||||||
'3rd:third' \
|
|
||||||
'th:4th, 5th, etc.' \
|
|
||||||
'wks:weeks'
|
|
||||||
_task_reldates=("$reply[@]")
|
|
||||||
|
|
||||||
task_dates=(
|
|
||||||
\( "$_task_dates[@]" \|
|
|
||||||
\( /$'[0-9][0-9]#'/- \( "$_task_reldates[@]" \) \)
|
|
||||||
\)
|
|
||||||
)
|
|
||||||
|
|
||||||
_regex_words values 'task frequencies' \
|
|
||||||
'daily:Every day' \
|
|
||||||
'day:Every day' \
|
|
||||||
'weekdays:Every day skipping weekend days' \
|
|
||||||
'weekly:Every week' \
|
|
||||||
'biweekly:Every two weeks' \
|
|
||||||
'fortnight:Every two weeks' \
|
|
||||||
'quarterly:Every three months' \
|
|
||||||
'semiannual:Every six months' \
|
|
||||||
'annual:Every year' \
|
|
||||||
'yearly:Every year' \
|
|
||||||
'biannual:Every two years' \
|
|
||||||
'biyearly:Every two years'
|
|
||||||
_task_freqs=("$reply[@]")
|
|
||||||
|
|
||||||
local -a _task_frequencies
|
|
||||||
_regex_words values 'task frequencies' \
|
|
||||||
'd:days' \
|
|
||||||
'w:weeks' \
|
|
||||||
'q:quarters' \
|
|
||||||
'y:years'
|
|
||||||
_task_frequencies=("$reply[@]")
|
|
||||||
|
|
||||||
task_freqs=(
|
|
||||||
\( "$_task_freqs[@]" \|
|
|
||||||
\( /$'[0-9][0-9]#'/- \( "$_task_frequencies[@]" \) \)
|
|
||||||
\)
|
|
||||||
)
|
|
||||||
|
|
||||||
# attributes
|
|
||||||
local -a task_attributes
|
|
||||||
_regex_words -t ':' default 'task attributes' \
|
|
||||||
'pro*ject:Project name:$task_projects' \
|
|
||||||
'du*e:Due date:$task_dates' \
|
|
||||||
'wa*it:Date until task becomes pending:$task_dates' \
|
|
||||||
're*cur:Recurrence frequency:$task_freqs' \
|
|
||||||
'pri*ority:priority:$task_priorities' \
|
|
||||||
'un*til:Recurrence end date:$task_dates' \
|
|
||||||
'fg:Foreground color' \
|
|
||||||
'bg:Background color' \
|
|
||||||
'li*mit:Desired number of rows in report'
|
|
||||||
task_attributes=("$reply[@]")
|
|
||||||
|
|
||||||
args=(
|
|
||||||
\( "$task_attributes[@]" \|
|
|
||||||
\( /'(project|due|wait|recur|priority|until|fg|bg|limit).'/- \( /$'[^:]#:'/ ":default:modifiers:compadd -S ':' -a _task_modifiers" \) \) \|
|
|
||||||
\( /'(rc).'/- \( /$'[^:]#:'/ ":arguments:config:compadd -S ':' -a _task_config" \) \) \|
|
|
||||||
\( /'(+|-)'/- \( /"$word"/ ":values:remove tag:compadd -a _task_tags" \) \) \|
|
|
||||||
\( /"$word"/ \)
|
|
||||||
\) \#
|
|
||||||
)
|
|
||||||
_regex_arguments _task_attributes "${args[@]}"
|
|
||||||
|
|
||||||
## task commands
|
|
||||||
|
|
||||||
# default completion
|
|
||||||
(( $+functions[_task_default] )) ||
|
|
||||||
_task_default() {
|
|
||||||
_task_attributes "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
# commands expecting an ID
|
|
||||||
(( $+functions[_task_id] )) ||
|
|
||||||
_task_id() {
|
|
||||||
if (( CURRENT < 3 )); then
|
|
||||||
# update IDs
|
|
||||||
_task_zshids=( ${(f)"$(task _zshids)"} )
|
|
||||||
_describe -t values 'task IDs' _task_zshids
|
|
||||||
else
|
|
||||||
_task_attributes "$@"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# merge completion
|
|
||||||
(( $+functions[_task_merge] )) ||
|
|
||||||
_task_merge() {
|
|
||||||
# TODO match URIs in .taskrc
|
|
||||||
_files
|
|
||||||
}
|
|
||||||
|
|
||||||
# push completion
|
|
||||||
(( $+functions[_task_push] )) ||
|
|
||||||
_task_push() {
|
|
||||||
# TODO match URIs in .taskrc
|
|
||||||
_files
|
|
||||||
}
|
|
||||||
|
|
||||||
# pull completion
|
|
||||||
(( $+functions[_task_pull] )) ||
|
|
||||||
_task_pull() {
|
|
||||||
# TODO match URIs in .taskrc
|
|
||||||
_files
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# modify (task [0-9]* ...) completion
|
|
||||||
(( $+functions[_task_modify] )) ||
|
|
||||||
_task_modify() {
|
|
||||||
_describe -t commands 'task command' _task_idCmdsDesc
|
|
||||||
_task_attributes "$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
## first level completion => task sub-command completion
|
|
||||||
(( $+functions[_task_commands] )) ||
|
|
||||||
_task_commands() {
|
|
||||||
local cmd ret=1
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
# update IDs
|
|
||||||
_task_zshids=( ${(f)"$(task _zshids)"} )
|
|
||||||
|
|
||||||
_describe -t commands 'task command' _task_zshcmds
|
|
||||||
_describe -t values 'task IDs' _task_zshids
|
|
||||||
# TODO match more than one ID
|
|
||||||
elif [[ $words[1] =~ ^[0-9]*$ ]] then
|
|
||||||
_call_function ret _task_modify
|
|
||||||
return ret
|
|
||||||
else
|
|
||||||
# local curcontext="${curcontext}"
|
|
||||||
# cmd="${_task_cmds[(r)$words[1]:*]%%:*}"
|
|
||||||
cmd="${_task_cmds[(r)$words[1]]}"
|
|
||||||
idCmd="${(M)_task_idCmds[@]:#$words[1]}"
|
|
||||||
if (( $#cmd )); then
|
|
||||||
# curcontext="${curcontext%:*:*}:task-${cmd}"
|
|
||||||
|
|
||||||
if (( $#idCmd )); then
|
|
||||||
_call_function ret _task_id
|
|
||||||
else
|
|
||||||
_call_function ret _task_${cmd} ||
|
|
||||||
_call_function ret _task_default ||
|
|
||||||
_message "No command remaining."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
_message "Unknown subcommand ${cmd}"
|
|
||||||
fi
|
|
||||||
return ret
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
@ -1,21 +0,0 @@
|
||||||
################################################################################
|
|
||||||
# Author: Pete Clark
|
|
||||||
# Email: pete[dot]clark[at]gmail[dot]com
|
|
||||||
# Version: 0.1 (05/24/2011)
|
|
||||||
# License: WTFPL<http://sam.zoy.org/wtfpl/>
|
|
||||||
#
|
|
||||||
# This oh-my-zsh plugin adds smart tab completion for
|
|
||||||
# TaskWarrior<http://taskwarrior.org/>. It uses the zsh tab completion
|
|
||||||
# script (_task) distributed with TaskWarrior for the completion definitions.
|
|
||||||
#
|
|
||||||
# Typing task[tabtab] will give you a list of current tasks, task 66[tabtab]
|
|
||||||
# gives a list of available modifications for that task, etc.
|
|
||||||
################################################################################
|
|
||||||
|
|
||||||
zstyle ':completion:*:*:task:*' verbose yes
|
|
||||||
zstyle ':completion:*:*:task:*:descriptions' format '%U%B%d%b%u'
|
|
||||||
|
|
||||||
zstyle ':completion:*:*:task:*' group-name ''
|
|
||||||
|
|
||||||
alias t=task
|
|
||||||
compdef _task t=task
|
|
||||||
|
|
@ -1,38 +0,0 @@
|
||||||
#compdef terminitor
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
# terminitor zsh completion
|
|
||||||
|
|
||||||
_terminitor_available_scripts() {
|
|
||||||
scripts=(`for SCRIPT in ~/.config/terminitor/*.term ; do basename $SCRIPT .term ; done`)
|
|
||||||
}
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
'create:create a Termfile in directory'
|
|
||||||
'delete:delete terminitor script'
|
|
||||||
'edit:open termitor script'
|
|
||||||
'fetch:clone the designated repo and run setup'
|
|
||||||
'help:Describe available tasks or one specific task'
|
|
||||||
'init:create initial root terminitor folder'
|
|
||||||
'list:lists all terminitor scripts'
|
|
||||||
'setup:execute setup in the terminitor script'
|
|
||||||
'start:runs the terminitor script'
|
|
||||||
'update:update Terminitor to new global path(.config/.terminitor)'
|
|
||||||
)
|
|
||||||
|
|
||||||
local expl
|
|
||||||
|
|
||||||
_arguments \
|
|
||||||
'*:: :->subcmds' && return 0
|
|
||||||
|
|
||||||
if (( CURRENT == 1 )); then
|
|
||||||
_describe -t commands "terminitor task" _1st_arguments
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$words[1]" in
|
|
||||||
start|edit|delete|setup)
|
|
||||||
_terminitor_available_scripts
|
|
||||||
_wanted scripts expl 'installed scripts' compadd -a scripts ;;
|
|
||||||
esac
|
|
||||||
|
|
@ -1,4 +0,0 @@
|
||||||
#compdef thor
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
compadd `thor list | grep thor | cut -d " " -f 2`
|
|
||||||
|
|
@ -1,104 +0,0 @@
|
||||||
#compdef vagrant
|
|
||||||
#autoload
|
|
||||||
|
|
||||||
# vagrant zsh completion
|
|
||||||
|
|
||||||
local -a _1st_arguments
|
|
||||||
_1st_arguments=(
|
|
||||||
'box:Box commands'
|
|
||||||
'destroy:Destroys the vagrant environment'
|
|
||||||
'halt:Halts the currently running vagrant environment'
|
|
||||||
'help:[TASK] Describe available tasks or one specific task'
|
|
||||||
'init:[box_name] [box_url] Initializes current folder for Vagrant usage'
|
|
||||||
'package:Packages a vagrant environment for distribution'
|
|
||||||
'provision:Run the provisioner'
|
|
||||||
'reload:Reload the vagrant environment'
|
|
||||||
'resume:Resumes a suspend vagrant environment'
|
|
||||||
'ssh:SSH into the currently running environment'
|
|
||||||
'ssh_config:outputs .ssh/config valid syntax for connecting to this environment via ssh.'
|
|
||||||
'status:Shows the status of the current Vagrant environment.'
|
|
||||||
'suspend:Suspends the currently running vagrant environment'
|
|
||||||
'up:Creates the vagrant environment'
|
|
||||||
'version:Prints the Vagrant version information'
|
|
||||||
)
|
|
||||||
|
|
||||||
local -a _box_arguments
|
|
||||||
_box_arguments=(
|
|
||||||
'add:NAME URI Add a box to the system'
|
|
||||||
'help:COMMAND Describe subcommands or one specific subcommand'
|
|
||||||
'list:Lists all installed boxes'
|
|
||||||
'remove:NAME Remove a box from the system'
|
|
||||||
'repackage:NAME Repackage an installed box into a `.box` file.'
|
|
||||||
)
|
|
||||||
|
|
||||||
__task_list ()
|
|
||||||
{
|
|
||||||
local expl
|
|
||||||
declare -a tasks
|
|
||||||
|
|
||||||
tasks=(box destroy halt init package provision reload resume ssh ssh_config status suspend up version)
|
|
||||||
|
|
||||||
_wanted tasks expl 'help' compadd $tasks
|
|
||||||
}
|
|
||||||
|
|
||||||
__box_list ()
|
|
||||||
{
|
|
||||||
_wanted application expl 'command' compadd $(command ls -1 $HOME/.vagrant/boxes 2>/dev/null| sed -e 's/ /\\ /g')
|
|
||||||
}
|
|
||||||
|
|
||||||
__vagrant-box ()
|
|
||||||
{
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
_describe -t commands "gem subcommand" _box_arguments
|
|
||||||
return
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
(repackage|remove)
|
|
||||||
_arguments ':feature:__box_list'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
local expl
|
|
||||||
local -a boxes installed_boxes
|
|
||||||
|
|
||||||
local curcontext="$curcontext" state line
|
|
||||||
typeset -A opt_args
|
|
||||||
|
|
||||||
_arguments -C \
|
|
||||||
':command:->command' \
|
|
||||||
'*::options:->options'
|
|
||||||
|
|
||||||
case $state in
|
|
||||||
(command)
|
|
||||||
_describe -t commands "gem subcommand" _1st_arguments
|
|
||||||
return
|
|
||||||
;;
|
|
||||||
|
|
||||||
(options)
|
|
||||||
case $line[1] in
|
|
||||||
(help)
|
|
||||||
_arguments ':feature:__task_list'
|
|
||||||
;;
|
|
||||||
|
|
||||||
(box)
|
|
||||||
__vagrant-box
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
@ -1,22 +0,0 @@
|
||||||
function zle-line-init zle-keymap-select {
|
|
||||||
zle reset-prompt
|
|
||||||
}
|
|
||||||
|
|
||||||
zle -N zle-line-init
|
|
||||||
zle -N zle-keymap-select
|
|
||||||
|
|
||||||
bindkey -v
|
|
||||||
|
|
||||||
# if mode indicator wasn't setup by theme, define default
|
|
||||||
if [[ "$MODE_INDICATOR" == "" ]]; then
|
|
||||||
MODE_INDICATOR="%{$fg_bold[red]%}<%{$fg[red]%}<<%{$reset_color%}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
function vi_mode_prompt_info() {
|
|
||||||
echo "${${KEYMAP/vicmd/$MODE_INDICATOR}/(main|viins)/}"
|
|
||||||
}
|
|
||||||
|
|
||||||
# define right prompt, if it wasn't defined by a theme
|
|
||||||
if [[ "$RPS1" == "" && "$RPROMPT" == "" ]]; then
|
|
||||||
RPS1='$(vi_mode_prompt_info)'
|
|
||||||
fi
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
||||||
function vundle-init () {
|
|
||||||
if [ ! -d ~/.vim/bundle/vundle/ ]
|
|
||||||
then
|
|
||||||
mkdir -p ~/.vim/bundle/vundle/
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -d ~/.vim/bundle/vundle/.git/ ]
|
|
||||||
then
|
|
||||||
git clone http://github.com/gmarik/vundle.git ~/.vim/bundle/vundle
|
|
||||||
echo "\n\tRead about vim configuration for vundle at https://github.com/gmarik/vundle\n"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function vundle () {
|
|
||||||
vundle-init
|
|
||||||
vim -c "execute \"BundleInstall\" | q | q"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function vundle-update () {
|
|
||||||
vundle-init
|
|
||||||
vim -c "execute \"BundleInstall!\" | q | q"
|
|
||||||
}
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue