From afd3a18fc3662ebc717a183b718ad2dae89bc0c4 Mon Sep 17 00:00:00 2001 From: drbrain Date: Fri, 22 Jul 2011 03:16:48 +0000 Subject: [PATCH] * tool/rbinstall.rb (default gems): Install executables into the fake gem dir for Gem.bin_path. [#4485] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32608 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ tool/rbinstall.rb | 31 +++++++++++++++++++++++-------- 2 files changed, 28 insertions(+), 8 deletions(-) diff --git a/ChangeLog b/ChangeLog index 771b3142f5..a01a84aeb4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Fri Jul 22 12:10:21 2011 Eric Hodel + + * tool/rbinstall.rb (default gems): Install executables into the fake + gem dir for Gem.bin_path. [#4485] + Fri Jul 22 11:20:20 2011 Martin Bosslet * ext/openssl/ossl_digest.c: Check return value of EVP_DigestInit_ex. diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb index 85daeffe34..967effab8c 100755 --- a/tool/rbinstall.rb +++ b/tool/rbinstall.rb @@ -534,32 +534,47 @@ end install?(:ext, :comm, :gem) do $:.unshift(File.join(srcdir, "lib")) require("rubygems.rb") - gpath = Gem.default_dir - directories = Gem.ensure_gem_subdirectories(gpath) - prepare "default gems", gpath, directories + gem_dir = Gem.default_dir + directories = Gem.ensure_gem_subdirectories(gem_dir) + prepare "default gems", gem_dir, directories - destdir = File.join(gpath, directories.grep(/^spec/)[0]) + spec_dir = File.join(gem_dir, directories.grep(/^spec/)[0]) default_gems = [ - ['rake', 'lib/rake/version.rb'], - ['rdoc', 'lib/rdoc.rb'], + ['rake', 'lib/rake/version.rb', ['rake']], + ['rdoc', 'lib/rdoc.rb', ['rdoc', 'ri']], ['minitest', 'lib/minitest/unit.rb'], ['json', 'ext/json/lib/json/version.rb'], ['io-console', 'ext/io/console/io-console.gemspec'], ] - default_gems.each do |name, src| + + default_gems.each do |name, src, execs| + execs ||= [] src = File.join(srcdir, src) version = open(src) {|f| f.find {|s| /^\s*\w*VERSION\s*=(?!=)/ =~ s}} or next version = version.split(%r"=\s*", 2)[1].strip[/\A([\'\"])(.*?)\1/, 2] + full_name = "#{name}-#{version}" + puts "#{" "*30}#{name} #{version}" - open_for_install(File.join(destdir, "#{name}-#{version}.gemspec"), $data_mode) do + open_for_install(File.join(spec_dir, "#{full_name}.gemspec"), $data_mode) do <<-GEMSPEC Gem::Specification.new do |s| s.name = #{name.dump} s.version = #{version.dump} s.summary = "This #{name} is bundled with Ruby" + s.executables = #{execs.inspect} end GEMSPEC end + + unless execs.empty? then + bin_dir = File.join(gem_dir, 'gems', full_name, 'bin') + makedirs(bin_dir) + + execs.each do |exec| + exec = File.join(srcdir, 'bin', exec) + install(exec, bin_dir, :mode => $prog_mode) + end + end end end