aboutsummaryrefslogtreecommitdiff
path: root/src/event/SocketMonitor.hxx
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2013-01-30 10:39:17 +0100
committerMax Kellermann <max@duempel.org>2013-01-30 10:39:17 +0100
commit73f36858bb4026eff7c9e44007c87e870d324a5f (patch)
treebd42fc660f2a29e8553563dc03bccd51a7e54e5f /src/event/SocketMonitor.hxx
parentfe3f0332f71258354b70e5db685b56934f0df703 (diff)
event/SocketMonitor: add methods Read(), Write()
Diffstat (limited to 'src/event/SocketMonitor.hxx')
-rw-r--r--src/event/SocketMonitor.hxx8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/event/SocketMonitor.hxx b/src/event/SocketMonitor.hxx
index ddfc21a4..b8ded196 100644
--- a/src/event/SocketMonitor.hxx
+++ b/src/event/SocketMonitor.hxx
@@ -24,7 +24,10 @@
#include <glib.h>
+#include <type_traits>
+
#include <assert.h>
+#include <stddef.h>
#ifdef WIN32
/* ERRORis a WIN32 macro that poisons our namespace; this is a
@@ -54,6 +57,8 @@ public:
static constexpr unsigned ERROR = G_IO_ERR;
static constexpr unsigned HANGUP = G_IO_HUP;
+ typedef std::make_signed<size_t>::type ssize_t;
+
SocketMonitor(EventLoop &_loop)
:fd(-1), loop(_loop), source(nullptr) {}
@@ -106,6 +111,9 @@ public:
poll.events &= ~WRITE;
}
+ ssize_t Read(void *data, size_t length);
+ ssize_t Write(const void *data, size_t length);
+
protected:
virtual void OnSocketReady(unsigned flags) = 0;