diff options
author | rhe <rhe@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-09-26 02:50:31 +0000 |
---|---|---|
committer | rhe <rhe@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-09-26 02:50:31 +0000 |
commit | d1dbeebebf184440bcda2c2e12a099fe1e2ffa0b (patch) | |
tree | e3be337ed6cceb8ee74f36dcee4dc2318632e726 /tool | |
parent | 537fea9921c8b18ec975d9520881167796d1bbd9 (diff) | |
download | ruby-d1dbeebebf184440bcda2c2e12a099fe1e2ffa0b.tar.gz |
rbinstall.rb: don't install gemspec for skipped libraries
* tool/rbinstall.rb (gem): Don't install gemspec if no files will be
installed for the gem. This happens when the extension library is not
compiled.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56248 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'tool')
-rwxr-xr-x | tool/rbinstall.rb | 35 |
1 files changed, 10 insertions, 25 deletions
diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb index e27cffd7a1..94bf91ecac 100755 --- a/tool/rbinstall.rb +++ b/tool/rbinstall.rb @@ -648,21 +648,6 @@ module RbInstall string.sub(/\A#{Regexp.escape(prefix)}/, "") end end - - class Reader < Struct.new(:src) - def gemspec - @gemspec ||= begin - spec = Gem::Specification.load(src) || raise("invalid spec in #{src}") - file_collector = FileCollector.new(File.dirname(src)) - spec.files = file_collector.collect - spec - end - end - - def spec_source - @gemspec.to_ruby - end - end end class UnpackedInstaller < Gem::Installer @@ -718,21 +703,21 @@ install?(:ext, :comm, :gem) do default_spec_dir = "#{spec_dir}/default" makedirs(default_spec_dir) - gems = {} - - Dir.glob(srcdir+"/{lib,ext}/**/*.gemspec").each do |src| - specgen = RbInstall::Specs::Reader.new(src) - gems[specgen.gemspec.name] ||= specgen - end - - gems.sort.each do |name, specgen| - gemspec = specgen.gemspec + gems = Dir.glob(srcdir+"/{lib,ext}/**/*.gemspec").map {|src| + spec = Gem::Specification.load(src) || raise("invalid spec in #{src}") + file_collector = RbInstall::Specs::FileCollector.new(File.dirname(src)) + files = file_collector.collect + next if files.empty? + spec.files = files + spec + } + gems.compact.sort_by(&:name).each do |gemspec| full_name = "#{gemspec.name}-#{gemspec.version}" puts "#{" "*30}#{gemspec.name} #{gemspec.version}" gemspec_path = File.join(default_spec_dir, "#{full_name}.gemspec") open_for_install(gemspec_path, $data_mode) do - specgen.spec_source + gemspec.to_ruby end unless gemspec.executables.empty? then |