From ee1de066788b3e769a0c6765abce682baff2e02d Mon Sep 17 00:00:00 2001 From: gcxfd Date: Tue, 22 Feb 2022 16:34:38 +0800 Subject: [PATCH] net: extract a common Socket struct, reuse it by embedding in TcpSocket & UdpSocket (#13559) --- vlib/net/socket.v | 11 +++++++++++ vlib/net/tcp.v | 8 +------- vlib/net/udp.v | 9 ++------- 3 files changed, 14 insertions(+), 14 deletions(-) create mode 100644 vlib/net/socket.v diff --git a/vlib/net/socket.v b/vlib/net/socket.v new file mode 100644 index 0000000000..0ea920d38b --- /dev/null +++ b/vlib/net/socket.v @@ -0,0 +1,11 @@ +module net + +pub struct Socket { + pub: + handle int +} + +// address gets the address of a socket +pub fn (s &Socket) address() ?Addr { + return addr_from_socket_handle(s.handle) +} diff --git a/vlib/net/tcp.v b/vlib/net/tcp.v index 92305a1449..428629398d 100644 --- a/vlib/net/tcp.v +++ b/vlib/net/tcp.v @@ -296,8 +296,7 @@ pub fn (c &TcpListener) addr() ?Addr { } struct TcpSocket { -pub: - handle int + Socket } fn new_tcp_socket(family AddrFamily) ?TcpSocket { @@ -418,8 +417,3 @@ fn (mut s TcpSocket) connect(a Addr) ? { // otherwise we timed out return err_connect_timed_out } - -// address gets the address of a socket -pub fn (s &TcpSocket) address() ?Addr { - return addr_from_socket_handle(s.handle) -} diff --git a/vlib/net/udp.v b/vlib/net/udp.v index ad4bf3f632..5c10444354 100644 --- a/vlib/net/udp.v +++ b/vlib/net/udp.v @@ -8,8 +8,8 @@ const ( ) struct UdpSocket { - handle int - l Addr + Socket + l Addr // TODO(emily): replace with option again // when i figure out how to coerce it properly mut: @@ -259,11 +259,6 @@ fn new_udp_socket_for_remote(raddr Addr) ?&UdpSocket { return sock } -// address gets the address of a socket -pub fn (s &UdpSocket) address() ?Addr { - return addr_from_socket_handle(s.handle) -} - pub fn (mut s UdpSocket) set_option_bool(opt SocketOption, value bool) ? { // TODO reenable when this `in` operation works again // if opt !in opts_can_set {