ruby.sh: fix version check.
- Rather than checking for the absence of a failure check for an actual success in the check - Fix the check to work on Ruby 1.9 (where `RUBY_VERSION.to_s.dup` is required to avoid modifying a frozen string).
This commit is contained in:
parent
65e940f833
commit
78933b3ee9
@ -2,7 +2,7 @@ setup-ruby-path() {
|
|||||||
local vendor_dir
|
local vendor_dir
|
||||||
local vendor_ruby_current_version
|
local vendor_ruby_current_version
|
||||||
local vendor_ruby_path
|
local vendor_ruby_path
|
||||||
local ruby_old_version
|
local ruby_version_new_enough
|
||||||
local minimum_ruby_version="2.3.3"
|
local minimum_ruby_version="2.3.3"
|
||||||
|
|
||||||
vendor_dir="$HOMEBREW_LIBRARY/Homebrew/vendor"
|
vendor_dir="$HOMEBREW_LIBRARY/Homebrew/vendor"
|
||||||
@ -35,12 +35,12 @@ setup-ruby-path() {
|
|||||||
HOMEBREW_RUBY_PATH="$(which ruby)"
|
HOMEBREW_RUBY_PATH="$(which ruby)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -n "$HOMEBREW_RUBY_PATH" ]]
|
if [[ -n "$HOMEBREW_RUBY_PATH" && -z "$HOMEBREW_FORCE_VENDOR_RUBY" ]]
|
||||||
then
|
then
|
||||||
ruby_old_version="$("$HOMEBREW_RUBY_PATH" -rrubygems -e "puts Gem::Version.new('$minimum_ruby_version') > Gem::Version.new(RUBY_VERSION)")"
|
ruby_version_new_enough="$("$HOMEBREW_RUBY_PATH" -rrubygems -e "puts Gem::Version.new(RUBY_VERSION.to_s.dup) >= Gem::Version.new('$minimum_ruby_version')")"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "$HOMEBREW_RUBY_PATH" || "$ruby_old_version" == "true" || -n "$HOMEBREW_FORCE_VENDOR_RUBY" ]]
|
if [[ -z "$HOMEBREW_RUBY_PATH" || -n "$HOMEBREW_FORCE_VENDOR_RUBY" || "$ruby_version_new_enough" != "true" ]]
|
||||||
then
|
then
|
||||||
brew vendor-install ruby
|
brew vendor-install ruby
|
||||||
if [[ ! -x "$vendor_ruby_path" ]]
|
if [[ ! -x "$vendor_ruby_path" ]]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user