summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-io/src
diff options
context:
space:
mode:
authorTakeshi Watanabe <[email protected]>2017-12-09 18:44:24 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-12-14 00:05:23 +0900
commit949bf6ca4306125b0ba51d8b09a1f4d642c24753 (patch)
tree0c719cb0cfc4bfa1b897892ac47722f9fec1943f /mrbgems/mruby-io/src
parent2300c9f7373e3785d36323b5d2820efb40fb1fab (diff)
downloadmruby-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.c14
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;
}