scripts/rvm-install in rvm-0.0.99 vs scripts/rvm-install in rvm-0.0.999

- old
+ new

@@ -1,9 +1,35 @@ #!/usr/bin/env bash -if [[ "--auto" = "$1" ]] ; then rvm_auto_flag=1 ; else unset rvm_auto_flag ; fi +unset rvm_auto_flag +source scripts/version +source scripts/utility + +usage() { + echo -e " + Usage: + ${0} <options> + + Options: + --auto : Automatically update shell profile files. + --prefix : Installation prefix directory. + --help : Display help/usage (this) message + --version : display rvm package version + " +} + +while [[ $# -gt 0 ]] ; do + token="$1" ; shift + case "$token" in + --auto) rvm_auto_flag=1 ;; + --prefix) prefix_path="$1" ; shift ;; + --version) rvm_path="$(pwd)" ; __rvm_version ; unset rvm_path ; exit ;; + --help|*) usage ;; + esac +done + if [[ -f /etc/rvmrc ]] ; then source /etc/rvmrc ; fi if [[ -f "$HOME/.rvmrc" ]] ; then source "$HOME/.rvmrc" ; fi if ! [[ "$rvm_path" =~ /rvm/?$ ]] ; then unset rvm_path @@ -12,40 +38,39 @@ else rvm_path="$HOME/.rvm" fi fi -source scripts/utility source scripts/initialize __rvm_initialize # # Setup # item="$(tput setaf 2)* $(tput sgr0)" question="\n$(tput setaf 2)<?>$(tput sgr0)" cwd=$(pwd) -source_dir="${source_dir:-"$(dirname $0 | xargs dirname)"}" -if [[ ! -d "$source_dir" ]] ; then unset source_dir ; fi -source_dir="${source_dir:-$cwd}" +source_path="${source_path:-"$(dirname $0 | xargs dirname)"}" +if [[ ! -d "$source_path" ]] ; then unset source_path ; fi +source_path="${source_path:-$cwd}" # State what is required to use rvm echo -e "\nInstalling rvm to $rvm_path/ ..." for dir_name in src scripts bin log archives config gems examples ; do mkdir -p "$rvm_path/$dir_name" done -cp -f "$source_dir/README" "$rvm_path/" +cp -f "$source_path/README" "$rvm_path/" # # Scripts # rm -rf $rvm_path/scripts # Clear the old scripts directory so that the old style rvm- scripts are cleared out. for dir_name in config scripts examples lib hooks ; do mkdir -p "$rvm_path/$dir_name" - if [[ -d "$source_dir/$dir_name" ]] ; then - cp -Rf "$source_dir/$dir_name" "$rvm_path" + if [[ -d "$source_path/$dir_name" ]] ; then + cp -Rf "$source_path/$dir_name" "$rvm_path" fi done ; unset dir_name if [[ ! -s "$rvm_path/config/user" ]] ; then echo '# Users settings file, overrides db file settings and persists across installs.' >> $rvm_path/config/user @@ -55,11 +80,11 @@ # Bin Scripts # # Cleanse and purge... rm -f $rvm_path/bin/rvm ; rm -rf $rvm_path/bin/binscripts for file in rvm-prompt rvm rvmsudo ; do - cp -f "$source_dir/binscripts/$file" $rvm_path/bin/ + cp -f "$source_path/binscripts/$file" $rvm_path/bin/ done chmod +x $rvm_path/bin/* # # RC Files @@ -81,10 +106,19 @@ fi done fi fi +# +# TODO: Migrate ~/.rvm/ruby-X,jruby-X,... to ~/.rvm/rubies/ +# +#rvm_rubies_path="${rvm_rubies_path:-"$rvm_path/rubies"}" +#mkdir -p $rvm_rubies_path +#for ruby in "$rvm_path"/ruby-* "$rvm_path"/jruby-* "$rvm_path"/mput-* "$rvm_path"/rbx-* ; do +# if [[ -d "$ruby" ]] ; then mv "$ruby" "$rvm_rubies_path" ; fi +#done + if [[ "root" = "$(whoami)" ]] ; then echo -e "\n Symlinking rvm to $rvm_symlink_path/rvm ..." mkdir -p $rvm_symlink_path ln -nfs $rvm_path/bin/rvm $rvm_symlink_path/rvm ln -nfs $rvm_path/bin/rvmsudo $rvm_symlink_path/rvmsudo @@ -105,15 +139,17 @@ echo -e "My irc nickname is 'wayneeseguin' and I hang out from ~09:00-17:00EST and again from ~21:00EST-~00:00EST." echo -e "If I do not respond right away, please hang around after asking your question, I will respond as soon as I am back." echo -e "\n w$(tput setaf 2)⦿‿⦿$(tput sgr0)t!" echo -e "\n ~ Wayne\n" echo "================================================================================" - +echo -e "Upgrades" +echo -e "Gems are now per interpreter installation instead of per interpreter/version" +echo -e "so for example to upgrade an older install of 1.8.6 and preserve gems:" +echo -e "rm -rf ~/.rvm/gems/ruby-1.8.6-p383 ; mv ~/.rvm/gems/ruby/1.8.6 ~/.rvm/gems/ruby-1.8.6-p383" +echo "================================================================================" echo -e "\n$(tput setaf 1)You must now finish the install manually:$(tput sgr0)" -echo -e "\n1) Place the folowing line at the end of your shell's loading files(.bash_profile and/or .zshenv), after all path/variable settings:" +echo -e "\n1) Place the folowing line at the end of your shell's loading files(.bashrc and then .bash_profile for bash and .zshrc for zsh), after all path/variable settings:" echo -e "\n if [[ -s $rvm_path/scripts/rvm ]] ; then source $rvm_path/scripts/rvm ; fi" echo -e "\n2) Ensure that there is no 'return' from inside the .bashrc file. (otherwise rvm will be prevented from working properly)." echo -e "\n3) $(tput setaf 1)CLOSE THIS SHELL$(tput sgr0) and open a new one in order to use rvm.\n" - -if [[ -x "$rvm_path/bin/rvm" ]] ; then "$rvm_path/bin/rvm" -v ; fi exit 0