diff options
author | Attila Molnar <attilamolnar@hush.com> | 2015-04-15 23:45:12 +0200 |
---|---|---|
committer | Attila Molnar <attilamolnar@hush.com> | 2015-04-15 23:45:12 +0200 |
commit | dad754237bf28b9cb7733f7607e128569897eb10 (patch) | |
tree | c1c4bc48209ba6ea0c67f2e825c82bb87e3d30ea /include/inspsocket.h | |
parent | 37de78450964b42741dffa51329251cdef28119f (diff) | |
parent | a42246b2f19d429a01fc901b7f49893764676499 (diff) |
Merge branch 'master+ehdispatch'
Diffstat (limited to 'include/inspsocket.h')
-rw-r--r-- | include/inspsocket.h | 35 |
1 files changed, 27 insertions, 8 deletions
diff --git a/include/inspsocket.h b/include/inspsocket.h index 1bcfbea09..221b92cc6 100644 --- a/include/inspsocket.h +++ b/include/inspsocket.h @@ -113,6 +113,16 @@ class CoreExport StreamSocket : public EventHandler size_t sendq_len; /** Error - if nonempty, the socket is dead, and this is the reason. */ std::string error; + + /** Check if the socket has an error set, if yes, call OnError + * @param err Error to pass to OnError() + */ + void CheckError(BufferedSocketError err); + + /** Read data from the socket into the recvq, if successful call OnDataReady() + */ + void DoRead(); + protected: std::string recvq; public: @@ -120,14 +130,23 @@ class CoreExport StreamSocket : public EventHandler IOHook* GetIOHook() const; void AddIOHook(IOHook* hook); void DelIOHook(); - /** Handle event from socket engine. - * This will call OnDataReady if there is *new* data in recvq + + /** Flush the send queue + */ + void DoWrite(); + + /** Called by the socket engine on a read event + */ + void OnEventHandlerRead() CXX11_OVERRIDE; + + /** Called by the socket engine on a write event + */ + void OnEventHandlerWrite() CXX11_OVERRIDE; + + /** Called by the socket engine on error + * @param errcode Error */ - virtual void HandleEvent(EventType et, int errornum = 0); - /** Dispatched from HandleEvent */ - virtual void DoRead(); - /** Dispatched from HandleEvent */ - virtual void DoWrite(); + void OnEventHandlerError(int errcode) CXX11_OVERRIDE; /** Sets the error message for this socket. Once set, the socket is dead. */ void SetError(const std::string& err) { if (error.empty()) error = err; } @@ -226,7 +245,7 @@ class CoreExport BufferedSocket : public StreamSocket virtual ~BufferedSocket(); protected: - virtual void DoWrite(); + void OnEventHandlerWrite() CXX11_OVERRIDE; BufferedSocketError BeginConnect(const irc::sockets::sockaddrs& dest, const irc::sockets::sockaddrs& bind, unsigned long timeout); BufferedSocketError BeginConnect(const std::string &ipaddr, int aport, unsigned long maxtime, const std::string &connectbindip); }; |