diff options
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | ext/socket/socket.c | 19 |
2 files changed, 18 insertions, 8 deletions
@@ -1,7 +1,12 @@ +Fri Nov 7 10:23:24 2003 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * ext/socket/socket.c (make_hostent): get rid of SEGV on aliases + lookup failure. (ruby-bugs:PR#1215) + Fri Nov 7 04:08:05 2003 UENO Katsuhiro <katsu@blue.sky.or.jp> * ext/zlib/zlib.c (Init_zlib): define Zlib::GzipReader#each_line as - an alias of Zlib::GzipReader#each. + an alias of Zlib::GzipReader#each. Fri Nov 7 01:03:16 2003 Yukihiro Matsumoto <matz@ruby-lang.org> diff --git a/ext/socket/socket.c b/ext/socket/socket.c index aa568cf6b3..e30d25404d 100644 --- a/ext/socket/socket.c +++ b/ext/socket/socket.c @@ -1033,8 +1033,6 @@ make_hostent(addr, ipaddr) ary = rb_ary_new(); rb_ary_push(ary, rb_str_new2(addr->ai_canonname)); - names = rb_ary_new(); - rb_ary_push(ary, names); #if defined(HAVE_GETIPNODEBYNAME) { int error; @@ -1046,14 +1044,21 @@ make_hostent(addr, ipaddr) #else h = gethostbyname(addr->ai_canonname); #endif - if (h->h_aliases != NULL) { - for (pch = h->h_aliases; *pch; pch++) { - rb_ary_push(names, rb_str_new2(*pch)); + if (h) { + names = rb_ary_new(); + if (h->h_aliases != NULL) { + for (pch = h->h_aliases; *pch; pch++) { + rb_ary_push(names, rb_str_new2(*pch)); + } } - } #if defined(HAVE_GETIPNODEBYNAME) - freehostent(h); + freehostent(h); #endif + } + else { + names = rb_ary_new2(0); + } + rb_ary_push(ary, names); rb_ary_push(ary, INT2NUM(addr->ai_family)); for (ai = addr; ai; ai = ai->ai_next) { rb_ary_push(ary, (*ipaddr)(ai->ai_addr, ai->ai_addrlen)); |