diff options
author | Arnold D. Robbins <arnold@skeeve.com> | 2017-04-11 22:24:41 +0300 |
---|---|---|
committer | Arnold D. Robbins <arnold@skeeve.com> | 2017-04-11 22:24:41 +0300 |
commit | 967e4b9ec9e1b7cc7ca9968f6fe822f3b1155f53 (patch) | |
tree | 25d98488c29b77686670ea66c6647701493de63a /io.c | |
parent | 75981b3d127c3c97329b5b085bddebf3b40e797d (diff) | |
parent | bd6dc293e35fdeac05bd1577593e111fd09d22b7 (diff) | |
download | egawk-967e4b9ec9e1b7cc7ca9968f6fe822f3b1155f53.tar.gz egawk-967e4b9ec9e1b7cc7ca9968f6fe822f3b1155f53.tar.bz2 egawk-967e4b9ec9e1b7cc7ca9968f6fe822f3b1155f53.zip |
Merge branch 'master' into feature/api-mpfr
Diffstat (limited to 'io.c')
-rw-r--r-- | io.c | 12 |
1 files changed, 12 insertions, 0 deletions
@@ -1399,6 +1399,10 @@ non_fatal_flush_std_file(FILE *fp) bool is_fatal = ! is_non_fatal_std(fp); if (is_fatal) { +#ifdef __MINGW32__ + if (errno == 0 || errno == EINVAL) + w32_maybe_set_errno(); +#endif if (errno == EPIPE) die_via_sigpipe(); else @@ -1494,12 +1498,20 @@ close_io(bool *stdio_problem) *stdio_problem = false; /* we don't warn about stdout/stderr if EPIPE, but we do error exit */ if (fflush(stdout) != 0) { +#ifdef __MINGW32__ + if (errno == 0 || errno == EINVAL) + w32_maybe_set_errno(); +#endif if (errno != EPIPE) warning(_("error writing standard output (%s)"), strerror(errno)); status++; *stdio_problem = true; } if (fflush(stderr) != 0) { +#ifdef __MINGW32__ + if (errno == 0 || errno == EINVAL) + w32_maybe_set_errno(); +#endif if (errno != EPIPE) warning(_("error writing standard error (%s)"), strerror(errno)); status++; |