From e1aec4aed8e745c41ab36ad8914285f011cd8b4f Mon Sep 17 00:00:00 2001 From: nobu Date: Tue, 20 Mar 2007 00:12:51 +0000 Subject: [PATCH] * process.c (rb_fork): flush stdouts always before fork(2). fixed: [ruby-dev:30612] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12103 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ process.c | 12 +++++++++--- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 7778cd7020..17b7ee82f2 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Tue Mar 20 09:13:10 2007 Nobuyoshi Nakada + + * process.c (rb_fork): flush stdouts always before fork(2). + fixed: [ruby-dev:30612] + Tue Mar 20 01:38:48 2007 Nobuyoshi Nakada * thread.c (thread_start_func_2): store the result of first_func diff --git a/process.c b/process.c index 98a65b0433..c6caf5f7f2 100644 --- a/process.c +++ b/process.c @@ -1343,10 +1343,16 @@ rb_fork(int *status, int (*chfunc)(void*), void *charg) #endif #ifndef __VMS - rb_io_flush(rb_stdout); - rb_io_flush(rb_stderr); +#define prefork() ( \ + rb_io_flush(rb_stdout), \ + rb_io_flush(rb_stderr) \ + ) +#else +#define prefork() ((void)0) #endif + prefork(); + #ifdef FD_CLOEXEC if (chfunc) { if (pipe(ep)) return -1; @@ -1356,7 +1362,7 @@ rb_fork(int *status, int (*chfunc)(void*), void *charg) } } #endif - while ((pid = fork()) < 0) { + for (; (pid = fork()) < 0; prefork()) { switch (errno) { case EAGAIN: #if defined(EWOULDBLOCK) && EWOULDBLOCK != EAGAIN