]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/src/transmitter.cpp
- Se limpian un poco las respuestas, ahora lo que van a ser respuestas reales,
[z.facultad/75.42/plaqui.git] / Server / src / transmitter.cpp
index 4211e51a0cc866828efaf6bdba632af6de24259a..de940f98c187097db7a050c543e96876781c0b8c 100644 (file)
@@ -26,6 +26,7 @@
 //
 
 #include "plaqui/server/transmitter.h"
 //
 
 #include "plaqui/server/transmitter.h"
+#include <glibmm/timer.h>
 #include <socket++/sockinet.h>
 #include <string>
 #ifdef DEBUG
 #include <socket++/sockinet.h>
 #include <string>
 #ifdef DEBUG
@@ -44,29 +45,37 @@ Transmitter::~Transmitter(void) {
 #endif // DEBUG
 }
 
 #endif // DEBUG
 }
 
-/// \todo debría conectarse en real_run() (?)
-Transmitter::Transmitter(string host, int port):
-               Connection(sockbuf::sock_dgram) {
+Transmitter::Transmitter(string& _host, Connection::Port& _port):
+               Connection(sockbuf::sock_dgram, _host, _port) {
 #ifdef DEBUG
 #ifdef DEBUG
-       cerr << __FILE__ << ": host = " << host
-               << " | port = " << port << endl;
+       cerr << __FILE__ << ": _host = " << _host
+               << " | _port = " << _port << endl;
 #endif // DEBUG
 #endif // DEBUG
-       // FIXME - deberia ir en run().
        socket->connect(host.c_str(), port);
        socket->connect(host.c_str(), port);
+       // Reasigno el host y puerto bien, tanto de este objeto como los que se
+       // environ para indicar su valor correcto.
+       host  = socket->peerhost();
+       port  = socket->peerport();
+       _host = socket->peerhost();
+       _port = socket->peerport();
 }
 
 /// \todo debría dar una excepción (?)
 void Transmitter::real_run(void) {
 #ifdef DEBUG
 }
 
 /// \todo debría dar una excepción (?)
 void Transmitter::real_run(void) {
 #ifdef DEBUG
-       // FIXME - debería tirar una excepción?
-       if (!socket->is_open()) {
-               cerr << "No se pudo conectar a " << socket->peerhost() <<
-                       ":" << socket->peerport() << "." << endl;
-       } else {
-               cerr << "Conectado a " << socket->peerhost() <<
-                       ":" << socket->peerport() << "." << endl;
+       cerr << __FILE__ << ": real_run()." << endl;
+#endif // DEBUG
+       // No hace nada, porque solo actua cuando se manda algo con send().
+       while (!stop) {
+               Glib::usleep(1000);
        }
        }
+}
+
+void Transmitter::send(const string& data) {
+#ifdef DEBUG
+       cerr << __FILE__ << ": send(data = " << data << ")." << endl;
 #endif // DEBUG
 #endif // DEBUG
+       socket << data << flush;
 }
 
 } // namespace Server
 }
 
 } // namespace Server