mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 02:12:09 -05:00
LocalSocket: Make recvfrom() return 0 to signal EOF when peer is gone
Once the peer has disconnected, recvfrom() should always return 0 once the socket buffer has been drained.
This commit is contained in:
parent
17670ae725
commit
910fab564e
1 changed files with 10 additions and 2 deletions
|
@ -234,16 +234,24 @@ ssize_t LocalSocket::recvfrom(FileDescription& description, void* buffer, size_t
|
|||
auto role = this->role(description);
|
||||
if (role == Role::Accepted) {
|
||||
if (!description.is_blocking()) {
|
||||
if (m_for_server.is_empty())
|
||||
if (m_for_server.is_empty()) {
|
||||
if (!has_attached_peer(description))
|
||||
return 0;
|
||||
return -EAGAIN;
|
||||
}
|
||||
}
|
||||
ASSERT(!m_for_server.is_empty());
|
||||
return m_for_server.read((u8*)buffer, buffer_size);
|
||||
}
|
||||
if (role == Role::Connected) {
|
||||
if (!description.is_blocking()) {
|
||||
if (m_for_client.is_empty())
|
||||
if (m_for_client.is_empty()) {
|
||||
if (!has_attached_peer(description))
|
||||
return 0;
|
||||
return -EAGAIN;
|
||||
}
|
||||
}
|
||||
ASSERT(!m_for_client.is_empty());
|
||||
return m_for_client.read((u8*)buffer, buffer_size);
|
||||
}
|
||||
ASSERT_NOT_REACHED();
|
||||
|
|
Loading…
Add table
Reference in a new issue