summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-15 00:29:10 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-15 00:29:10 +0000
commite4d1745717744eec8800d5b39a5b22c796889b8d (patch)
treebfc2059ea58b150c93d1c317c4dd7303e07e2cd4 /ext
parentd5537936ab39dea835fb6e8fd440321ceabd4bb2 (diff)
* ext/socket/init.c (rsock_init_sock): mswin doesn't have S_IFSOCK
flag in st_mode of struct stat. so, use rb_w32_issocket() function instead of S_ISSOCK macro. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25339 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r--ext/socket/init.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/ext/socket/init.c b/ext/socket/init.c
index 85cc3de4f9..b143dccd5f 100644
--- a/ext/socket/init.c
+++ b/ext/socket/init.c
@@ -45,10 +45,15 @@ rsock_init_sock(VALUE sock, int fd)
rb_io_t *fp;
struct stat sbuf;
+#ifndef _WIN32
if (fstat(fd, &sbuf) < 0)
rb_sys_fail(0);
if (!S_ISSOCK(sbuf.st_mode))
rb_raise(rb_eArgError, "not a socket file descriptor");
+#else
+ if (!rb_w32_is_socket(fd))
+ rb_raise(rb_eArgError, "not a socket file descriptor");
+#endif
MakeOpenFile(sock, fp);
fp->fd = fd;