[前][次][番号順一覧][スレッド一覧]

ruby-changes:10327

From: nobu <ko1@a...>
Date: Thu, 29 Jan 2009 12:30:15 +0900 (JST)
Subject: [ruby-changes:10327] Ruby:r21871 (trunk): * lib/rake.rb (FileUtils#rake_system): no longer needs workaround

nobu	2009-01-29 12:29:53 +0900 (Thu, 29 Jan 2009)

  New Revision: 21871

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=21871

  Log:
    * lib/rake.rb (FileUtils#rake_system): no longer needs workaround
      on Windows.  [ruby-core:21339]
    * lib/rake/win32.rb (Rake::Win32#rake_system): ditto.
    
    * lib/rake/win32.rb (Rake::Win32#win32_system_dir): no longer
      needs environment variables other than APPDATA now.
    
    * lib/rake.rb (Rake::Application#standard_system_dir): uses
      platfrom specific definition on Windows system.

  Modified files:
    trunk/ChangeLog
    trunk/lib/rake/win32.rb
    trunk/lib/rake.rb

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 21870)
+++ ChangeLog	(revision 21871)
@@ -1,3 +1,16 @@
+Thu Jan 29 12:29:51 2009  Nobuyoshi Nakada  <nobu@r...>
+
+	* lib/rake.rb (FileUtils#rake_system): no longer needs workaround
+	  on Windows.  [ruby-core:21339]
+
+	* lib/rake/win32.rb (Rake::Win32#rake_system): ditto.
+
+	* lib/rake/win32.rb (Rake::Win32#win32_system_dir): no longer
+	  needs environment variables other than APPDATA now.
+
+	* lib/rake.rb (Rake::Application#standard_system_dir): uses
+	  platfrom specific definition on Windows system.
+
 Thu Jan 29 12:18:54 2009  Technorama Ltd.  <oss-ruby@t...>
 
 	* lib/securerandom.rb: new method SecureRandom#uuid
Index: lib/rake/win32.rb
===================================================================
--- lib/rake/win32.rb	(revision 21870)
+++ lib/rake/win32.rb	(revision 21871)
@@ -1,54 +1,34 @@
 module Rake
-  
+
   # Win 32 interface methods for Rake. Windows specific functionality
   # will be placed here to collect that knowledge in one spot.
   module Win32
-    
-    # Error indicating a problem in locating the home directory on a
-    # Win32 system.
-    class Win32HomeError < RuntimeError
-    end
-    
     class << self
       # True if running on a windows system.
       def windows?
-        Config::CONFIG['host_os'] =~ /mswin/
+        # assume other DOSish systems are extinct.
+        File::ALT_SEPARATOR == '\\'
       end
+    end
 
-      # Run a command line on windows.
-      def rake_system(*cmd)
-        if cmd.size == 1
-          system("call #{cmd}")
-        else
-          system(*cmd)
-        end
-      end
-      
+    class << self
       # The standard directory containing system wide rake files on
       # Win 32 systems. Try the following environment variables (in
       # order):
       #
       # * APPDATA
+      # * HOME
       # * HOMEDRIVE + HOMEPATH
       # * USERPROFILE
       #
-      # If the above are not defined, the return nil.
+      # If the above are not defined, retruns the personal folder.
       def win32_system_dir #:nodoc:
         win32_shared_path = ENV['APPDATA']
-        if win32_shared_path.nil? && ENV['HOMEDRIVE'] && ENV['HOMEPATH']
-          win32_shared_path = ENV['HOMEDRIVE'] + ENV['HOMEPATH']
+        if !win32_shared_path or win32_shared_path.empty?
+          win32_shared_path = '~'
         end
-        win32_shared_path ||= ENV['USERPROFILE']
-        raise Win32HomeError, "Unable to determine home path environment variable." if
-          win32_shared_path.nil? or win32_shared_path.empty?
-        normalize(File.join(win32_shared_path, 'Rake'))
+        File.expand_path('Rake', win32_shared_path)
       end
-      
-      # Normalize a win32 path so that the slashes are all forward slashes.
-      def normalize(path)
-        path.gsub(/\\/, '/')
-      end
-      
-    end
+    end if windows?
   end
 end
Index: lib/rake.rb
===================================================================
--- lib/rake.rb	(revision 21870)
+++ lib/rake.rb	(revision 21871)
@@ -983,11 +983,7 @@
   end
 
   def rake_system(*cmd)
-    if Rake::Win32.windows?
-      Rake::Win32.rake_system(*cmd)
-    else
-      system(*cmd)
-    end
+    system(*cmd)
   end
   private :rake_system
 
@@ -2364,8 +2360,6 @@
         begin
           if ENV['RAKE_SYSTEM']
             ENV['RAKE_SYSTEM']
-          elsif Win32.windows?
-            Win32.win32_system_dir
           else
             standard_system_dir
           end
@@ -2373,8 +2367,14 @@
     end
     
     # The standard directory containing system wide rake files.
-    def standard_system_dir #:nodoc:
-      File.join(File.expand_path('~'), '.rake')
+    if Win32.windows?
+      def standard_system_dir #:nodoc:
+        Win32.win32_system_dir
+      end
+    else
+      def standard_system_dir #:nodoc:
+        File.expand_path('.rake', '~')
+      end
     end
     private :standard_system_dir
 

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]