X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/658a6629fd4958dad9add9d2a1e06de6003fa5aa..1855f998e5c0e51e2c1958724ac84cc13a87d84c:/Server/src/tcpserver.cpp diff --git a/Server/src/tcpserver.cpp b/Server/src/tcpserver.cpp index 8b1c3bb..61d3e11 100644 --- a/Server/src/tcpserver.cpp +++ b/Server/src/tcpserver.cpp @@ -86,17 +86,24 @@ TCPServer::TCPServer(const Connection::Port& port) throw(sockerr): #endif // DEBUG } -/*void TCPServer::finish(bool attach) { +void TCPServer::finish(void) { #ifdef DEBUG cerr << __FILE__ << "(" << __LINE__ << ")" - << ": finish(attach = " << attach << ");" << endl; + << ": finish(void);" << endl; #endif // DEBUG - //socket_mutex.lock(); - close(socket.sd()); - //socket.shutdown(sockbuf::shut_readwrite); - //socket_mutex.unlock(); - Runnable::finish(attach); -}*/ + Runnable::finish(); + // Creo una conexión suicida para que el accept() del server retorne + // el control y el server pueda terminar realmente. + try { + sockinetbuf suicida(sockbuf::sock_stream); + suicida.connect(socket.localhost(), socket.localport()); + } catch (const sockerr& e) { + // FIXME + signal_error().emit(100000 + e.serrno(), string("No se pudo crear " + "conexión 'suicida' para terminar el servidor: ") + + e.errstr()); + } +} void TCPServer::on_connection_finished(Connection* connection) { #ifdef DEBUG @@ -149,11 +156,9 @@ void TCPServer::real_run(void) throw() { // XXX connections_mutex.unlock(); // Si pongo el mutex antes del run(), // muere. // Conecto la señal para cuando termina una conexión, borrarla. - connection->signal_finished().connect( - SigC::bind( - SigC::slot_class(*this, - &TCPServer::on_connection_finished), - connection)); + connection->signal_finished().connect(SigC::bind( + SigC::slot_class(*this, &TCPServer::on_connection_finished), + connection)); connection->run(); } }