summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-04-30 14:11:34 +0000
committerkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-04-30 14:11:34 +0000
commit04202dc83dde72db03d72227841c6dddbd41a925 (patch)
tree1e4e936793e2a911c4e90d33dcf6c00374605fab
parent3c68095b8a0d665b9ae94ec3c48fa4f30b3fb86a (diff)
* win32/win32.c (rb_w32_fdcopy): New. This can copy even though
fdset size exceed FD_SETSIZE. * include/ruby/intern.h (rb_fd_copy): use rb_w32_fdcopy() git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@31397 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--include/ruby/intern.h2
-rw-r--r--win32/win32.c12
3 files changed, 19 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 8e1bc5f35d..7f9dc4bdae 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Sat Apr 30 23:10:15 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
+
+ * win32/win32.c (rb_w32_fdcopy): New. This can copy even though
+ fdset size exceed FD_SETSIZE.
+ * include/ruby/intern.h (rb_fd_copy): use rb_w32_fdcopy()
+
Sat Apr 30 20:18:43 2011 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
* thread.c (do_select): Change arugment type to rb_fdset_t.
diff --git a/include/ruby/intern.h b/include/ruby/intern.h
index 41e9e963cd..c66064f8be 100644
--- a/include/ruby/intern.h
+++ b/include/ruby/intern.h
@@ -269,7 +269,7 @@ void rb_fd_term(rb_fdset_t *);
void rb_fd_set(int, rb_fdset_t *);
#define rb_fd_clr(n, f) rb_w32_fdclr((n), (f)->fdset)
#define rb_fd_isset(n, f) rb_w32_fdisset((n), (f)->fdset)
-#define rb_fd_copy(d, s) *((d)->fdset) = *((s)->fdset)
+#define rb_fd_copy(d, s) rb_w32_fdcopy((d), (s))
#define rb_fd_select(n, rfds, wfds, efds, timeout) rb_w32_select((n), (rfds) ? ((rb_fdset_t*)(rfds))->fdset : NULL, (wfds) ? ((rb_fdset_t*)(wfds))->fdset : NULL, (efds) ? ((rb_fdset_t*)(efds))->fdset: NULL, (timeout))
#define rb_fd_resize(n, f) ((void)(f))
diff --git a/win32/win32.c b/win32/win32.c
index 46c57dc47e..a7abbfb4a6 100644
--- a/win32/win32.c
+++ b/win32/win32.c
@@ -2366,6 +2366,18 @@ rb_w32_fdisset(int fd, fd_set *set)
return ret;
}
+void
+rb_w32_fdcopy(rb_fdset_t *dst, const rb_fdset_t *src)
+{
+ if (dst->capa < src->fdset->fd_count) {
+ dst->capa = (src->fdset->fd_count / FD_SETSIZE + 1) * FD_SETSIZE;
+ dst->fdset = xrealloc(dst->fdset, sizeof(unsigned int) + sizeof(SOCKET) * dst->capa);
+ }
+
+ memcpy(dst->fdset->fd_array, src->fdset->fd_array,
+ src->fdset->fd_count * sizeof(src->fdset->fd_array[0]));
+}
+
//
// Networking trampolines
// These are used to avoid socket startup/shutdown overhead in case