mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-28 23:39:02 +00:00
LibWeb: Stop leaking socket fds when sending them over IPC
The implicit constructor for IPC::File does not take ownership of the file, which is surprising.
This commit is contained in:
parent
13abb1b2c7
commit
26ce8ad40f
Notes:
sideshowbarker
2024-07-16 22:58:46 +09:00
Author: https://github.com/ADKaster
Commit: 26ce8ad40f
Pull-request: https://github.com/SerenityOS/serenity/pull/23989
Reviewed-by: https://github.com/trflynn89
2 changed files with 4 additions and 4 deletions
|
@ -80,12 +80,12 @@ WebIDL::ExceptionOr<void> MessagePort::transfer_steps(HTML::TransferDataHolder&
|
|||
// 2. Set dataHolder.[[RemotePort]] to remotePort.
|
||||
auto fd = MUST(m_socket->release_fd());
|
||||
m_socket = nullptr;
|
||||
data_holder.fds.append(fd);
|
||||
data_holder.fds.append(IPC::File(fd, IPC::File::CloseAfterSending));
|
||||
data_holder.data.append(IPC_FILE_TAG);
|
||||
|
||||
auto fd_passing_socket = MUST(m_fd_passing_socket->release_fd());
|
||||
m_fd_passing_socket = nullptr;
|
||||
data_holder.fds.append(fd_passing_socket);
|
||||
data_holder.fds.append(IPC::File(fd_passing_socket, IPC::File::CloseAfterSending));
|
||||
data_holder.data.append(IPC_FILE_TAG);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue