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

ruby-changes:11382

From: takano32 <ko1@a...>
Date: Wed, 18 Mar 2009 17:04:27 +0900 (JST)
Subject: [ruby-changes:11382] Ruby:r23003 (trunk): * ext/socket/ancdata.c: not use pktinfo.ipi_spec_dst if not defined

takano32	2009-03-18 17:04:17 +0900 (Wed, 18 Mar 2009)

  New Revision: 23003

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

  Log:
    * ext/socket/ancdata.c: not use pktinfo.ipi_spec_dst if not defined
    * ext/socket/extconf.rb: define HAVE_IPI_SPEC_DST

  Modified files:
    trunk/ChangeLog
    trunk/ext/socket/ancdata.c
    trunk/ext/socket/extconf.rb

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 23002)
+++ ChangeLog	(revision 23003)
@@ -3,6 +3,11 @@
 	* test/test_syslog.rb (TestSyslog#test_open): check
 	  param after block again. because detect not to call block.
 
+Wed Mar 18 16:54:04 2009  TAKANO Mitsuhiro (takano32)  <tak@n...>
+
+	* ext/socket/ancdata.c: not use pktinfo.ipi_spec_dst if not defined
+	* ext/socket/extconf.rb: define HAVE_IPI_SPEC_DST
+
 Wed Mar 18 16:38:11 2009  Kazuhiro NISHIYAMA  <zn@m...>
 
 	* test/test_syslog.rb (TestSyslog#test_open): check
Index: ext/socket/extconf.rb
===================================================================
--- ext/socket/extconf.rb	(revision 23002)
+++ ext/socket/extconf.rb	(revision 23003)
@@ -310,6 +310,9 @@
   src.sub(%r'^/\*top\*/', '\1'"\n#if defined(IPPROTO_IPV6) && defined(IPV6_PKTINFO)") <<
   "#else\n" << "#error\n" << ">>>>>> no in6_pktinfo <<<<<<\n" << "#endif\n"
 }
+if have_struct_member("struct in_pktinfo", "ipi_spec_dst", headers)
+  $defs[-1] = "-DHAVE_IPI_SPEC_DST"
+end
 
 have_type("struct sockcred", headers)
 have_type("struct cmsgcred", headers)
Index: ext/socket/ancdata.c
===================================================================
--- ext/socket/ancdata.c	(revision 23002)
+++ ext/socket/ancdata.c	(revision 23003)
@@ -414,7 +414,7 @@
 static VALUE
 ancillary_s_ip_pktinfo(int argc, VALUE *argv, VALUE self)
 {
-#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) /* GNU/Linux */
+#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) && defined(HAVE_IPI_SPEC_DST) /* GNU/Linux */
     VALUE v_addr, v_ifindex, v_spec_dst;
     unsigned int ifindex;
     struct sockaddr_in sa;
@@ -477,7 +477,7 @@
 static VALUE
 ancillary_ip_pktinfo(VALUE self)
 {
-#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) /* GNU/Linux */
+#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) && defined(HAVE_IPI_SPEC_DST) /* GNU/Linux */
     int level, type;
     VALUE data;
     struct in_pktinfo pktinfo;
@@ -790,7 +790,7 @@
 }
 #endif
 
-#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) /* GNU/Linux */
+#if defined(IPPROTO_IP) && defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) && defined(HAVE_IPI_SPEC_DST) /* GNU/Linux */
 static int
 anc_inspect_ip_pktinfo(int level, int type, VALUE data, VALUE ret)
 {
@@ -1042,7 +1042,7 @@
 #            if defined(IP_RECVDSTADDR) /* 4.4BSD */
               case IP_RECVDSTADDR: inspected = anc_inspect_ip_recvdstaddr(level, type, data, ret); break;
 #            endif
-#            if defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) /* GNU/Linux */
+#            if defined(IP_PKTINFO) && defined(HAVE_TYPE_STRUCT_IN_PKTINFO) && defined(HAVE_IPI_SPEC_DST) /* GNU/Linux */
               case IP_PKTINFO: inspected = anc_inspect_ip_pktinfo(level, type, data, ret); break;
 #            endif
             }

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

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