diff options
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/bundler/bundler.plugin.zsh | 48 | ||||
| -rw-r--r-- | plugins/chruby/chruby.plugin.zsh | 99 | ||||
| -rw-r--r-- | plugins/heroku/_heroku | 6 | ||||
| -rw-r--r-- | plugins/jira/jira.plugin.zsh | 2 | ||||
| -rw-r--r-- | plugins/osx/osx.plugin.zsh | 34 | ||||
| -rw-r--r-- | plugins/pass/_pass | 2 | ||||
| -rw-r--r-- | plugins/pip/_pip | 4 | ||||
| -rw-r--r-- | plugins/pip/pip.plugin.zsh | 78 | ||||
| -rw-r--r-- | plugins/pod/_pod | 16 | ||||
| -rw-r--r-- | plugins/pyenv/pyenv.plugin.zsh | 31 | ||||
| -rw-r--r-- | plugins/python/python.plugin.zsh | 1 | ||||
| -rw-r--r-- | plugins/rails/_rails (renamed from plugins/rails3/_rails3) | 17 | ||||
| -rw-r--r-- | plugins/rails/rails.plugin.zsh | 68 | ||||
| -rw-r--r-- | plugins/rails3/rails3.plugin.zsh | 36 | ||||
| -rw-r--r-- | plugins/rails4/rails4.plugin.zsh | 36 | ||||
| -rw-r--r-- | plugins/ssh-agent/ssh-agent.plugin.zsh | 2 | ||||
| -rw-r--r-- | plugins/terminalapp/terminalapp.plugin.zsh | 2 | ||||
| -rwxr-xr-x | plugins/wd2/wd2/wd.plugin.zsh | 9 | ||||
| -rwxr-xr-x | plugins/wd2/wd2/wd.sh | 201 | 
19 files changed, 579 insertions, 113 deletions
| diff --git a/plugins/bundler/bundler.plugin.zsh b/plugins/bundler/bundler.plugin.zsh index 2e657e5a8..e390f8620 100644 --- a/plugins/bundler/bundler.plugin.zsh +++ b/plugins/bundler/bundler.plugin.zsh @@ -4,18 +4,6 @@ alias bp="bundle package"  alias bo="bundle open"  alias bu="bundle update" -bundler_version=`bundle version | cut -d' ' -f3` -if [[ $bundler_version > '1.4.0' || $bundler_version = '1.4.0' ]]; then -  if [[ "$(uname)" == 'Darwin' ]] -  then -    local cores_num="$(sysctl hw.ncpu | awk '{print $2}')" -  else -    local cores_num="$(nproc)" -  fi -  eval "alias bi='bundle install --jobs=$cores_num'" -else -  alias bi='bundle install'  -fi  # The following is based on https://github.com/gma/bundler-exec @@ -44,14 +32,28 @@ _run-with-bundler() {    fi  } -## Main program -for cmd in $bundled_commands; do -  eval "function unbundled_$cmd () { $cmd \$@ }" -  eval "function bundled_$cmd () { _run-with-bundler $cmd \$@}" -  alias $cmd=bundled_$cmd - -  if which _$cmd > /dev/null 2>&1; then -        compdef _$cmd bundled_$cmd=$cmd -  fi -done - +if _bundler-installed; then +	bundler_version=`bundle version | cut -d' ' -f3` +	if [[ $bundler_version > '1.4.0' || $bundler_version = '1.4.0' ]]; then +		if [[ "$(uname)" == 'Darwin' ]] +		then +			local cores_num="$(sysctl hw.ncpu | awk '{print $2}')" +		else +			local cores_num="$(nproc)" +		fi +		eval "alias bi='bundle install --jobs=$cores_num'" +	else +		alias bi='bundle install'  +	fi + +	## Main program +	for cmd in $bundled_commands; do +		eval "function unbundled_$cmd () { $cmd \$@ }" +		eval "function bundled_$cmd () { _run-with-bundler $cmd \$@}" +		alias $cmd=bundled_$cmd + +		if which _$cmd > /dev/null 2>&1; then +			compdef _$cmd bundled_$cmd=$cmd +		fi +	done +fi diff --git a/plugins/chruby/chruby.plugin.zsh b/plugins/chruby/chruby.plugin.zsh new file mode 100644 index 000000000..2a2c80cf6 --- /dev/null +++ b/plugins/chruby/chruby.plugin.zsh @@ -0,0 +1,99 @@ +# +# INSTRUCTIONS +# +#  With either a manual or brew installed chruby things should just work. +# +#  If you'd prefer to specify an explicit path to load chruby from +#  you can set variables like so: +# +#    zstyle :omz:plugins:chruby path /local/path/to/chruby.sh +#    zstyle :omz:plugins:chruby auto /local/path/to/auto.sh +#  +# TODO +#  - autodetermine correct source path on non OS X systems +#  - completion if ruby-install exists + +# rvm and rbenv plugins also provide this alias +alias rubies='chruby' + +local _chruby_path +local _chruby_auto + +_homebrew-installed() { +    whence brew &> /dev/null +} + +_chruby-from-homebrew-installed() { +    brew --prefix chruby &> /dev/null +} + +_ruby-build_installed() { +    whence ruby-build &> /dev/null +} + +_ruby-install-installed() { +    whence ruby-install &> /dev/null +} + +# Simple definition completer for ruby-build +if _ruby-build_installed; then +    _ruby-build() { compadd $(ruby-build --definitions) } +    compdef _ruby-build ruby-build +fi + +_source_from_omz_settings() { +    zstyle -s :omz:plugins:chruby path _chruby_path +    zstyle -s :omz:plugins:chruby auto _chruby_auto + +    if _chruby_path && [[ -r _chruby_path ]]; then +        source ${_chruby_path} +    fi + +    if _chruby_auto && [[ -r _chruby_auto ]]; then +        source ${_chruby_auto} +    fi +} + +_chruby_dirs() { +    chrubydirs=($HOME/.rubies/ $PREFIX/opt/rubies) +    for dir in chrubydirs; do +        if [[ -d $dir ]]; then +            RUBIES+=$dir +        fi +    done +} + +if _homebrew-installed && _chruby-from-homebrew-installed ; then +    source $(brew --prefix chruby)/share/chruby/chruby.sh +    source $(brew --prefix chruby)/share/chruby/auto.sh +    _chruby_dirs +elif [[ -r "/usr/local/share/chruby/chruby.sh" ]] ; then +    source /usr/local/share/chruby/chruby.sh +    source /usr/local/share/chruby/auto.sh +    _chruby_dirs +else +    _source_from_omz_settings +    _chruby_dirs +fi + +function ensure_chruby() { +    $(whence chruby) +} + +function current_ruby() { +    local _ruby +    _ruby="$(chruby |grep \* |tr -d '* ')" +    if [[ $(chruby |grep -c \*) -eq 1 ]]; then +        echo ${_ruby} +    else +        echo "system" +    fi +} + +function chruby_prompt_info() { +    echo "$(current_ruby)" +} + +# complete on installed rubies +_chruby() { compadd $(chruby | tr -d '* ') } +compdef _chruby chruby diff --git a/plugins/heroku/_heroku b/plugins/heroku/_heroku index a95c38647..46663303a 100644 --- a/plugins/heroku/_heroku +++ b/plugins/heroku/_heroku @@ -23,8 +23,10 @@ _1st_arguments=(    "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" +  "config\:pull":"pull heroku config vars down to the local environment" +  "config\:push":"push local config vars to heroku" +  "config\:set":"set one or more config vars" +  "config\:unset":"unset one or more config vars"    "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" diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index 9aa192c1e..739ee7142 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -31,7 +31,7 @@ open_jira_issue () {    if [ -z "$1" ]; then      echo "Opening new issue" -    `open $jira_url/secure/CreateIssue!default.jspa` +    $open_cmd "$jira_url/secure/CreateIssue!default.jspa"    else      echo "Opening issue #$1"      if [[ "x$JIRA_RAPID_BOARD" = "xtrue" ]]; then diff --git a/plugins/osx/osx.plugin.zsh b/plugins/osx/osx.plugin.zsh index dd785f911..608ec3789 100644 --- a/plugins/osx/osx.plugin.zsh +++ b/plugins/osx/osx.plugin.zsh @@ -157,3 +157,37 @@ function trash() {  function vncviewer() {    open vnc://$@  } + +# iTunes control function +function itunes() { +	local opt=$1 +	shift +	case "$opt" in +		launch|play|pause|stop|rewind|resume|quit) +			;; +		mute) +			opt="set mute to true" +			;; +		unmute) +			opt="set mute to false" +			;; +		next|previous) +			opt="$opt track" +			;; +		""|-h|--help) +			echo "Usage: itunes <option>" +			echo "option:" +			echo "\tlaunch|play|pause|stop|rewind|resume|quit" +			echo "\tmute|unmute\tcontrol volume set" +			echo "\tnext|previous\tplay next or previous track" +			echo "\thelp\tshow this message and exit" +			return 0 +			;; +		*) +			print "Unkonwn option: $opt" +			return 1 +			;; +	esac +	osascript -e "tell application \"iTunes\" to $opt" +} + diff --git a/plugins/pass/_pass b/plugins/pass/_pass index f6c1a6c4b..d8ec38828 100644 --- a/plugins/pass/_pass +++ b/plugins/pass/_pass @@ -101,7 +101,7 @@ _pass_cmd_show () {  _pass_complete_entries_helper () {  	local IFS=$'\n'  	local prefix="${PASSWORD_STORE_DIR:-$HOME/.password-store}" -	_values -C 'passwords' $(find "$prefix" \( -name .git -o -name .gpg-id \) -prune -o $@ -print | sed -e "s#${prefix}.##" -e 's#\.gpg##' | sort) +	_values -C 'passwords' $(find -L "$prefix" \( -name .git -o -name .gpg-id \) -prune -o $@ -print | sed -e "s#${prefix}.##" -e 's#\.gpg##' | sort)  }  _pass_complete_entries_with_subdirs () { diff --git a/plugins/pip/_pip b/plugins/pip/_pip index fb8765c7e..967da48ca 100644 --- a/plugins/pip/_pip +++ b/plugins/pip/_pip @@ -6,8 +6,8 @@  _pip_all() {    # we cache the list of packages (originally from the macports plugin)    if (( ! $+piplist )); then -      echo -n " (caching package index...)" -      piplist=($(pip search * | cut -d ' ' -f 1 | tr '[A-Z]' '[a-z]')) +      zsh-pip-cache-packages +      piplist=($(cat $ZSH_PIP_CACHE_FILE))    fi  } diff --git a/plugins/pip/pip.plugin.zsh b/plugins/pip/pip.plugin.zsh new file mode 100644 index 000000000..b5433ae9d --- /dev/null +++ b/plugins/pip/pip.plugin.zsh @@ -0,0 +1,78 @@ +# Usage: +# Just add pip to your installed plugins. + +# If you would like to change the cheeseshops used for autocomplete set +# ZSH_PIP_INDEXES in your zshrc. If one of your indexes are bogus you won't get +# any kind of error message, pip will just not autocomplete from them. Double +# check! +# +# If you would like to clear your cache, go ahead and do a +# "zsh-pip-clear-cache". + +ZSH_PIP_CACHE_FILE=~/.pip/zsh-cache +ZSH_PIP_INDEXES=(https://pypi.python.org/simple/) + +zsh-pip-clear-cache() { +  rm $ZSH_PIP_CACHE_FILE +  unset piplist +} + +zsh-pip-clean-packages() { +    sed -n '/<a href/ s/.*>\([^<]\{1,\}\).*/\1/p' +} + +zsh-pip-cache-packages() { +  if [[ ! -d ${ZSH_PIP_CACHE_FILE:h} ]]; then +      mkdir -p ${ZSH_PIP_CACHE_FILE:h} +  fi + +  if [[ ! -f $ZSH_PIP_CACHE_FILE ]]; then +      echo -n "(...caching package index...)" +      tmp_cache=/tmp/zsh_tmp_cache +      for index in $ZSH_PIP_INDEXES ; do +          # well... I've already got two problems +          curl $index 2>/dev/null | \ +              zsh-pip-clean-packages \ +               >> $tmp_cache +      done +      sort $tmp_cache | uniq | tr '\n' ' ' > $ZSH_PIP_CACHE_FILE +      rm $tmp_cache +  fi +} + +# A test function that validates the regex against known forms of the simple +# index. If you modify the regex to make it work for you, you should add a test +# case in here and make sure that your changes don't break things for someone +# else. +zsh-pip-test-clean-packages() { +    local expected +    local actual +    expected="0x10c-asm +1009558_nester" + +    actual=$(echo -n "<html><head><title>Simple Index</title><meta name=\"api-version\" value=\"2\" /></head><body> +<a href='0x10c-asm'>0x10c-asm</a><br/> +<a href='1009558_nester'>1009558_nester</a><br/> +</body></html>" | zsh-pip-clean-packages) + +    if [[ $actual != $expected ]] ; then +        echo -e "python's simple index is broken:\n$actual\n  !=\n$expected" +    else +        echo "python's simple index is fine" +    fi + +    actual=$(echo -n '<html> +  <head> +    <title>Simple Package Index</title> +  </head> +  <body> +    <a href="0x10c-asm">0x10c-asm</a><br/> +    <a href="1009558_nester">1009558_nester</a><br/> +</body></html>' | zsh-pip-clean-packages) + +    if [[ $actual != $expected ]] ; then +        echo -e "the djangopypi2 index is broken:\n$actual\n  !=\n$expected" +    else +        echo "the djangopypi2 index is fine" +    fi +} diff --git a/plugins/pod/_pod b/plugins/pod/_pod index 563fa5e66..8c0f4460f 100644 --- a/plugins/pod/_pod +++ b/plugins/pod/_pod @@ -3,18 +3,19 @@  # -----------------------------------------------------------------------------  #          FILE:  _pod -#   DESCRIPTION:  Cocoapods autocomplete plugin for Oh-My-Zsh +#   DESCRIPTION:  Cocoapods (0.27.1) autocomplete plugin for Oh-My-Zsh  #                 http://cocoapods.org  #        AUTHOR:  Alexandre Joly (alexandre.joly@mekanics.ch)  #        GITHUB:  https://github.com/mekanics  #       TWITTER:  @jolyAlexandre -#       VERSION:  0.0.1 +#       VERSION:  0.0.3  #       LICENSE:  MIT  # -----------------------------------------------------------------------------  local -a _1st_arguments  _1st_arguments=( -    'help:Show help for the given command.' +    'help:Show help for the given command' +    'init:Generate a Podfile for the current directory'      'install:Install project dependencies'      'ipc:Inter-process communication'      'list:List pods' @@ -32,6 +33,7 @@ local -a _repo_arguments  _repo_arguments=(      'add:Add a spec repo'      'lint:Validates all specs in a repo' +    'remove:Remove a spec repo.'      'update:Update a spec repo'  ) @@ -158,7 +160,7 @@ __first_command_list ()  }  __repo_list() { -    _wanted application expl 'repo' compadd $(command ls -1 ~/.cocoapods 2>/dev/null | sed -e 's/ /\\ /g') +    _wanted application expl 'repo' compadd $(command ls -1 ~/.cocoapods/repos 2>/dev/null | sed -e 's/ /\\ /g')  }  __pod-repo() { @@ -193,6 +195,12 @@ __pod-repo() {                  (add)                      _arguments \                          $_inherited_options + +                (remove) +                    _arguments \ +                        $_inherited_options \ +                        ':feature:__repo_list' +                ;;              esac          ;;      esac diff --git a/plugins/pyenv/pyenv.plugin.zsh b/plugins/pyenv/pyenv.plugin.zsh new file mode 100644 index 000000000..b3dc7aa17 --- /dev/null +++ b/plugins/pyenv/pyenv.plugin.zsh @@ -0,0 +1,31 @@ +_homebrew-installed() { +    type brew &> /dev/null +} + +_pyenv-from-homebrew-installed() { +    brew --prefix pyenv &> /dev/null +} + +FOUND_PYENV=0 +pyenvdirs=("$HOME/.pyenv" "/usr/local/pyenv" "/opt/pyenv") +if _homebrew-installed && _pyenv-from-homebrew-installed ; then +    pyenvdirs=($(brew --prefix pyenv) "${pyenvdirs[@]}") +fi + +for pyenvdir in "${pyenvdirs[@]}" ; do +    if [ -d $pyenvdir/bin -a $FOUND_PYENV -eq 0 ] ; then +        FOUND_PYENV=1 +        export PYENV_ROOT=$pyenvdir +        export PATH=${pyenvdir}/bin:$PATH +        eval "$(pyenv init --no-rehash - zsh)" + +        function pyenv_prompt_info() { +            echo "$(pyenv version-name)" +        } +    fi +done +unset pyenvdir + +if [ $FOUND_PYENV -eq 0 ] ; then +    function pyenv_prompt_info() { echo "system: $(python -V 2>&1 | cut -f 2 -d ' ')" } +fi diff --git a/plugins/python/python.plugin.zsh b/plugins/python/python.plugin.zsh index 852c8b919..a8f9760ad 100644 --- a/plugins/python/python.plugin.zsh +++ b/plugins/python/python.plugin.zsh @@ -6,6 +6,7 @@ alias pyfind='find . -name "*.py"'  function pyclean() {      ZSH_PYCLEAN_PLACES=${*:-'.'}      find ${ZSH_PYCLEAN_PLACES} -type f -name "*.py[co]" -delete +    find ${ZSH_PYCLEAN_PLACES} -type d -name "__pycache__" -delete  }  # Grep among .py files diff --git a/plugins/rails3/_rails3 b/plugins/rails/_rails index 97915e68b..96f57ce64 100644 --- a/plugins/rails3/_rails3 +++ b/plugins/rails/_rails @@ -1,10 +1,6 @@  #compdef rails  #autoload -# rails 3 zsh completion, based on homebrew completion -# Extracted from https://github.com/robbyrussell/oh-my-zsh/blob/30620d463850c17f86e7a56fbf6a8b5e793a4e07/plugins/rails3/_rails3 -# Published by Christopher Chow -  local -a _1st_arguments  _1st_arguments=(      'generate:Generate new code (short-cut alias: "g")' @@ -14,14 +10,20 @@ _1st_arguments=(      'new:Create a new Rails application. "rails new my_app" creates a new application called MyApp in "./my_app"'      'application:Generate the Rails application code'      'destroy:Undo code generated with "generate"' +      'benchmarker:See how fast a piece of code runs'      'profiler:Get profile information from a piece of code'      'plugin:Install a plugin' + +    'plugin new:Generates skeleton for developing a Rails plugin' +    'runner:Run a piece of code in the application environment (short-cut alias: "r")'  )  _rails_generate_arguments() {      generate_arguments=( +        assets          controller +        decorator          generator          helper          integration_test @@ -36,9 +38,11 @@ _rails_generate_arguments() {          scaffold_controller          session_migration          stylesheets +        task      )  } +  _arguments \      '(--version)--version[show version]' \      '(--help)--help[show help]' \ @@ -50,7 +54,10 @@ if (( CURRENT == 1 )); then  fi  case "$words[1]" in -  generate) +  g|generate) +    _rails_generate_arguments +    _wanted generate_arguments expl 'all generate' compadd -a generate_arguments ;; +  d|destroy)      _rails_generate_arguments      _wanted generate_arguments expl 'all generate' compadd -a generate_arguments ;;  esac diff --git a/plugins/rails/rails.plugin.zsh b/plugins/rails/rails.plugin.zsh index dd8b174b2..23d15a9a1 100644 --- a/plugins/rails/rails.plugin.zsh +++ b/plugins/rails/rails.plugin.zsh @@ -1,20 +1,70 @@ +function _rails_command () { +  if [ -e "script/server" ]; then +    ruby script/$@ +  elif [ -e "script/rails" ]; then +    ruby script/rails $@ +  elif [ -e "bin/rails" ]; then +    bin/rails $@ +  else +    rails $@ +  fi +} + +function _rake_command () { +  if [ -e "bin/rake" ]; then +    bin/rake $@ +  else +    rake $@ +  fi +} + +alias rails='_rails_command' +compdef _rails_command=rails + +alias rake='_rake_command' +compdef _rake_command=rake + +alias devlog='tail -f log/development.log' +alias prodlog='tail -f log/production.log' +alias testlog='tail -f log/test.log' + +alias -g RED='RAILS_ENV=development' +alias -g REP='RAILS_ENV=production' +alias -g RET='RAILS_ENV=test' + +# Rails aliases +alias rc='rails console' +alias rd='rails destroy' +alias rdb='rails dbconsole' +alias rg='rails generate' +alias rgm='rails generate migration' +alias rp='rails plugin' +alias ru='rails runner' +alias rs='rails server' +alias rsd='rails server --debugger' + +# Rake aliases +alias rdm='rake db:migrate' +alias rdr='rake db:rollback' +alias rdc='rake db:create' +alias rds='rake db:seed' +alias rdd='rake db:drop' +alias rdtc='rake db:test:clone' +alias rdtp='rake db:test:prepare' + +alias rlc='rake log:clear' +alias rn='rake notes' +alias rr='rake routes' + +# legacy stuff  alias ss='thin --stats "/thin/stats" start'  alias sg='ruby script/generate'  alias sd='ruby script/destroy'  alias sp='ruby script/plugin'  alias sr='ruby script/runner'  alias ssp='ruby script/spec' -alias rdbm='rake db:migrate' -alias rdbtp='rake db:test:prepare' -alias migrate='rake db:migrate && rake db:test:prepare'  alias sc='ruby script/console'  alias sd='ruby script/server --debugger' -alias devlog='tail -f log/development.log' -alias testlog='tail -f log/test.log' -alias prodlog='tail -f log/production.log' -alias -g RET='RAILS_ENV=test' -alias -g REP='RAILS_ENV=production' -alias -g RED='RAILS_ENV=development'  function remote_console() {    /usr/bin/env ssh $1 "( cd $2 && ruby script/console production )" diff --git a/plugins/rails3/rails3.plugin.zsh b/plugins/rails3/rails3.plugin.zsh index b53d18d08..261b92108 100644 --- a/plugins/rails3/rails3.plugin.zsh +++ b/plugins/rails3/rails3.plugin.zsh @@ -1,32 +1,4 @@ -# Rails 3 aliases, backwards-compatible with Rails 2. - -function _rails_command () { -  if [ -e "script/server" ]; then -    ruby script/$@ -  else -    if [ -e "bin/rails" ]; then -      bin/rails $@ -    else -      rails $@ -    fi -  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 rgm='_rails_command generate migration' -alias rp='_rails_command plugin' -alias ru='_rails_command runner' -alias rs='_rails_command server' -alias rsd='_rails_command server --debugger' -alias devlog='tail -f log/development.log' -alias testlog='tail -f log/test.log' -alias prodlog='tail -f log/production.log' -alias rdm='rake db:migrate' -alias rdr='rake db:rollback' -alias -g RET='RAILS_ENV=test' -alias -g REP='RAILS_ENV=production' -alias -g RED='RAILS_ENV=development' +echo "It looks like you have been using the 'rails3' plugin," +echo "which has been deprecated in favor of a newly consolidated 'rails' plugin." +echo "You will want to modify your ~/.zshrc configuration to begin using it." +echo "Learn more at https://github.com/robbyrussell/oh-my-zsh/pull/2240" diff --git a/plugins/rails4/rails4.plugin.zsh b/plugins/rails4/rails4.plugin.zsh index cb6cf816d..5452c242c 100644 --- a/plugins/rails4/rails4.plugin.zsh +++ b/plugins/rails4/rails4.plugin.zsh @@ -1,32 +1,4 @@ -# Rails 4 aliases - -function _rails_command () { -  if [ -e "script/server" ]; then -    ruby script/$@ -  elif [ -e "script/rails" ]; then -    ruby script/rails $@ -  else -    ruby bin/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 rgm='_rails_command generate migration' -alias rp='_rails_command plugin' -alias ru='_rails_command runner' -alias rs='_rails_command server' -alias rsd='_rails_command server --debugger' -alias devlog='tail -f log/development.log' -alias testlog='tail -f log/test.log' -alias prodlog='tail -f log/production.log' -alias rdm='rake db:migrate' -alias rdc='rake db:create' -alias rdr='rake db:rollback' -alias rds='rake db:seed' -alias rlc='rake log:clear' -alias rn='rake notes' -alias rr='rake routes' +echo "It looks like you have been using the 'rails4' plugin," +echo "which has been deprecated in favor of a newly consolidated 'rails' plugin." +echo "You will want to modify your ~/.zshrc configuration to begin using it." +echo "Learn more at https://github.com/robbyrussell/oh-my-zsh/pull/2240" diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index 3b0042a7d..a1e64ad0f 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -57,7 +57,7 @@ if [[ ${_plugin__forwarding} == "yes" && -n "$SSH_AUTH_SOCK" ]]; then  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 || { +  ps x | grep ${SSH_AGENT_PID} | grep ssh-agent > /dev/null || {      _plugin__start_agent;    }  else diff --git a/plugins/terminalapp/terminalapp.plugin.zsh b/plugins/terminalapp/terminalapp.plugin.zsh index 2249b1e2f..6e47ee188 100644 --- a/plugins/terminalapp/terminalapp.plugin.zsh +++ b/plugins/terminalapp/terminalapp.plugin.zsh @@ -32,7 +32,7 @@ if [[ "$TERM_PROGRAM" == "Apple_Terminal" ]] && [[ -z "$INSIDE_EMACS" ]]; then      # Register the function so it is called whenever the working      # directory changes.      autoload add-zsh-hook -    add-zsh-hook chpwd update_terminal_cwd +    add-zsh-hook precmd update_terminal_cwd      # Tell the terminal about the initial directory.      update_terminal_cwd diff --git a/plugins/wd2/wd2/wd.plugin.zsh b/plugins/wd2/wd2/wd.plugin.zsh new file mode 100755 index 000000000..e0846ffd9 --- /dev/null +++ b/plugins/wd2/wd2/wd.plugin.zsh @@ -0,0 +1,9 @@ +#!/bin/zsh + +# WARP +# ==== +# oh-my-zsh plugin +# +# @github.com/mfaerevaag/wd + +alias wd='. ~/.oh-my-zsh/plugins/wd/wd.sh' diff --git a/plugins/wd2/wd2/wd.sh b/plugins/wd2/wd2/wd.sh new file mode 100755 index 000000000..7852028c0 --- /dev/null +++ b/plugins/wd2/wd2/wd.sh @@ -0,0 +1,201 @@ +#!/bin/zsh + +# WARP +# ==== +# Jump to custom directories in terminal +# because `cd` takes too long... +# +# @github.com/mfaerevaag/wd + + +## variables +CONFIG=$HOME/.warprc + +## colors +BLUE="\033[96m" +GREEN="\033[92m" +YELLOW="\033[93m" +RED="\033[91m" +NOC="\033[m" + + +## load warp points +typeset -A points +while read line +do +    arr=(${(s,:,)line}) +    key=${arr[1]} +    val=${arr[2]} + +    points[$key]=$val +done < $CONFIG + + +## functions +# prepended wd_ to not conflict with your environment (no sub shell) + +wd_warp() +{ +    if [[ $1 =~ "^\.+$" ]] +    then +        if [[ $#1 < 2 ]] +        then +            wd_print_msg $YELLOW "Warping to current directory?" +        else +            (( n = $#1 - 1 )) +            wd_print_msg $BLUE "Warping..." +            cd -$n > /dev/null +        fi +    elif [[ ${points[$1]} != "" ]] +    then +        wd_print_msg $BLUE "Warping..." +        cd ${points[$1]} +    else +        wd_print_msg $RED "Unkown warp point '$1'" +    fi +} + +wd_add() +{ +    if [[ $1 =~ "^\.+$" ]] +    then +        wd_print_msg $RED "Illeagal warp point (see README)." +    elif [[ ${points[$1]} == "" ]] || $2 +    then +        wd_remove $1 > /dev/null +        print "$1:$PWD" >> $CONFIG +        wd_print_msg $GREEN "Warp point added" +    else +        wd_print_msg $YELLOW "Warp point '$1' alredy exists. Use 'add!' to overwrite." +    fi +} + +wd_remove() +{ +    if [[ ${points[$1]} != "" ]] +    then +        if wd_tmp=`sed "/^$1:/d" $CONFIG` +        then +            echo $wd_tmp > $CONFIG +            wd_print_msg $GREEN "Warp point removed" +        else +            wd_print_msg $RED "Warp point unsuccessfully removed. Sorry!" +        fi +    else +        wd_print_msg $RED "Warp point was not found" +    fi +} + +wd_show() +{ +    wd_print_msg $BLUE "Warp points to current directory:" +    wd_list_all | grep $PWD$ +} + +wd_list_all() +{ +    wd_print_msg $BLUE "All warp points:" +    while read line +    do +        if [[ $line != "" ]] +        then +            arr=(${(s,:,)line}) +            key=${arr[1]} +            val=${arr[2]} + +            print "\t" $key "\t -> \t" $val +        fi +    done < $CONFIG +} + +wd_print_msg() +{ +    if [[ $1 == "" || $2 == "" ]] +    then +        print " $RED*$NOC Could not print message. Sorry!" +    else +        print " $1*$NOC $2" +    fi +} + +wd_print_usage() +{ +		print "Usage: wd [add|-a|--add] [rm|-r|--remove] [ls|-l|--list] <point>" +    print "\nCommands:" +    print "\t add \t Adds the current working directory to your warp points" +    print "\t add! \t Overwrites existing warp point" +    print "\t remove  Removes the given warp point" +    print "\t list \t Outputs all stored warp points" +    print "\t help \t Show this extremely helpful text" +} + + +## run + +# get opts +args=`getopt -o a:r:lhs -l add:,remove:,list,help,show -- $*` + +if [[ $? -ne 0 || $#* -eq 0 ]] +then +    wd_print_usage +else +    # can't exit, as this would exit the excecuting shell +    # e.i. your terminal + +    #set -- $args # WTF + +    for i +    do +		    case "$i" +		        in +			      -a|--add|add) +                wd_add $2 false +				        shift +                shift +                break +                ;; +            -a!|--add!|add!) +                wd_add $2 true +				        shift +                shift +                break +                ;; +			      -r|--remove|rm) +				        wd_remove $2 +                shift +				        shift +                break +                ;; +			      -l|--list|ls) +				        wd_list_all +				        shift +                break +                ;; +			      -h|--help|help) +				        wd_print_usage +				        shift +                break +                ;; +			      -s|--show|show) +				        wd_show +				        shift +                break +                ;; +            *) +                wd_warp $i +                shift +                break +                ;; +			      --) +				        shift; break;; +		    esac +    done +fi + + +## garbage collection +# if not, next time warp will pick up variables from this run +# remember, there's no sub shell +points="" +args="" +unhash -d val &> /dev/null # fixes issue #1 | 
