50 lines
1.4 KiB
Bash
50 lines
1.4 KiB
Bash
# Enables rbfu with --auto option, if available.
|
|
#
|
|
# Also provides a command to list all installed/available
|
|
# rubies. To ensure compatibility with themes, creates the
|
|
# rvm_prompt_info function to return the $RBFU_RUBY_VERSION
|
|
# version.
|
|
|
|
command -v rbfu &>/dev/null || return
|
|
|
|
eval "$(rbfu --init --auto)"
|
|
|
|
# Internal: Print ruby version details, if it's currently active, etc.
|
|
function _rbfu_rubies_print() {
|
|
# 1: path to ruby file
|
|
# 2: active ruby
|
|
local rb rb_out
|
|
rb="${$1:t}"
|
|
rb_out="$rb"
|
|
|
|
# If the ruby is a symlink, add @ to the name.
|
|
if [[ -h "$1" ]]; then
|
|
rb_out="${rb_out}${fg[green]}@${reset_color}"
|
|
fi
|
|
|
|
# If the ruby is active, add * to the name and show it in red.
|
|
if [[ "$rb" = "$2" ]]; then
|
|
rb_out="${fg[red]}${rb_out} ${fg[red]}*${reset_color}"
|
|
fi
|
|
|
|
echo $rb_out
|
|
}
|
|
|
|
# Public: Provide a list with all available rubies, this basically depends
|
|
# on ~/.rfbu/rubies. Highlights the currently active ruby version and aliases.
|
|
function rbfu-rubies() {
|
|
local rbfu_dir active_rb
|
|
rbfu_dir="${RBFU_RUBIES:-${HOME}/.rbfu/rubies}"
|
|
active_rb="${RBFU_RUBY_VERSION:-system}"
|
|
|
|
_rbfu_rubies_print "${rbfu_dir}/system" "$active_rb"
|
|
for rb in ${rbfu_dir}/*(N); do
|
|
_rbfu_rubies_print "$rb" "$active_rb"
|
|
done
|
|
}
|
|
|
|
# Public: Create rvm_prompt_info command for themes compatibility, unless
|
|
# it has already been defined.
|
|
(( ${+functions[rvm_prompt_info]} )) || \
|
|
function rvm_prompt_info() { echo "${${RBFU_RUBY_VERSION:=system}:gs/%/%%}" }
|