summaryrefslogtreecommitdiffstats
path: root/src/lib/net/ISocketMultiplexerJob.h
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@ubuntu.com>2018-04-25 18:07:30 -0400
committerLibravatarUnit 193 <unit193@ubuntu.com>2018-04-25 18:07:30 -0400
commit9b1b081cfdb1c0fb6457278775e0823f8bc10f62 (patch)
treece8840148d8445055ba9e4f12263b2208f234c16 /src/lib/net/ISocketMultiplexerJob.h
Import Upstream version 2.0.0+dfsgupstream/2.0.0+dfsg
Diffstat (limited to 'src/lib/net/ISocketMultiplexerJob.h')
-rw-r--r--src/lib/net/ISocketMultiplexerJob.h76
1 files changed, 76 insertions, 0 deletions
diff --git a/src/lib/net/ISocketMultiplexerJob.h b/src/lib/net/ISocketMultiplexerJob.h
new file mode 100644
index 0000000..ddd3ba5
--- /dev/null
+++ b/src/lib/net/ISocketMultiplexerJob.h
@@ -0,0 +1,76 @@
+/*
+ * barrier -- mouse and keyboard sharing utility
+ * Copyright (C) 2012-2016 Symless Ltd.
+ * Copyright (C) 2004 Chris Schoeneman
+ *
+ * This package is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * found in the file LICENSE that should have accompanied this file.
+ *
+ * This package is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#pragma once
+
+#include "arch/IArchNetwork.h"
+#include "common/IInterface.h"
+
+//! Socket multiplexer job
+/*!
+A socket multiplexer job handles events on a socket.
+*/
+class ISocketMultiplexerJob : public IInterface {
+public:
+ //! @name manipulators
+ //@{
+
+ //! Handle socket event
+ /*!
+ Called by a socket multiplexer when the socket becomes readable,
+ writable, or has an error. It should return itself if the same
+ job can continue to service events, a new job if the socket must
+ be serviced differently, or NULL if the socket should no longer
+ be serviced. The socket is readable if \p readable is true,
+ writable if \p writable is true, and in error if \p error is
+ true.
+
+ This call must not attempt to directly change the job for this
+ socket by calling \c addSocket() or \c removeSocket() on the
+ multiplexer. It must instead return the new job. It can,
+ however, add or remove jobs for other sockets.
+ */
+ virtual ISocketMultiplexerJob*
+ run(bool readable, bool writable, bool error) = 0;
+
+ //@}
+ //! @name accessors
+ //@{
+
+ //! Get the socket
+ /*!
+ Return the socket to multiplex
+ */
+ virtual ArchSocket getSocket() const = 0;
+
+ //! Check for interest in readability
+ /*!
+ Return true if the job is interested in being run if the socket
+ becomes readable.
+ */
+ virtual bool isReadable() const = 0;
+
+ //! Check for interest in writability
+ /*!
+ Return true if the job is interested in being run if the socket
+ becomes writable.
+ */
+ virtual bool isWritable() const = 0;
+
+ //@}
+};