summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/io.c22
1 files changed, 14 insertions, 8 deletions
diff --git a/src/io.c b/src/io.c
index f942d564c..3177ec050 100644
--- a/src/io.c
+++ b/src/io.c
@@ -465,23 +465,26 @@ mrb_io_initialize(mrb_state *mrb, mrb_value io)
static void
fptr_finalize(mrb_state *mrb, struct mrb_io *fptr, int quiet)
{
- int n = 0;
+ int saved_errno = 0;
if (fptr == NULL) {
return;
}
if (fptr->fd > 2) {
- n = close(fptr->fd);
- if (n == 0) {
- fptr->fd = -1;
+ if (close(fptr->fd) == -1) {
+ saved_errno = errno;
}
+ fptr->fd = -1;
}
+
if (fptr->fd2 > 2) {
- n = close(fptr->fd2);
- if (n == 0) {
- fptr->fd2 = -1;
+ if (close(fptr->fd2) == -1) {
+ if (saved_errno == 0) {
+ saved_errno = errno;
+ }
}
+ fptr->fd2 = -1;
}
#if !defined(_WIN32) && !defined(_WIN64)
@@ -494,10 +497,13 @@ fptr_finalize(mrb_state *mrb, struct mrb_io *fptr, int quiet)
if (!quiet && pid == fptr->pid) {
io_set_process_status(mrb, pid, status);
}
+ fptr->pid = 0;
+ /* Note: we don't raise an exception when waitpid(3) fails */
}
#endif
- if (!quiet && n != 0) {
+ if (!quiet && saved_errno != 0) {
+ errno = saved_errno;
mrb_sys_fail(mrb, "fptr_finalize failed.");
}
}