Commit daffefdb authored by Max Kellermann's avatar Max Kellermann

event/ServerSocket: pass UniqueSocketDescriptor to AddFD()

parent 5fb21fbd
......@@ -24,6 +24,7 @@
#include "config/Data.hxx"
#include "config/Option.hxx"
#include "config/Net.hxx"
#include "net/UniqueSocketDescriptor.hxx"
#include "system/Error.hxx"
#include "util/RuntimeError.hxx"
#include "fs/AllocatedPath.hxx"
......@@ -66,7 +67,7 @@ listen_systemd_activation(ClientListener &listener)
for (int i = SD_LISTEN_FDS_START, end = SD_LISTEN_FDS_START + n;
i != end; ++i)
listener.AddFD(i);
listener.AddFD(UniqueSocketDescriptor(i));
return true;
}
......
......@@ -107,8 +107,8 @@ public:
return ::ToString(address);
}
void SetFD(SocketDescriptor _fd) noexcept {
SocketMonitor::Open(_fd);
void SetFD(UniqueSocketDescriptor _fd) noexcept {
SocketMonitor::Open(_fd.Release());
SocketMonitor::ScheduleRead();
}
......@@ -194,7 +194,7 @@ OneServerSocket::Open()
/* register in the EventLoop */
SetFD(_fd.Release());
SetFD(std::move(_fd));
}
ServerSocket::ServerSocket(EventLoop &_loop) noexcept
......@@ -291,18 +291,16 @@ ServerSocket::AddAddress(AllocatedSocketAddress &&address) noexcept
}
void
ServerSocket::AddFD(int _fd)
ServerSocket::AddFD(UniqueSocketDescriptor fd)
{
assert(_fd >= 0);
SocketDescriptor fd(_fd);
assert(fd.IsDefined());
StaticSocketAddress address = fd.GetLocalAddress();
if (!address.IsDefined())
throw MakeSocketError("Failed to get socket address");
OneServerSocket &s = AddAddress(address);
s.SetFD(fd);
s.SetFD(std::move(fd));
}
#ifdef HAVE_TCP
......
......@@ -107,7 +107,7 @@ public:
*
* Throws #std::runtime_error on error.
*/
void AddFD(int fd);
void AddFD(UniqueSocketDescriptor fd);
bool IsEmpty() const noexcept {
return sockets.empty();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment