diff options
| author | Takeshi Watanabe <[email protected]> | 2017-12-09 18:44:24 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-12-14 00:05:23 +0900 |
| commit | 949bf6ca4306125b0ba51d8b09a1f4d642c24753 (patch) | |
| tree | 0c719cb0cfc4bfa1b897892ac47722f9fec1943f /mrbgems/mruby-io/src | |
| parent | 2300c9f7373e3785d36323b5d2820efb40fb1fab (diff) | |
| download | mruby-949bf6ca4306125b0ba51d8b09a1f4d642c24753.tar.gz mruby-949bf6ca4306125b0ba51d8b09a1f4d642c24753.zip | |
Fix socket closing by using `closesocket` API in windows instead.
Diffstat (limited to 'mrbgems/mruby-io/src')
| -rw-r--r-- | mrbgems/mruby-io/src/io.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/mrbgems/mruby-io/src/io.c b/mrbgems/mruby-io/src/io.c index 64729e05c..b2320038b 100644 --- a/mrbgems/mruby-io/src/io.c +++ b/mrbgems/mruby-io/src/io.c @@ -578,8 +578,18 @@ fptr_finalize(mrb_state *mrb, struct mrb_io *fptr, int quiet) } if (fptr->fd > 2) { - if (close(fptr->fd) == -1) { - saved_errno = errno; +#ifdef _WIN32 + if (fptr->is_socket) { + if (closesocket(fptr->fd) != 0) { + saved_errno = WSAGetLastError(); + } + fptr->fd = -1; + } +#endif + if (fptr->fd != -1) { + if (close(fptr->fd) == -1) { + saved_errno = errno; + } } fptr->fd = -1; } |
