ruby-changes:9563
From: akr <ko1@a...>
Date: Sun, 28 Dec 2008 00:45:08 +0900 (JST)
Subject: [ruby-changes:9563] Ruby:r21102 (trunk): * runruby.rb: refactored to modify ENV as once.
akr 2008-12-28 00:44:51 +0900 (Sun, 28 Dec 2008) New Revision: 21102 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=21102 Log: * runruby.rb: refactored to modify ENV as once. Modified files: trunk/ChangeLog trunk/runruby.rb Index: ChangeLog =================================================================== --- ChangeLog (revision 21101) +++ ChangeLog (revision 21102) @@ -1,3 +1,7 @@ +Sun Dec 28 00:43:33 2008 Tanaka Akira <akr@f...> + + * runruby.rb: refactored to modify ENV as once. + Sat Dec 27 22:41:02 2008 Nobuyoshi Nakada <nobu@r...> * test/rdoc/test_rdoc_info_formatting.rb (setup, teadown): uses Index: runruby.rb =================================================================== --- runruby.rb (revision 21101) +++ runruby.rb (revision 21102) @@ -44,28 +44,36 @@ 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) -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/