summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoreban <eban@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-05-27 06:34:11 +0000
committereban <eban@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-05-27 06:34:11 +0000
commit67aa5059bb8ab949c2fc3ead75f1834a31259799 (patch)
treeaa510ca635dc5924748916d0de332ebb323528ce
parent31f00aaf2b660964b3df306823c2398569339555 (diff)
* io.c (rb_io_fwrite): workaround for bcc32's fwrite bug.
add errno checking. [ruby-dev:23627] git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@6417 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--io.c6
2 files changed, 10 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 6671ef0f1..e5efdaaef 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Thu May 27 14:53:13 2004 WATANABE Hirofumi <eban@ruby-lang.org>
+
+ * io.c (rb_io_fwrite): workaround for bcc32's fwrite bug.
+ add errno checking. [ruby-dev:23627]
+
Wed May 26 14:19:42 2004 Nobuyoshi Nakada <nobu@ruby-lang.org>
* eval.c (rb_eval, eval): make line number consistent on eval with
diff --git a/io.c b/io.c
index 9cb924ba2..00f97be61 100644
--- a/io.c
+++ b/io.c
@@ -394,7 +394,11 @@ rb_io_fwrite(ptr, len, f)
} while (--n > 0);
#else
while (errno = 0, ptr += (r = fwrite(ptr, 1, n, f)), (n -= r) > 0) {
- if (ferror(f)) {
+ if (ferror(f)
+#if defined __BORLANDC__
+ || errno == EBADF || errno == ENOENT
+#endif
+ ) {
#ifdef __hpux
if (!errno) errno = EAGAIN;
#endif