From da468f24388d7f0f574c6e4dd4022e05d47a9db2 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Thu, 10 May 2012 03:23:11 +0000 Subject: Use SharedPtr references to Interfaces to keep things sane. Fix double register when using GUI with a remote engine. Avoid signal when writing to dead socket by using send with MSG_NOSIGNAL. git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@4336 a436a847-0d15-0410-975c-d299462d15a1 --- src/socket/SocketClient.hpp | 8 ++++++++ src/socket/SocketServer.hpp | 20 +++++++++++++------- src/socket/SocketWriter.cpp | 10 +++++++++- 3 files changed, 30 insertions(+), 8 deletions(-) (limited to 'src/socket') diff --git a/src/socket/SocketClient.hpp b/src/socket/SocketClient.hpp index 22e6eeb4..d75288e0 100644 --- a/src/socket/SocketClient.hpp +++ b/src/socket/SocketClient.hpp @@ -41,6 +41,14 @@ public: _reader.start(); } + virtual SharedPtr respondee() const { + return _respondee; + } + + virtual void set_respondee(SharedPtr respondee) { + _respondee = respondee; + } + private: SharedPtr _respondee; SocketReader _reader; diff --git a/src/socket/SocketServer.hpp b/src/socket/SocketServer.hpp index 8ea0f445..55434030 100644 --- a/src/socket/SocketServer.hpp +++ b/src/socket/SocketServer.hpp @@ -34,17 +34,23 @@ public: SharedPtr sock) : Server::EventWriter(engine) , SocketReader(world, *this, sock) - , _writer(*world.lv2_uri_map().get(), - *world.uris().get(), - sock->uri(), - sock) + , _engine(engine) + , _writer(new SocketWriter(*world.lv2_uri_map().get(), + *world.uris().get(), + sock->uri(), + sock)) { - set_respondee(&_writer); - engine.register_client(sock->uri(), &_writer); + set_respondee(_writer); + engine.register_client(_writer->uri(), _writer); + } + + ~SocketServer() { + _engine.unregister_client(_writer->uri()); } private: - SocketWriter _writer; + Server::Engine& _engine; + SharedPtr _writer; }; } // namespace Ingen diff --git a/src/socket/SocketWriter.cpp b/src/socket/SocketWriter.cpp index 29bc018b..808d62cf 100644 --- a/src/socket/SocketWriter.cpp +++ b/src/socket/SocketWriter.cpp @@ -14,6 +14,10 @@ along with Ingen. If not, see . */ +#include +#include +#include + #include "SocketWriter.hpp" namespace Ingen { @@ -23,7 +27,11 @@ static size_t socket_sink(const void* buf, size_t len, void* stream) { SocketWriter* writer = (SocketWriter*)stream; - return write(writer->fd(), buf, len); + ssize_t ret = send(writer->fd(), buf, len, MSG_NOSIGNAL); + if (ret < 0) { + return 0; + } + return ret; } SocketWriter::SocketWriter(Shared::LV2URIMap& map, -- cgit v1.2.1