]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/src/transmitter.cpp
Se puede conectar de una manera bizarra una OR con un TANQUE
[z.facultad/75.42/plaqui.git] / Server / src / transmitter.cpp
index b8635fa6c7f5fbed0c53c441f72deb5886136642..a1ac7b0deb24df8c0839209b83a89cfa628cd203 100644 (file)
 // $Id$
 //
 
-#include "transmitter.h"
+#include "plaqui/server/transmitter.h"
+#include <glibmm/timer.h>
 #include <socket++/sockinet.h>
 #include <string>
+#ifdef DEBUG
+#      include <iostream>
+#endif // DEBUG
 
-using namespace Plaqui;
+using namespace std;
 
-Transmitter::Transmitter(std::string host, int port):
-               Connection(sockbuf::sock_dgram) {
-#warning Not implemented!
+namespace PlaQui {
+
+namespace Server {
+
+Transmitter::~Transmitter(void) {
+#ifdef DEBUG
+       cerr << __FILE__ << ": destructor." << endl;
+#endif // DEBUG
+}
+
+Transmitter::Transmitter(const string& _host, const Connection::Port& _port):
+               Connection(sockbuf::sock_dgram, _host, _port) {
+#ifdef DEBUG
+       cerr << __FILE__ << ": _host = " << _host
+               << " | _port = " << _port << endl;
+#endif // DEBUG
        socket->connect(host.c_str(), port);
+       host = socket->peerhost();
+       port = socket->peerport();
+}
+
+/// \todo debría dar una excepción (?)
+void Transmitter::real_run(void) {
+#ifdef DEBUG
+       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
+       socket << data << flush;
 }
 
+} // namespace Server
+
+} // namespace PlaQui
+