mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/rubygems/ext/builder.rb: Fix incompatibilities when installing
extensions. Patch by Nobu. [ruby-trunk - Bug #7968] [ruby-trunk - Bug #7971] * lib/rubygems/ext/ext_conf_builder.rb: ditto. * lib/rubygems/installer.rb: ditto. * test/rubygems/test_gem_ext_ext_conf_builder.rb: Test for the above. * test/rubygems/test_gem_installer.rb: ditto. * lib/rubygems/commands/sources_command.rb: Prefer HTTPS over HTTP. * lib/rubygems/defaults.rb: ditto * lib/rubygems/dependency_resolver.rb: Ditto. * lib/rubygems/source.rb: ditto. * lib/rubygems/spec_fetcher.rb: ditto. * lib/rubygems/specification.rb: ditto. * lib/rubygems/test_utilities.rb: ditto. * test/rubygems/test_gem.rb: Test for the above. * test/rubygems/test_gem_commands_sources_command.rb: ditto. * test/rubygems/test_gem_dependency_resolver_api_set.rb: ditto. * test/rubygems/test_gem_remote_fetcher.rb: ditto. * test/rubygems/test_gem_source.rb: ditto. * test/rubygems/test_gem_spec_fetcher.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@39542 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
3fc7731297
commit
a5dfaca00a
19 changed files with 298 additions and 40 deletions
|
@ -6,16 +6,36 @@
|
|||
|
||||
require 'rubygems/ext/builder'
|
||||
require 'rubygems/command'
|
||||
require 'fileutils'
|
||||
require 'tmpdir'
|
||||
|
||||
class Gem::Ext::ExtConfBuilder < Gem::Ext::Builder
|
||||
|
||||
def self.build(extension, directory, dest_path, results, args=[])
|
||||
cmd = "#{Gem.ruby} #{File.basename extension}"
|
||||
pwd = Dir.pwd
|
||||
cmd = "#{Gem.ruby} -r./siteconf #{File.join pwd, File.basename(extension)}"
|
||||
cmd << " #{args.join ' '}" unless args.empty?
|
||||
|
||||
run cmd, results
|
||||
Dir.mktmpdir("gem-install.") do |tmpdir|
|
||||
Dir.chdir(tmpdir) do
|
||||
open("siteconf.rb", "w") do |f|
|
||||
f.puts "require 'rbconfig'"
|
||||
f.puts "dest_path = #{dest_path.dump}"
|
||||
%w[sitearchdir sitelibdir].each do |dir|
|
||||
f.puts "RbConfig::MAKEFILE_CONFIG['#{dir}'] = dest_path"
|
||||
f.puts "RbConfig::CONFIG['#{dir}'] = dest_path"
|
||||
end
|
||||
end
|
||||
|
||||
make dest_path, results
|
||||
begin
|
||||
run cmd, results
|
||||
|
||||
make dest_path, results
|
||||
ensure
|
||||
FileUtils.mv("mkmf.log", pwd) if $! and File.exist?("mkmf.log")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
results
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue