summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-10-06 11:11:07 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-10-06 11:11:07 +0000
commit549525ae5610df980290d8081b3d60a756a0a8f1 (patch)
tree6245fc334b333763c21439c593e0cea72a1c9f77
parent4eaa23c83d56cef645c1a6448426737721340a4d (diff)
downloadruby-549525ae5610df980290d8081b3d60a756a0a8f1.tar.gz
ruby-549525ae5610df980290d8081b3d60a756a0a8f1.tar.xz
ruby-549525ae5610df980290d8081b3d60a756a0a8f1.zip
* ext/socket/extconf.rb: check recvmsg even if sendmsg is exists.
* ext/socket/socket.c (thread_read_select): restored. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@4707 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog6
-rw-r--r--ext/socket/extconf.rb2
-rw-r--r--ext/socket/socket.c13
3 files changed, 20 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index f55752a75..ec8a59056 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Sun Oct 5 23:27:09 2003 Tanaka Akira <akr@m17n.org>
+
+ * ext/socket/extconf.rb: check recvmsg even if sendmsg is exists.
+
+ * ext/socket/socket.c (thread_read_select): restored.
+
Mon Oct 6 16:23:38 2003 Nobuyoshi Nakada <nobu@ruby-lang.org>
* marshal.c (w_object): wrong method name in the message.
diff --git a/ext/socket/extconf.rb b/ext/socket/extconf.rb
index 234f37317..5cdc949d8 100644
--- a/ext/socket/extconf.rb
+++ b/ext/socket/extconf.rb
@@ -194,7 +194,7 @@ end
have_header("netinet/tcp.h") if not /cygwin/ =~ RUBY_PLATFORM # for cygwin 1.1.5
have_header("netinet/udp.h")
-if have_func("sendmsg") or have_func("recvmsg")
+if have_func("sendmsg") | have_func("recvmsg")
have_struct_member('struct msghdr', 'msg_control', header=['sys/types.h', 'sys/socket.h'])
have_struct_member('struct msghdr', 'msg_accrights', header=['sys/types.h', 'sys/socket.h'])
end
diff --git a/ext/socket/socket.c b/ext/socket/socket.c
index ca7bdc50c..95ec45bfe 100644
--- a/ext/socket/socket.c
+++ b/ext/socket/socket.c
@@ -1502,6 +1502,19 @@ unix_send_io(sock, val)
#endif
}
+#if defined(HAVE_RECVMSG) && (defined(HAVE_ST_MSG_CONTROL) || defined(HAVE_ST_MSG_ACCRIGHTS))
+static void
+thread_read_select(fd)
+ int fd;
+{
+ fd_set fds;
+
+ FD_ZERO(&fds);
+ FD_SET(fd, &fds);
+ rb_thread_select(fd+1, &fds, 0, 0, 0);
+}
+#endif
+
static VALUE
unix_recv_io(argc, argv, sock)
int argc;