summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-28 09:42:41 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-28 09:42:41 +0000
commit5f746714c32272dc13b1b3f7f9a839336a57fce2 (patch)
tree787971c46852ebbd2a4b416a1961ce31cb3e0cb6
parent10e0ed7bd48b3c2dda09f5db05cd5b5fd1618b28 (diff)
downloadruby-5f746714c32272dc13b1b3f7f9a839336a57fce2.tar.gz
ruby-5f746714c32272dc13b1b3f7f9a839336a57fce2.tar.xz
ruby-5f746714c32272dc13b1b3f7f9a839336a57fce2.zip
merges r21102 from trunk into ruby_1_9_1.
* runruby.rb: refactored to modify ENV as once. git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@21130 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rwxr-xr-xrunruby.rb18
2 files changed, 17 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index c2081b812..337eab553 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Sun Dec 28 00:43:33 2008 Tanaka Akira <akr@fsij.org>
+
+ * runruby.rb: refactored to modify ENV as once.
+
Sat Dec 27 22:41:02 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* test/rdoc/test_rdoc_info_formatting.rb (setup, teadown): uses
diff --git a/runruby.rb b/runruby.rb
index 8b0e9c20e..c43978404 100755
--- a/runruby.rb
+++ b/runruby.rb
@@ -44,28 +44,36 @@ if extout
end
libs << File.expand_path("lib", srcdir)
config["bindir"] = abs_archdir
-ENV["RUBY"] = File.expand_path(ruby)
-ENV["PATH"] = [abs_archdir, ENV["PATH"]].compact.join(File::PATH_SEPARATOR)
+
+env = {}
+
+env["RUBY"] = File.expand_path(ruby)
+env["PATH"] = [abs_archdir, ENV["PATH"]].compact.join(File::PATH_SEPARATOR)
if pure
libs << File.expand_path("ext", srcdir) << "-"
elsif e = ENV["RUBYLIB"]
libs |= e.split(File::PATH_SEPARATOR)
end
-ENV["RUBYLIB"] = $:.replace(libs).join(File::PATH_SEPARATOR)
+env["RUBYLIB"] = $:.replace(libs).join(File::PATH_SEPARATOR)
libruby_so = File.join(abs_archdir, config['LIBRUBY_SO'])
if File.file?(libruby_so)
if e = config['LIBPATHENV'] and !e.empty?
- ENV[e] = [abs_archdir, ENV[e]].compact.join(File::PATH_SEPARATOR)
+ env[e] = [abs_archdir, ENV[e]].compact.join(File::PATH_SEPARATOR)
end
if /linux/ =~ RUBY_PLATFORM
- ENV["LD_PRELOAD"] = [libruby_so, ENV["LD_PRELOAD"]].compact.join(' ')
+ env["LD_PRELOAD"] = [libruby_so, ENV["LD_PRELOAD"]].compact.join(' ')
end
end
+ENV.update env
+
cmd = [ruby]
cmd << "-rpurelib.rb" if pure
cmd.concat(ARGV)
cmd.unshift(*debugger) if debugger
+
+#require 'shellwords'; puts Shellwords.join(env.map {|k,v| "#{k}=#{v}" } + cmd)
+
exec(*cmd)