Commit 0c1a0016 authored by Max Kellermann's avatar Max Kellermann

system/Event{FD,Pipe}: throw exception on error

parent 148c38fb
......@@ -116,7 +116,11 @@ class EventLoop final : SocketMonitor
ThreadId thread = ThreadId::Null();
public:
/**
* Throws on error.
*/
explicit EventLoop(ThreadId _thread);
EventLoop():EventLoop(ThreadId::GetCurrent()) {}
~EventLoop() noexcept;
......
......@@ -20,7 +20,7 @@
#include "config.h"
#ifdef USE_EVENTFD
#include "EventFD.hxx"
#include "system/FatalError.hxx"
#include "system/Error.hxx"
#include "Compiler.h"
#include <assert.h>
......@@ -29,7 +29,7 @@
EventFD::EventFD()
{
if (!fd.CreateEventFD(0))
FatalSystemError("eventfd() failed");
throw MakeErrno("eventfd() failed");
}
bool
......
......@@ -25,13 +25,14 @@
/**
* A class that wraps eventfd().
*
* Errors in the constructor are fatal.
*/
class EventFD {
UniqueFileDescriptor fd;
public:
/**
* Throws on error.
*/
EventFD();
int Get() const {
......
......@@ -31,7 +31,11 @@ class EventPipe {
int fds[2];
public:
/**
* Throws on error.
*/
EventPipe();
~EventPipe();
EventPipe(const EventPipe &other) = delete;
......
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