summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-17 04:38:27 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-17 04:38:27 +0000
commitc7550e2a3d7b048e3c2b516fd5c7449c32f0a105 (patch)
tree55583f7cdb3b93288403298ca10a33b6eb26635e
parentae487eda6e961a7010b1a6914cb05100fdf207a5 (diff)
* ext/socket/init.c (rsock_getfamily): return AF_UNSPEC if getsockname
is failed. [ruby-core:24383] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24160 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--ext/socket/init.c2
2 files changed, 6 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 3d68349b14..7f5d08fb8b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Jul 17 13:35:47 2009 Tanaka Akira <akr@fsij.org>
+
+ * ext/socket/init.c (rsock_getfamily): return AF_UNSPEC if getsockname
+ is failed. [ruby-core:24383]
+
Fri Jul 17 01:22:57 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
* array.c (recursive_join): raise ArgumentError for joining
diff --git a/ext/socket/init.c b/ext/socket/init.c
index 81237536c9..ed85e0b503 100644
--- a/ext/socket/init.c
+++ b/ext/socket/init.c
@@ -532,7 +532,7 @@ rsock_getfamily(int sockfd)
ss.ss_family = AF_UNSPEC;
if (getsockname(sockfd, (struct sockaddr*)&ss, &sslen) < 0)
- rb_sys_fail("getsockname(2)");
+ return AF_UNSPEC;
return ss.ss_family;
}