summaryrefslogtreecommitdiff
path: root/lib/bundler/ruby_dsl.rb
diff options
context:
space:
mode:
authorMartin Emde <martin.emde@gmail.com>2023-09-12 18:54:39 -0700
committergit <svn-admin@ruby-lang.org>2023-09-14 19:43:21 +0000
commit66ffa15ce01e1b8d46738032e714be18194af3ca (patch)
tree1753cd9cef0f8c816fccaea871be05eb177f833a /lib/bundler/ruby_dsl.rb
parent0d33bc0cde5b9eca805cec1133e2c48ebdea5c84 (diff)
[rubygems/rubygems] Gemfile ruby file: covers more version formats
Increase test coverage and be explicit about what is and is not supported. https://github.com/rubygems/rubygems/commit/a096397a00
Diffstat (limited to 'lib/bundler/ruby_dsl.rb')
-rw-r--r--lib/bundler/ruby_dsl.rb30
1 files changed, 23 insertions, 7 deletions
diff --git a/lib/bundler/ruby_dsl.rb b/lib/bundler/ruby_dsl.rb
index 542dbac1e4..95151898ff 100644
--- a/lib/bundler/ruby_dsl.rb
+++ b/lib/bundler/ruby_dsl.rb
@@ -10,13 +10,8 @@ module Bundler
raise GemfileError, "Please define :engine" if options[:engine_version] && options[:engine].nil?
if options[:file]
- raise GemfileError, "Cannot specify version when using the file option" if ruby_version.any?
- file_content = Bundler.read_file(Bundler.root.join(options[:file]))
- if /^ruby\s+(.*)$/.match(file_content) # match .tool-versions files
- ruby_version << $1.split("#", 2).first.strip # remove trailing comment
- else
- ruby_version << file_content.strip
- end
+ raise GemfileError, "Do not pass version argument when using :file option" unless ruby_version.empty?
+ ruby_version << normalize_ruby_file(options[:file])
end
if options[:engine] == "ruby" && options[:engine_version] &&
@@ -25,5 +20,26 @@ module Bundler
end
@ruby_version = RubyVersion.new(ruby_version, options[:patchlevel], options[:engine], options[:engine_version])
end
+
+ # Support the various file formats found in .ruby-version files.
+ #
+ # 3.2.2
+ # ruby-3.2.2
+ #
+ # Also supports .tool-versions files for asdf. Lines not starting with "ruby" are ignored.
+ #
+ # ruby 2.5.1 # comment is ignored
+ # ruby 2.5.1# close comment and extra spaces doesn't confuse
+ #
+ # Intentionally does not support `3.2.1@gemset` since rvm recommends using .ruby-gemset instead
+ def normalize_ruby_file(filename)
+ file_content = Bundler.read_file(Bundler.root.join(filename))
+ # match "ruby-3.2.2" or "ruby 3.2.2" capturing version string up to the first space or comment
+ if /^ruby(-|\s+)([^\s#]+)/.match(file_content)
+ $2
+ else
+ file_content.strip
+ end
+ end
end
end