summaryrefslogtreecommitdiff
path: root/lib/rubygems/ext
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-02 16:14:32 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-02 16:14:32 +0000
commitc0c72c9ba1e2492999664d6b0335dd7d3ae43bb6 (patch)
tree80c89308a9bc6130c12bb6adc6cb01ecfb30d27b /lib/rubygems/ext
parentee01561bf16105a614adf00acd4afea4832e2367 (diff)
ext_conf_builder.rb: build in the source directory
* lib/rubygems/ext/ext_conf_builder.rb (Gem::Ext::ExtConfBuilder.build): revert use of temporary directory for build, to work some buggy extconf.rb which cannot build outside the source directory. [ruby-core:53056] [Bug #7698] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@39558 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rubygems/ext')
-rw-r--r--lib/rubygems/ext/ext_conf_builder.rb39
1 files changed, 16 insertions, 23 deletions
diff --git a/lib/rubygems/ext/ext_conf_builder.rb b/lib/rubygems/ext/ext_conf_builder.rb
index 3a439af502..eaf5e607a6 100644
--- a/lib/rubygems/ext/ext_conf_builder.rb
+++ b/lib/rubygems/ext/ext_conf_builder.rb
@@ -7,37 +7,30 @@
require 'rubygems/ext/builder'
require 'rubygems/command'
require 'fileutils'
-require 'tmpdir'
+require 'tempfile'
class Gem::Ext::ExtConfBuilder < Gem::Ext::Builder
def self.build(extension, directory, dest_path, results, args=[])
- pwd = Dir.pwd
- cmd = "#{Gem.ruby} -r./siteconf #{File.join pwd, File.basename(extension)}"
- cmd << " #{args.join ' '}" unless args.empty?
-
- 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
-
- begin
- run cmd, results
-
- make dest_path, results
- ensure
- FileUtils.mv("mkmf.log", pwd) if $! and File.exist?("mkmf.log")
- end
+ siteconf = Tempfile.open(%w"siteconf .rb", ".") 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
+ f
end
+ cmd = [Gem.ruby, "-r#{siteconf.path}", File.basename(extension), *args].join ' '
+
+ run cmd, results
+
+ make dest_path, results
+
results
+ ensure
+ siteconf.close(true) if siteconf
end
end