X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/00cffd5f7c35a915c09d55e6292775e9e01bdeec..c5c8d16a2d8c4a0ec1a8d3e83104f73512c91001:/Server/src/transmitter.cpp?ds=sidebyside diff --git a/Server/src/transmitter.cpp b/Server/src/transmitter.cpp index 268f216..9d0e24d 100644 --- a/Server/src/transmitter.cpp +++ b/Server/src/transmitter.cpp @@ -26,40 +26,73 @@ // #include "plaqui/server/transmitter.h" +#include #include #include #ifdef DEBUG # include #endif // DEBUG -PlaQui::Server::Transmitter::~Transmitter(void) { +using namespace std; + +namespace PlaQui { + +namespace Server { + +Transmitter::~Transmitter(void) { #ifdef DEBUG - std::cerr << __FILE__ << ": destructor." << std::endl; + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": destructor." << endl; #endif // DEBUG } -/// \todo debría conectarse en real_run() (?) -PlaQui::Server::Transmitter::Transmitter(std::string host, int port): - PlaQui::Server::Connection(sockbuf::sock_dgram) { +Transmitter::Transmitter(const string& _host, const Connection::Port& _port) + throw(sockerr): Connection(sockbuf::sock_dgram, _host, _port) { #ifdef DEBUG - std::cerr << __FILE__ << ": host = " << host - << " | port = " << port << std::endl; + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": _host = " << _host + << " | _port = " << _port << endl; #endif // DEBUG - // FIXME - deberia ir en run(). socket->connect(host.c_str(), port); + // Reasigno el host y puerto bien. + host = socket->peerhost(); + port = socket->peerport(); +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": (real) host = " << _host + << " | port = " << _port << endl; +#endif // DEBUG } -/// \todo debría dar una excepción (?) -void PlaQui::Server::Transmitter::real_run(void) { +void Transmitter::real_run(void) throw() { #ifdef DEBUG - // FIXME - debería tirar una excepción? - if (!socket->is_open()) { - std::cerr << "No se pudo conectar a " << socket->peerhost() << - ":" << socket->peerport() << "." << std::endl; - } else { - std::cerr << "Conectado a " << socket->peerhost() << - ":" << socket->peerport() << "." << std::endl; + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": real_run()." << endl; +#endif // DEBUG + // No hace nada, porque solo actua cuando se manda algo con send(). + while (!stop()) { + Glib::usleep(500000); // 1/2 segundo } +} + +void Transmitter::send(const string& data) { +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": send()." << endl; +// << ": send(data = " << data << ")." << endl; #endif // DEBUG + if (stop()) { + return; + } + try { + socket << data << flush; + } catch (const sockerr& e) { + signal_error().emit(e.serrno(), e.errstr()); + stop(true); + } } +} // namespace Server + +} // namespace PlaQui +