diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-02-10 14:31:21 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-02-10 14:31:21 +0000 |
commit | cc779adb39686dd3a388685fadc5bf41d829d069 (patch) | |
tree | 48480d919e055e8417bd573e463defd0e10f9360 /ext | |
parent | 91c1bb9d449206ce57036fb9c458f44b0bffc9d2 (diff) | |
download | ruby-cc779adb39686dd3a388685fadc5bf41d829d069.tar.gz ruby-cc779adb39686dd3a388685fadc5bf41d829d069.tar.xz ruby-cc779adb39686dd3a388685fadc5bf41d829d069.zip |
* ext/socket/basicsocket.c (bsock_getpeername): use struct
sockaddr_storage.
(bsock_local_address): ditto.
(bsock_remote_address): ditto.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@22213 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r-- | ext/socket/basicsocket.c | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/ext/socket/basicsocket.c b/ext/socket/basicsocket.c index 7690fb60e..88f8b1ba6 100644 --- a/ext/socket/basicsocket.c +++ b/ext/socket/basicsocket.c @@ -351,14 +351,14 @@ bsock_getsockname(VALUE sock) static VALUE bsock_getpeername(VALUE sock) { - char buf[1024]; + struct sockaddr_storage buf; socklen_t len = sizeof buf; rb_io_t *fptr; GetOpenFile(sock, fptr); - if (getpeername(fptr->fd, (struct sockaddr*)buf, &len) < 0) + if (getpeername(fptr->fd, (struct sockaddr*)&buf, &len) < 0) rb_sys_fail("getpeername(2)"); - return rb_str_new(buf, len); + return rb_str_new((char*)&buf, len); } /* @@ -377,14 +377,14 @@ bsock_getpeername(VALUE sock) static VALUE bsock_local_address(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 fd_socket_addrinfo(fptr->fd, (struct sockaddr *)buf, len); + return fd_socket_addrinfo(fptr->fd, (struct sockaddr *)&buf, len); } /* @@ -405,14 +405,14 @@ bsock_local_address(VALUE sock) static VALUE bsock_remote_address(VALUE sock) { - char buf[1024]; + struct sockaddr_storage buf; socklen_t len = sizeof buf; rb_io_t *fptr; GetOpenFile(sock, fptr); - if (getpeername(fptr->fd, (struct sockaddr*)buf, &len) < 0) + if (getpeername(fptr->fd, (struct sockaddr*)&buf, &len) < 0) rb_sys_fail("getpeername(2)"); - return fd_socket_addrinfo(fptr->fd, (struct sockaddr *)buf, len); + return fd_socket_addrinfo(fptr->fd, (struct sockaddr *)&buf, len); } /* |