From 8977fe1e3617cff23c01db396a0617b6ca5da56e Mon Sep 17 00:00:00 2001 From: akr Date: Mon, 9 Feb 2009 11:19:57 +0000 Subject: * ext/socket/basicsocket.c (bsock_getsockname): use sockaddr_storage. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22181 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ext/socket/basicsocket.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'ext/socket/basicsocket.c') diff --git a/ext/socket/basicsocket.c b/ext/socket/basicsocket.c index fdd2ce7221..f6fb9f264a 100644 --- a/ext/socket/basicsocket.c +++ b/ext/socket/basicsocket.c @@ -326,14 +326,14 @@ bsock_getsockopt(VALUE sock, VALUE lev, VALUE optname) static VALUE bsock_getsockname(VALUE sock) { - char buf[1024]; + struct sockaddr_storage buf; socklen_t len = sizeof buf; rb_io_t *fptr; GetOpenFile(sock, fptr); - if (getsockname(fptr->fd, (struct sockaddr*)buf, &len) < 0) + if (getsockname(fptr->fd, (struct sockaddr*)&buf, &len) < 0) rb_sys_fail("getsockname(2)"); - return rb_str_new(buf, len); + return rb_str_new((char*)&buf, len); } /* -- cgit v1.2.3