From 17f68709bf5185d849cd8cd93569aeaf2a96811c Mon Sep 17 00:00:00 2001 From: Koichiro Iwao Date: Mon, 12 Oct 2020 03:02:34 +0000 Subject: Add lang/ruby30 (Ruby 3.0.0 Preview 1) PR: 250131 Submitted by: Yasuhiro KIMURA Reviewed by: meta (myself) Relnotes: https://www.ruby-lang.org/en/news/2020/09/25/ruby-3-0-0-preview1-released/ --- lang/ruby30/files/patch-tool_rbinstall.rb | 150 ++++++++++++++++++++++++++++++ 1 file changed, 150 insertions(+) create mode 100644 lang/ruby30/files/patch-tool_rbinstall.rb (limited to 'lang/ruby30/files/patch-tool_rbinstall.rb') diff --git a/lang/ruby30/files/patch-tool_rbinstall.rb b/lang/ruby30/files/patch-tool_rbinstall.rb new file mode 100644 index 000000000000..9e02a2c30733 --- /dev/null +++ b/lang/ruby30/files/patch-tool_rbinstall.rb @@ -0,0 +1,150 @@ +--- tool/rbinstall.rb.orig 2020-10-02 17:47:07 UTC ++++ tool/rbinstall.rb +@@ -864,147 +864,6 @@ end + + # :startdoc: + +-install?(:ext, :comm, :gem, :'default-gems', :'default-gems-comm') do +- install_default_gem('lib', srcdir) +-end +-install?(:ext, :arch, :gem, :'default-gems', :'default-gems-arch') do +- install_default_gem('ext', srcdir) +-end +- +-def load_gemspec(file) +- file = File.realpath(file) +- code = File.read(file, encoding: "utf-8:-") +- code.gsub!(/`git.*?`/m, '""') +- code.gsub!(/%x\[git.*?\]/m, '""') +- spec = eval(code, binding, file) +- unless Gem::Specification === spec +- raise TypeError, "[#{file}] isn't a Gem::Specification (#{spec.class} instead)." +- end +- spec.loaded_from = file +- spec +-end +- +-def install_default_gem(dir, srcdir) +- gem_dir = Gem.default_dir +- install_dir = with_destdir(gem_dir) +- prepare "default gems from #{dir}", gem_dir +- makedirs(Gem.ensure_default_gem_subdirectories(install_dir, $dir_mode).map {|d| File.join(gem_dir, d)}) +- +- default_spec_dir = Gem.default_specifications_dir +- +- gems = Dir.glob("#{srcdir}/#{dir}/**/*.gemspec").map {|src| +- spec = load_gemspec(src) +- file_collector = RbInstall::Specs::FileCollector.new(src) +- files = file_collector.collect +- next if files.empty? +- spec.files = files +- spec +- } +- gems.compact.sort_by(&:name).each do |gemspec| +- old_gemspecs = Dir[File.join(with_destdir(default_spec_dir), "#{gemspec.name}-*.gemspec")] +- if old_gemspecs.size > 0 +- old_gemspecs.each {|spec| rm spec } +- end +- +- full_name = "#{gemspec.name}-#{gemspec.version}" +- +- puts "#{INDENT}#{gemspec.name} #{gemspec.version}" +- gemspec_path = File.join(default_spec_dir, "#{full_name}.gemspec") +- open_for_install(gemspec_path, $data_mode) do +- gemspec.to_ruby.gsub(/.*\0.*\n/, '') +- end +- +- specific_gem_dir = File.join(gem_dir, 'gems', full_name) +- +- makedirs(specific_gem_dir) +- +- unless gemspec.executables.empty? then +- bin_dir = File.join(specific_gem_dir, gemspec.bindir) +- makedirs(bin_dir) +- +- gemspec.executables.map {|exec| +- install File.join(srcdir, 'libexec', exec), +- File.join(bin_dir, exec) +- } +- end +- end +-end +- +-install?(:ext, :comm, :gem, :'bundled-gems') do +- gem_dir = Gem.default_dir +- install_dir = with_destdir(gem_dir) +- prepare "bundled gems", gem_dir +- makedirs(Gem.ensure_gem_subdirectories(install_dir, $dir_mode).map {|d| File.join(gem_dir, d)}) +- installed_gems = {} +- options = { +- :install_dir => install_dir, +- :bin_dir => with_destdir(bindir), +- :domain => :local, +- :ignore_dependencies => true, +- :dir_mode => $dir_mode, +- :data_mode => $data_mode, +- :prog_mode => $script_mode, +- :wrappers => true, +- :format_executable => true, +- } +- gem_ext_dir = "#$extout/gems/#{CONFIG['arch']}" +- extensions_dir = Gem::StubSpecification.gemspec_stub("", gem_dir, gem_dir).extensions_dir +- File.foreach("#{srcdir}/gems/bundled_gems") do |name| +- next if /^\s*(?:#|$)/ =~ name +- next unless /^(\S+)\s+(\S+).*/ =~ name +- gem_name = "#$1-#$2" +- path = "#{srcdir}/.bundle/gems/#{gem_name}/#$1.gemspec" +- next unless File.exist?(path) +- spec = load_gemspec(path) +- next unless spec.platform == Gem::Platform::RUBY +- next unless spec.full_name == gem_name +- spec.extension_dir = "#{extensions_dir}/#{spec.full_name}" +- if File.directory?(ext = "#{gem_ext_dir}/#{spec.full_name}") +- spec.extensions[0] ||= "-" +- end +- package = RbInstall::DirPackage.new spec +- ins = RbInstall::UnpackedInstaller.new(package, options) +- puts "#{INDENT}#{spec.name} #{spec.version}" +- ins.install +- unless $dryrun +- File.chmod($data_mode, File.join(install_dir, "specifications", "#{spec.full_name}.gemspec")) +- end +- unless spec.extensions.empty? +- install_recursive(ext, spec.extension_dir) +- end +- installed_gems[spec.full_name] = true +- end +- installed_gems, gems = Dir.glob(srcdir+'/gems/*.gem').partition {|gem| installed_gems.key?(File.basename(gem, '.gem'))} +- unless installed_gems.empty? +- prepare "bundled gem cache", gem_dir+"/cache" +- install installed_gems, gem_dir+"/cache" +- end +- next if gems.empty? +- if defined?(Zlib) +- Gem.instance_variable_set(:@ruby, with_destdir(File.join(bindir, ruby_install_name))) +- silent = Gem::SilentUI.new +- gems.each do |gem| +- package = Gem::Package.new(gem) +- inst = RbInstall::GemInstaller.new(package, options) +- inst.spec.extension_dir = with_destdir(inst.spec.extension_dir) +- begin +- Gem::DefaultUserInteraction.use_ui(silent) {inst.install} +- rescue Gem::InstallError +- next +- end +- gemname = File.basename(gem) +- puts "#{INDENT}#{gemname}" +- end +- # fix directory permissions +- # TODO: Gem.install should accept :dir_mode option or something +- File.chmod($dir_mode, *Dir.glob(install_dir+"/**/")) +- # fix .gemspec permissions +- File.chmod($data_mode, *Dir.glob(install_dir+"/specifications/*.gemspec")) +- else +- puts "skip installing bundled gems because of lacking zlib" +- end +-end +- + parse_args() + + include FileUtils -- cgit v1.2.3