aboutsummaryrefslogtreecommitdiffstats
path: root/tool
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-08-17 14:14:44 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-08-17 14:14:44 +0000
commited2472a7a25524b0491d13fb3f206548fbfc0452 (patch)
tree69a1062ea08ead0edb403452025dbe6ed18b4c1d /tool
parentacc7c14f619bca98af36d337fb0567644d724526 (diff)
downloadruby-ed2472a7a25524b0491d13fb3f206548fbfc0452.tar.gz
gem extensions
* ext/extmk.rb: build gem extensions into separate directories * tool/rbinstall.rb: install pre-built gem extension files gem extension directories. [ruby-core:76931] [Bug #12681] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55950 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'tool')
-rwxr-xr-xtool/rbinstall.rb13
1 files changed, 13 insertions, 0 deletions
diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb
index 104d5ff98f..28315f8bff 100755
--- a/tool/rbinstall.rb
+++ b/tool/rbinstall.rb
@@ -678,6 +678,9 @@ module RbInstall
def write_cache_file
end
+
+ def build_extensions
+ end
end
end
@@ -750,11 +753,21 @@ install?(:ext, :comm, :gem) do
:wrappers => true,
:format_executable => true,
}
+ gem_ext_dir = "#$extout/gems/#{CONFIG['arch']}"
+ extensions_dir = Gem::StubSpecification.gemspec_stub("", gem_dir, gem_dir).extensions_dir
Gem::Specification.each_spec([srcdir+'/gems/*']) do |spec|
+ spec.extension_dir = "#{extensions_dir}/#{spec.full_name}"
+ if File.directory?(ext = "#{gem_ext_dir}/#{spec.full_name}")
+ spec.extensions[0] ||= "-"
+ end
ins = RbInstall::UnpackedInstaller.new(spec, options)
puts "#{" "*30}#{spec.name} #{spec.version}"
ins.install
File.chmod($data_mode, File.join(install_dir, "specifications", "#{spec.full_name}.gemspec"))
+ unless spec.extensions.empty?
+ install_recursive(ext, spec.extension_dir)
+ open_for_install(spec.gem_build_complete_path, $data_mode) {""}
+ 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'))}