mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-11-22 05:40:08 +00:00
Change bi
alias to a function
Only check the bundler version when we call bi. This fixes two issues: First, if there is no bundler available system-wide this will cause an error each time zsh loads. Second, if new bundler is installed system-wide but you change into an rbenv with an older version, the alias will no longer work.
This commit is contained in:
parent
5643fac887
commit
22c0db64ee
1 changed files with 28 additions and 24 deletions
|
@ -4,13 +4,31 @@ alias bp="bundle package"
|
||||||
alias bo="bundle open"
|
alias bo="bundle open"
|
||||||
alias bu="bundle update"
|
alias bu="bundle update"
|
||||||
|
|
||||||
|
|
||||||
# The following is based on https://github.com/gma/bundler-exec
|
# The following is based on https://github.com/gma/bundler-exec
|
||||||
|
|
||||||
bundled_commands=(annotate berks cap capify cucumber foodcritic foreman guard jekyll kitchen knife middleman nanoc rackup rainbows rake rspec ruby shotgun spec spin spork strainer tailor taps thin thor unicorn unicorn_rails puma)
|
bundled_commands=(annotate berks cap capify cucumber foodcritic foreman guard jekyll kitchen knife middleman nanoc rackup rainbows rake rspec ruby shotgun spec spin spork strainer tailor taps thin thor unicorn unicorn_rails puma)
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
|
|
||||||
|
bi() {
|
||||||
|
if _bundler-installed && _within-bundled-project; then
|
||||||
|
local 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
|
||||||
|
bundle install --jobs=$cores_num $@
|
||||||
|
else
|
||||||
|
bundle install $@
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Can't 'bundle install' outside a bundled project"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
_bundler-installed() {
|
_bundler-installed() {
|
||||||
which bundle > /dev/null 2>&1
|
which bundle > /dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
@ -32,28 +50,14 @@ _run-with-bundler() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
if _bundler-installed; then
|
## Main program
|
||||||
bundler_version=`bundle version | cut -d' ' -f3`
|
for cmd in $bundled_commands; do
|
||||||
if [[ $bundler_version > '1.4.0' || $bundler_version = '1.4.0' ]]; then
|
eval "function unbundled_$cmd () { $cmd \$@ }"
|
||||||
if [[ "$(uname)" == 'Darwin' ]]
|
eval "function bundled_$cmd () { _run-with-bundler $cmd \$@}"
|
||||||
then
|
alias $cmd=bundled_$cmd
|
||||||
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
|
if which _$cmd > /dev/null 2>&1; then
|
||||||
for cmd in $bundled_commands; do
|
compdef _$cmd bundled_$cmd=$cmd
|
||||||
eval "function unbundled_$cmd () { $cmd \$@ }"
|
fi
|
||||||
eval "function bundled_$cmd () { _run-with-bundler $cmd \$@}"
|
done
|
||||||
alias $cmd=bundled_$cmd
|
|
||||||
|
|
||||||
if which _$cmd > /dev/null 2>&1; then
|
|
||||||
compdef _$cmd bundled_$cmd=$cmd
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
Loading…
Reference in a new issue