aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--io.c7
2 files changed, 12 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 776b6b1a4b..fc6c7b9a8d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Thu Jan 15 12:58:26 2004 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * io.c (argf_read): do not append EOF. (ruby-bugs-ja:PR#585)
+
+ * io.c (rb_io_fwrite): ad-hockery hack to get rid of HP-UX stdio
+ weird behavior. [ruby-dev:22424]
+
Wed Jan 14 21:13:06 2004 Nobuyoshi Nakada <nobu@ruby-lang.org>
* test/inlinetest.rb (InlineTest::eval_part): eval under the top
diff --git a/io.c b/io.c
index f49fce3685..cf629009a2 100644
--- a/io.c
+++ b/io.c
@@ -394,8 +394,11 @@ rb_io_fwrite(ptr, len, f)
}
} while (--n > 0);
#else
- while (ptr += (r = fwrite(ptr, 1, n, f)), (n -= r) > 0) {
+ while (errno = 0, ptr += (r = fwrite(ptr, 1, n, f)), (n -= r) > 0) {
if (ferror(f)) {
+#ifdef __hpux
+ if (!errno) errno = EAGAIN;
+#endif
if (rb_io_wait_writable(fileno(f))) {
clearerr(f);
continue;
@@ -4939,7 +4942,7 @@ argf_read(argc, argv)
tmp = io_read(argc, argv, current_file);
}
if (NIL_P(str)) str = tmp;
- else rb_str_append(str, tmp);
+ else if (!NIL_P(tmp)) rb_str_append(str, tmp);
if (NIL_P(tmp) || NIL_P(length)) {
if (next_p != -1) {
argf_close(current_file);