aboutsummaryrefslogtreecommitdiff
path: root/core/net/socket_freebsd.odin
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2024-09-19 12:53:42 +0100
committerGitHub <noreply@github.com>2024-09-19 12:53:42 +0100
commit327ca2ab717ae288e74bbedd768f252770159470 (patch)
tree70257c863cd84f7cdda6af27ed9c655afa2db959 /core/net/socket_freebsd.odin
parent68960e7d0a3cc9a0c3c8a7f5589ae5c0e5a966f1 (diff)
parent652557bfcd64deccf018e96817a001fd9c4d69a1 (diff)
Merge pull request #4261 from laytan/net-bound-endpoint
net: add `bound_endpoint` procedure
Diffstat (limited to 'core/net/socket_freebsd.odin')
-rw-r--r--core/net/socket_freebsd.odin14
1 files changed, 14 insertions, 0 deletions
diff --git a/core/net/socket_freebsd.odin b/core/net/socket_freebsd.odin
index 8ac69907f..0f3a85cbb 100644
--- a/core/net/socket_freebsd.odin
+++ b/core/net/socket_freebsd.odin
@@ -150,6 +150,20 @@ _listen_tcp :: proc(interface_endpoint: Endpoint, backlog := 1000) -> (socket: T
}
@(private)
+_bound_endpoint :: proc(sock: Any_Socket) -> (ep: Endpoint, err: Network_Error) {
+ sockaddr: freebsd.Socket_Address_Storage
+
+ errno := freebsd.getsockname(cast(Fd)any_socket_to_socket(sock), &sockaddr)
+ if errno != nil {
+ err = cast(Listen_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: Network_Error) {
sockaddr: freebsd.Socket_Address_Storage