From df872595b9893d6029dee47ef5394a9f138771d4 Mon Sep 17 00:00:00 2001 From: Tait Hoyem Date: Thu, 30 Nov 2023 11:13:11 -0700 Subject: [PATCH] Added safety comments above unsafe blocks within safe functions --- src/stdnet/socket.rs | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/stdnet/socket.rs b/src/stdnet/socket.rs index 982387c..f4feb4d 100644 --- a/src/stdnet/socket.rs +++ b/src/stdnet/socket.rs @@ -303,18 +303,21 @@ impl IntoRawSocket for Socket { impl AsSocket for Socket { fn as_socket(&self) -> BorrowedSocket<'_> { + // SAFETY: Although the lifetime is elided, it is indeed a borrow from self, and the returned value can not outlive the lifetime of the Socket. unsafe { BorrowedSocket::borrow_raw(self.as_raw_socket()) } } } impl From for OwnedSocket { fn from(sock: Socket) -> OwnedSocket { + // SAFETY: This is safe because it consumes the socket using the `OwnedSocket::from(Socket)`, or by using `Socket.into::()` unsafe { OwnedSocket::from_raw_socket(sock.into_raw_socket()) } } } impl From for Socket { fn from(owned: OwnedSocket) -> Socket { + // SAFETY: This is safe because it consumes the socket using the `Socket::from(OwnedSocket)`, or by using `OwnedSocket.into::()` unsafe { Socket::from_raw_socket(owned.into_raw_socket()) } } }