Merge branch 'master' of https://github.com/robbyrussell/oh-my-zsh
Conflicts: .gitignore lib/completion.zsh lib/git.zsh oh-my-zsh.shpull/1/merge
commit
969553349f
@ -1,3 +1,4 @@
|
|||||||
locals.zsh
|
locals.zsh
|
||||||
log/.zsh_history
|
log/.zsh_history
|
||||||
projects.zsh
|
projects.zsh
|
||||||
|
cache
|
||||||
|
@ -0,0 +1,332 @@
|
|||||||
|
#!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'
|
@ -0,0 +1,27 @@
|
|||||||
|
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
|
@ -0,0 +1,8 @@
|
|||||||
|
# commands to control local mysql-server installation
|
||||||
|
# paths are for osx installation via macports
|
||||||
|
|
||||||
|
alias mysqlstart='sudo /opt/local/share/mysql5/mysql/mysql.server start'
|
||||||
|
alias mysqlstop='sudo /opt/local/share/mysql5/mysql/mysql.server stop'
|
||||||
|
alias mysqlrestart='sudo /opt/local/share/mysql5/mysql/mysql.server restart'
|
||||||
|
|
||||||
|
alias mysqlstatus='mysqladmin5 -u root -p ping'
|
@ -1,6 +0,0 @@
|
|||||||
# commands to control local mysql-server installation
|
|
||||||
# paths are for osx installtion via macports
|
|
||||||
|
|
||||||
alias mysqlstart='sudo /opt/local/bin/mysqld_safe5'
|
|
||||||
alias mysqlstop='/opt/local/bin/mysqladmin5 -u root -p shutdown'
|
|
||||||
alias mysqlstatus='mysqladmin5 -u root -p ping'
|
|
@ -1,10 +1,30 @@
|
|||||||
alias rs='ruby script/rails server'
|
# Rails 3 aliases, backwards-compatible with Rails 2.
|
||||||
alias rg='ruby script/rails generate'
|
|
||||||
alias rd='ruby script/rails destroy'
|
function _bundle_command {
|
||||||
alias rp='ruby script/rails plugin'
|
if command -v bundle && [ -e "Gemfile" ]; then
|
||||||
|
bundle exec $@
|
||||||
|
else
|
||||||
|
$@
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
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 rdbm='rake db:migrate db:test:clone'
|
||||||
alias rdbmr='rake db:migrate && rake db:migrate:redo'
|
alias rg='_rails_command generate'
|
||||||
alias rc='ruby script/rails console'
|
alias rp='_rails_command plugin'
|
||||||
alias rd='ruby script/rails server --debugger'
|
alias rs='_rails_command server'
|
||||||
|
alias rsd='_rails_command server --debugger'
|
||||||
alias devlog='tail -f log/development.log'
|
alias devlog='tail -f log/development.log'
|
||||||
|
|
||||||
|
alias rspec='_bundle_command rspec'
|
||||||
|
alias cuke='_bundle_command cucumber'
|
||||||
|
@ -0,0 +1,142 @@
|
|||||||
|
#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'
|
||||||
|
'linset: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
|
@ -0,0 +1,12 @@
|
|||||||
|
## Aliases
|
||||||
|
|
||||||
|
alias ys="yum search" # search package
|
||||||
|
alias yp="yum info" # show package info
|
||||||
|
alias yl="yum list" # list packages
|
||||||
|
alias yli="yum list installed" # print all installed packages
|
||||||
|
|
||||||
|
alias yu="sudo yum update" # upgrate packages
|
||||||
|
alias yi="sudo yum install" # install package
|
||||||
|
alias yr="sudo yum remove" # remove package
|
||||||
|
alias yrl="sudo yum remove --remove-leaves" # remove package and leaves
|
||||||
|
alias yc="sudo yum clean all" # clean cache
|
@ -0,0 +1,19 @@
|
|||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[green]%}["
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
#Customized git status, oh-my-zsh currently does not allow render dirty status before branch
|
||||||
|
git_custom_status() {
|
||||||
|
local cb=$(current_branch)
|
||||||
|
if [ -n "$cb" ]; then
|
||||||
|
echo "$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_PREFIX$(current_branch)$ZSH_THEME_GIT_PROMPT_SUFFIX"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#RVM and git settings
|
||||||
|
if [[ -s ~/.rvm/scripts/rvm ]] ; then
|
||||||
|
RPS1='$(git_custom_status)%{$fg[red]%}[`~/.rvm/bin/rvm-prompt`]%{$reset_color%} $EPS1'
|
||||||
|
fi
|
||||||
|
|
||||||
|
PROMPT='%{$fg[cyan]%}[%~% ]%(?.%{$fg[green]%}.%{$fg[red]%})%B$%b '
|
@ -0,0 +1,137 @@
|
|||||||
|
function precmd {
|
||||||
|
local TERMWIDTH
|
||||||
|
(( TERMWIDTH = ${COLUMNS} - 1 ))
|
||||||
|
|
||||||
|
|
||||||
|
###
|
||||||
|
# Truncate the path if it's too long.
|
||||||
|
|
||||||
|
PR_FILLBAR=""
|
||||||
|
PR_PWDLEN=""
|
||||||
|
|
||||||
|
local promptsize=${#${(%):---(%n@%m:%l)---()--}}
|
||||||
|
local rubyprompt=`rvm_prompt_info`
|
||||||
|
local rubypromptsize=${#${rubyprompt}}
|
||||||
|
local pwdsize=${#${(%):-%~}}
|
||||||
|
|
||||||
|
if [[ "$promptsize + $rubypromptsize + $pwdsize" -gt $TERMWIDTH ]]; then
|
||||||
|
((PR_PWDLEN=$TERMWIDTH - $promptsize))
|
||||||
|
else
|
||||||
|
PR_FILLBAR="\${(l.(($TERMWIDTH - ($promptsize + $rubypromptsize + $pwdsize)))..${PR_HBAR}.)}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
setopt extended_glob
|
||||||
|
preexec () {
|
||||||
|
if [[ "$TERM" == "screen" ]]; then
|
||||||
|
local CMD=${1[(wr)^(*=*|sudo|-*)]}
|
||||||
|
echo -n "\ek$CMD\e\\"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
setprompt () {
|
||||||
|
###
|
||||||
|
# Need this so the prompt will work.
|
||||||
|
|
||||||
|
setopt prompt_subst
|
||||||
|
|
||||||
|
|
||||||
|
###
|
||||||
|
# See if we can use colors.
|
||||||
|
|
||||||
|
autoload colors zsh/terminfo
|
||||||
|
if [[ "$terminfo[colors]" -ge 8 ]]; then
|
||||||
|
colors
|
||||||
|
fi
|
||||||
|
for color in RED GREEN YELLOW BLUE MAGENTA CYAN WHITE GREY; do
|
||||||
|
eval PR_$color='%{$terminfo[bold]$fg[${(L)color}]%}'
|
||||||
|
eval PR_LIGHT_$color='%{$fg[${(L)color}]%}'
|
||||||
|
(( count = $count + 1 ))
|
||||||
|
done
|
||||||
|
PR_NO_COLOUR="%{$terminfo[sgr0]%}"
|
||||||
|
|
||||||
|
###
|
||||||
|
# Modify Git prompt
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" on %{$fg[green]%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭"
|
||||||
|
|
||||||
|
###
|
||||||
|
# See if we can use extended characters to look nicer.
|
||||||
|
|
||||||
|
typeset -A altchar
|
||||||
|
set -A altchar ${(s..)terminfo[acsc]}
|
||||||
|
PR_SET_CHARSET="%{$terminfo[enacs]%}"
|
||||||
|
PR_SHIFT_IN="%{$terminfo[smacs]%}"
|
||||||
|
PR_SHIFT_OUT="%{$terminfo[rmacs]%}"
|
||||||
|
PR_HBAR=${altchar[q]:--}
|
||||||
|
PR_ULCORNER=${altchar[l]:--}
|
||||||
|
PR_LLCORNER=${altchar[m]:--}
|
||||||
|
PR_LRCORNER=${altchar[j]:--}
|
||||||
|
PR_URCORNER=${altchar[k]:--}
|
||||||
|
|
||||||
|
|
||||||
|
###
|
||||||
|
# Decide if we need to set titlebar text.
|
||||||
|
|
||||||
|
case $TERM in
|
||||||
|
xterm*)
|
||||||
|
PR_TITLEBAR=$'%{\e]0;%(!.-=*[ROOT]*=- | .)%n@%m:%~ | ${COLUMNS}x${LINES} | %y\a%}'
|
||||||
|
;;
|
||||||
|
screen)
|
||||||
|
PR_TITLEBAR=$'%{\e_screen \005 (\005t) | %(!.-=[ROOT]=- | .)%n@%m:%~ | ${COLUMNS}x${LINES} | %y\e\\%}'
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
PR_TITLEBAR=''
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
|
||||||
|
###
|
||||||
|
# Decide whether to set a screen title
|
||||||
|
if [[ "$TERM" == "screen" ]]; then
|
||||||
|
PR_STITLE=$'%{\ekzsh\e\\%}'
|
||||||
|
else
|
||||||
|
PR_STITLE=''
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
###
|
||||||
|
# Finally, the prompt.
|
||||||
|
|
||||||
|
PROMPT='$PR_SET_CHARSET$PR_STITLE${(e)PR_TITLEBAR}\
|
||||||
|
$PR_CYAN$PR_SHIFT_IN$PR_ULCORNER$PR_HBAR$PR_SHIFT_OUT$PR_GREY(\
|
||||||
|
$PR_GREEN%$PR_PWDLEN<...<%~%<<\
|
||||||
|
$PR_GREY)`rvm_prompt_info`$PR_CYAN$PR_SHIFT_IN$PR_HBAR$PR_HBAR${(e)PR_FILLBAR}$PR_HBAR$PR_SHIFT_OUT$PR_GREY(\
|
||||||
|
$PR_CYAN%(!.%SROOT%s.%n)$PR_GREY@$PR_GREEN%m:%l\
|
||||||
|
$PR_GREY)$PR_CYAN$PR_SHIFT_IN$PR_HBAR$PR_URCORNER$PR_SHIFT_OUT\
|
||||||
|
|
||||||
|
$PR_CYAN$PR_SHIFT_IN$PR_LLCORNER$PR_BLUE$PR_HBAR$PR_SHIFT_OUT(\
|
||||||
|
$PR_YELLOW%D{%H:%M:%S}\
|
||||||
|
$PR_LIGHT_BLUE%{$reset_color%}`git_prompt_info``git_prompt_status`$PR_BLUE)$PR_CYAN$PR_SHIFT_IN$PR_HBAR\
|
||||||
|
$PR_SHIFT_IN$PR_HBAR$PR_SHIFT_OUT\
|
||||||
|
>$PR_NO_COLOUR '
|
||||||
|
|
||||||
|
# display exitcode on the right when >0
|
||||||
|
return_code="%(?..%{$fg[red]%}%? ↵ %{$reset_color%})"
|
||||||
|
RPROMPT=' $return_code$PR_CYAN$PR_SHIFT_IN$PR_HBAR$PR_BLUE$PR_HBAR$PR_SHIFT_OUT\
|
||||||
|
($PR_YELLOW%D{%a,%b%d}$PR_BLUE)$PR_SHIFT_IN$PR_HBAR$PR_CYAN$PR_LRCORNER$PR_SHIFT_OUT$PR_NO_COLOUR'
|
||||||
|
|
||||||
|
PS2='$PR_CYAN$PR_SHIFT_IN$PR_HBAR$PR_SHIFT_OUT\
|
||||||
|
$PR_BLUE$PR_SHIFT_IN$PR_HBAR$PR_SHIFT_OUT(\
|
||||||
|
$PR_LIGHT_GREEN%_$PR_BLUE)$PR_SHIFT_IN$PR_HBAR$PR_SHIFT_OUT\
|
||||||
|
$PR_CYAN$PR_SHIFT_IN$PR_HBAR$PR_SHIFT_OUT$PR_NO_COLOUR '
|
||||||
|
}
|
||||||
|
|
||||||
|
setprompt
|
@ -0,0 +1,8 @@
|
|||||||
|
#PROMPT='%{$fg_bold[red]%}➜ %{$fg_bold[green]%}%p %{$fg[cyan]%}%c %{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%} % %{$reset_color%}'
|
||||||
|
PROMPT="%{$fg_bold[cyan]%}%T%{$fg_bold[green]%} %{$fg_bold[white]%}%n%{$fg[magenta]%}@%{$fg_bold[white]%}%m %{$fg_bold[green]%}%d
|
||||||
|
%{$fg_bold[yellow]%}%% $(git_prompt_info)%{$reset_color%}"
|
||||||
|
|
||||||
|
#ZSH_THEME_GIT_PROMPT_PREFIX="git:(%{$fg[red]%}"
|
||||||
|
#ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}"
|
||||||
|
#ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}✗%{$reset_color%}"
|
||||||
|
#ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[blue]%})"
|
@ -0,0 +1,46 @@
|
|||||||
|
# ------------------------------------------------------------------------
|
||||||
|
# Juan G. Hurtado oh-my-zsh theme
|
||||||
|
# (Needs Git plugin for current_branch method)
|
||||||
|
# ------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Color shortcuts
|
||||||
|
RED=$fg[red]
|
||||||
|
YELLOW=$fg[yellow]
|
||||||
|
GREEN=$fg[green]
|
||||||
|
WHITE=$fg[white]
|
||||||
|
BLUE=$fg[blue]
|
||||||
|
RED_BOLD=$fg_bold[red]
|
||||||
|
YELLOW_BOLD=$fg_bold[yellow]
|
||||||
|
GREEN_BOLD=$fg_bold[green]
|
||||||
|
WHITE_BOLD=$fg_bold[white]
|
||||||
|
BLUE_BOLD=$fg_bold[blue]
|
||||||
|
RESET_COLOR=$reset_color
|
||||||
|
|
||||||
|
# Format for git_prompt_info()
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=""
|
||||||
|
|
||||||
|
# Format for parse_git_dirty()
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=" %{$RED%}(*)"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=""
|
||||||
|
|
||||||
|
# Format for git_prompt_status()
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED=" %{$RED%}unmerged"
|
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED=" %{$RED%}deleted"
|
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED=" %{$YELLOW%}renamed"
|
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED=" %{$YELLOW%}modified"
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED=" %{$GREEN%}added"
|
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED=" %{$WHITE%}untracked"
|
||||||
|
|
||||||
|
# Format for git_prompt_ahead()
|
||||||
|
ZSH_THEME_GIT_PROMPT_AHEAD=" %{$RED%}(!)"
|
||||||
|
|
||||||
|
# Format for git_prompt_long_sha() and git_prompt_short_sha()
|
||||||
|
ZSH_THEME_GIT_PROMPT_SHA_BEFORE=" %{$WHITE%}[%{$YELLOW%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_SHA_AFTER="%{$WHITE%}]"
|
||||||
|
|
||||||
|
# Prompt format
|
||||||
|
PROMPT='
|
||||||
|
%{$GREEN_BOLD%}%n@%m%{$WHITE%}:%{$YELLOW%}%~%u$(parse_git_dirty)$(git_prompt_ahead)%{$RESET_COLOR%}
|
||||||
|
%{$BLUE%}>%{$RESET_COLOR%} '
|
||||||
|
RPROMPT='%{$GREEN_BOLD%}$(current_branch)$(git_prompt_short_sha)$(git_prompt_status)%{$RESET_COLOR%}'
|
@ -0,0 +1,14 @@
|
|||||||
|
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||||
|
local user_host='%{$terminfo[bold]$fg[green]%}%n@%m%{$reset_color%}'
|
||||||
|
local current_dir='%{$terminfo[bold]$fg[blue]%}%~%{$reset_color%}'
|
||||||
|
local rvm_ruby='%{$fg[red]%}$(rvm_prompt_info)%{$reset_color%}'
|
||||||
|
local git_branch='%{$fg[blue]%}$(git_prompt_info)%{$reset_color%}'
|
||||||
|
|
||||||
|
PROMPT="${user_host}:${current_dir} ${rvm_ruby}
|
||||||
|
${git_branch} %B$%b "
|
||||||
|
RPS1="${return_code}"
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX=""
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=" %{$fg[red]%}✗%{$reset_color%}"
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=" %{$fg[green]%}✔%{$reset_color%}"
|
Loading…
Reference in new issue