From f1e332beb5047e5c91e0098606eef7d90830f35e Mon Sep 17 00:00:00 2001 From: nobu Date: Sat, 19 Aug 2006 02:29:18 +0000 Subject: [PATCH] * file.c (rb_file_s_rename): use errno if set properly. fixed: [ruby-dev:29293] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@10747 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ file.c | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index b0ee6995cc..f686840c33 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Sat Aug 19 11:28:08 2006 Nobuyoshi Nakada + + * file.c (rb_file_s_rename): use errno if set properly. + fixed: [ruby-dev:29293] + Fri Aug 18 01:05:57 2006 Yukihiro Matsumoto * lib/cgi.rb (CGI::out): specify -m0 to disable MIME decode. a diff --git a/file.c b/file.c index 790b0d3a2a..544604c7fa 100644 --- a/file.c +++ b/file.c @@ -2232,10 +2232,16 @@ rb_file_s_rename(klass, from, to) src = StringValueCStr(from); dst = StringValueCStr(to); +#if defined __CYGWIN__ + errno = 0; +#endif if (rename(src, dst) < 0) { #if defined __CYGWIN__ extern unsigned long __attribute__((stdcall)) GetLastError(void); - errno = GetLastError(); /* This is a Cygwin bug */ + if (errno == 0) { /* This is a bug of old Cygwin */ + /* incorrect as cygwin errno, but the last resort */ + errno = GetLastError(); + } #elif defined DOSISH && !defined _WIN32 if (errno == EEXIST #if defined (__EMX__)