summaryrefslogtreecommitdiff
path: root/plugins/rbenv
diff options
context:
space:
mode:
authorRobby Russell <robby@planetargon.com>2011-12-26 10:33:17 -0800
committerRobby Russell <robby@planetargon.com>2011-12-26 10:33:17 -0800
commit6bab89a47912b0ff822974788acb4daf3cb280ab (patch)
tree26296ed2fd6fd1b2f425c6f48574d0e12bfbce36 /plugins/rbenv
parent359fe53883838dedeeb02c62df9e3a2acb10bc96 (diff)
parent31cddcd32427a5f5d3daa0da168d39aba5b510b4 (diff)
downloadzsh-6bab89a47912b0ff822974788acb4daf3cb280ab.tar.gz
zsh-6bab89a47912b0ff822974788acb4daf3cb280ab.tar.bz2
zsh-6bab89a47912b0ff822974788acb4daf3cb280ab.zip
Merge pull request #671 from peterhoeg/31cddcd32427a5f5d3daa0da168d39aba5b510b4
fix: rbenv plugin - gemset.
Diffstat (limited to 'plugins/rbenv')
-rw-r--r--plugins/rbenv/rbenv.plugin.zsh44
1 files changed, 44 insertions, 0 deletions
diff --git a/plugins/rbenv/rbenv.plugin.zsh b/plugins/rbenv/rbenv.plugin.zsh
new file mode 100644
index 000000000..ae37404cd
--- /dev/null
+++ b/plugins/rbenv/rbenv.plugin.zsh
@@ -0,0 +1,44 @@
+FOUND_RBENV=0
+for rbenvdir in "$HOME/.rbenv" "/usr/local/rbenv" "/opt/rbenv" ; do
+ if [ -d $rbenvdir/bin -a $FOUND_RBENV -eq 0 ] ; then
+ FOUND_RBENV=1
+ export RBENV_ROOT=$rbenvdir
+ export PATH=${rbenvdir}/bin:$PATH
+ eval "$(rbenv init -)"
+
+ alias rubies="rbenv versions"
+ alias gemsets="rbenv gemset list"
+
+ function current_ruby() {
+ echo "$(rbenv version-name)"
+ }
+
+ function current_gemset() {
+ echo "$(rbenv gemset active 2&>/dev/null | sed -e ":a" -e '$ s/\n/+/gp;N;b a' | head -n1)"
+ }
+
+ function gems {
+ local rbenv_path=$(rbenv prefix)
+ gem list $@ | sed \
+ -Ee "s/\([0-9\.]+( .+)?\)/$fg[blue]&$reset_color/g" \
+ -Ee "s|$(echo $rbenv_path)|$fg[magenta]\$rbenv_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"
+ }
+
+ function rbenv_prompt_info() {
+ if [[ -n $(current_gemset) ]] ; then
+ echo "$(current_ruby)@$(current_gemset)"
+ else
+ echo "$(current_ruby)"
+ fi
+ }
+ fi
+done
+unset rbenvdir
+
+if [ $FOUND_RBENV -eq 0 ] ; then
+ alias rubies='ruby -v'
+ function gemsets() { echo 'not supported' }
+ function rbenv_prompt_info() { echo "system: $(ruby -v | cut -f-2 -d ' ')" }
+fi