[前][次][番号順一覧][スレッド一覧]

ruby-changes:20608

From: akr <ko1@a...>
Date: Sun, 24 Jul 2011 20:07:54 +0900 (JST)
Subject: [ruby-changes:20608] akr:r32656 (trunk, ruby_1_9_3): * ext/socket/extconf.rb: fix the recvmsg test.

akr	2011-07-24 20:04:11 +0900 (Sun, 24 Jul 2011)

  New Revision: 32656

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=32656

  Log:
    * ext/socket/extconf.rb: fix the recvmsg test.

  Modified files:
    branches/ruby_1_9_3/ChangeLog
    branches/ruby_1_9_3/ext/socket/extconf.rb
    trunk/ChangeLog
    trunk/ext/socket/extconf.rb

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 32655)
+++ ChangeLog	(revision 32656)
@@ -1,3 +1,7 @@
+Sun Jul 24 20:02:31 2011  Tanaka Akira  <akr@f...>
+
+	* ext/socket/extconf.rb: fix the recvmsg test.
+
 Sun Jul 24 08:42:51 2011  Tanaka Akira  <akr@f...>
 
 	* ext/socket/extconf.rb: test recvmsg allocates file descriptors for
Index: ext/socket/extconf.rb
===================================================================
--- ext/socket/extconf.rb	(revision 32655)
+++ ext/socket/extconf.rb	(revision 32656)
@@ -147,7 +147,7 @@
     } s_cmsg, r_cmsg;
     struct iovec s_iov, r_iov;
     char s_buf[1], r_buf[1];
-    struct stat statbuf;
+    struct stat s_statbuf, r_statbuf;
 
     s_fd = 0; /* stdin */
 
@@ -198,13 +198,23 @@
 
     if (r_msg.msg_controllen < CMSG_LEN(sizeof(int))) exit(EXIT_FAILURE);
     if (r_cmsg.hdr.cmsg_len < CMSG_LEN(sizeof(int))) exit(EXIT_FAILURE);
-    memcpy((char *)&r_fd, CMSG_DATA(&s_cmsg.hdr), sizeof(int));
+    memcpy((char *)&r_fd, CMSG_DATA(&r_cmsg.hdr), sizeof(int));
 
     if (r_fd < 0) exit(EXIT_FAILURE);
 
-    ret = fstat(r_fd, &statbuf);
+    if (r_fd == s_fd) exit(EXIT_FAILURE);
+
+    ret = fstat(s_fd, &s_statbuf);
     if (ret == -1) { exit(EXIT_FAILURE); }
 
+    ret = fstat(r_fd, &r_statbuf);
+    if (ret == -1) { exit(EXIT_FAILURE); }
+
+    if (s_statbuf.st_dev != r_statbuf.st_dev ||
+        s_statbuf.st_ino != r_statbuf.st_ino) {
+        exit(EXIT_FAILURE);
+    }
+
     return EXIT_SUCCESS;
 }
 EOF
Index: ruby_1_9_3/ChangeLog
===================================================================
--- ruby_1_9_3/ChangeLog	(revision 32655)
+++ ruby_1_9_3/ChangeLog	(revision 32656)
@@ -1,3 +1,7 @@
+Sun Jul 24 20:02:31 2011  Tanaka Akira  <akr@f...>
+
+	* ext/socket/extconf.rb: fix the recvmsg test.
+
 Sun Jul 24 08:42:51 2011  Tanaka Akira  <akr@f...>
 
 	* ext/socket/extconf.rb: test recvmsg allocates file descriptors for
Index: ruby_1_9_3/ext/socket/extconf.rb
===================================================================
--- ruby_1_9_3/ext/socket/extconf.rb	(revision 32655)
+++ ruby_1_9_3/ext/socket/extconf.rb	(revision 32656)
@@ -147,7 +147,7 @@
     } s_cmsg, r_cmsg;
     struct iovec s_iov, r_iov;
     char s_buf[1], r_buf[1];
-    struct stat statbuf;
+    struct stat s_statbuf, r_statbuf;
 
     s_fd = 0; /* stdin */
 
@@ -198,13 +198,23 @@
 
     if (r_msg.msg_controllen < CMSG_LEN(sizeof(int))) exit(EXIT_FAILURE);
     if (r_cmsg.hdr.cmsg_len < CMSG_LEN(sizeof(int))) exit(EXIT_FAILURE);
-    memcpy((char *)&r_fd, CMSG_DATA(&s_cmsg.hdr), sizeof(int));
+    memcpy((char *)&r_fd, CMSG_DATA(&r_cmsg.hdr), sizeof(int));
 
     if (r_fd < 0) exit(EXIT_FAILURE);
 
-    ret = fstat(r_fd, &statbuf);
+    if (r_fd == s_fd) exit(EXIT_FAILURE);
+
+    ret = fstat(s_fd, &s_statbuf);
     if (ret == -1) { exit(EXIT_FAILURE); }
 
+    ret = fstat(r_fd, &r_statbuf);
+    if (ret == -1) { exit(EXIT_FAILURE); }
+
+    if (s_statbuf.st_dev != r_statbuf.st_dev ||
+        s_statbuf.st_ino != r_statbuf.st_ino) {
+        exit(EXIT_FAILURE);
+    }
+
     return EXIT_SUCCESS;
 }
 EOF

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]