From 297fdd4075c18c8102ef7a453bc10675cccef3a5 Mon Sep 17 00:00:00 2001 From: PePerRoNii Date: Wed, 11 Jun 2025 13:05:16 +0700 Subject: [PATCH] added freebsd implementation NOTE: bsd's tcp_recv_error does not cover all cases --- core/net/socket_freebsd.odin | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/core/net/socket_freebsd.odin b/core/net/socket_freebsd.odin index b510346ba..681d0e038 100644 --- a/core/net/socket_freebsd.odin +++ b/core/net/socket_freebsd.odin @@ -153,6 +153,20 @@ _bound_endpoint :: proc(sock: Any_Socket) -> (ep: Endpoint, err: Listen_Error) { return } +@(private) +_peer_endpoint :: proc(sock: Any_Socket) -> (ep: Endpoint, err: TCP_Recv_Error) { + sockaddr: freebsd.Socket_Address_Storage + + errno := freebsd.getpeername(cast(Fd)any_socket_to_socket(sock), &sockaddr) + if errno != nil { + err = _tcp_recv_error(errno) + return + } + + ep = _sockaddr_to_endpoint(&sockaddr) + return +} + @(private) _accept_tcp :: proc(sock: TCP_Socket, options := DEFAULT_TCP_OPTIONS) -> (client: TCP_Socket, source: Endpoint, err: Accept_Error) { sockaddr: freebsd.Socket_Address_Storage