]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/controlclient.h
Se corrige un bug en la carga del XML. Me habia olvidado que hay elementos con 3...
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / controlclient.h
index 8341a5f4549698b4bfb86a0ed8ee5f5bdda33446..f2252401890ae6183915053bde6af11d2f0e4628 100644 (file)
@@ -28,7 +28,9 @@
 #ifndef PLAQUI_CONTROLCLIENT_H
 #define PLAQUI_CONTROLCLIENT_H
 
 #ifndef PLAQUI_CONTROLCLIENT_H
 #define PLAQUI_CONTROLCLIENT_H
 
+#include "plaqui/server/command.h"
 #include "plaqui/server/connection.h"
 #include "plaqui/server/connection.h"
+#include "plaqui/server/receiver.h" // TODO TEMPRORAL
 #include <string>
 
 namespace PlaQui {
 #include <string>
 
 namespace PlaQui {
@@ -38,10 +40,41 @@ namespace Server {
        /// Conexión para enviar comandos de control a una planta.
        class ControlClient: public Connection {
 
        /// Conexión para enviar comandos de control a una planta.
        class ControlClient: public Connection {
 
+               // Tipos.
+
+               public:
+
+                       /// Tipo de señal para indicar que se conectó.
+                       typedef SigC::Signal0<void> SignalConnected;
+
+                       /// Tipo de señal para indicar que se recibió una respuesta OK.
+                       typedef SigC::Signal1<void, const std::string&> SignalOKReceived;
+
+                       /// Tipo de señal para indicar que se recibió un error.
+                       typedef SigC::Signal1<void, unsigned> SignalErrorReceived;
+
+               // Atributos.
+
+               protected:
+
+                       /// Señal para indicar que se conectó.
+                       SignalConnected connected;
+
+                       /// Señal para indicar que se recibió una respuesta OK.
+                       SignalOKReceived ok_received;
+
+                       /// Señal para indicar que se recibió un error.
+                       SignalErrorReceived error_received;
+
+                       /// Receptor del estado de la planta TODO Temporal.
+                       Receiver receiver;
+
+               // Métodos.
+
                private:
 
                        /**
                private:
 
                        /**
-                        * Atiende la conexión.
+                        * Realiza la conexión al servidor.
                         */
                        virtual void real_run(void);
 
                         */
                        virtual void real_run(void);
 
@@ -50,7 +83,7 @@ namespace Server {
                        /**
                         * Destructor.
                         */
                        /**
                         * Destructor.
                         */
-                       virtual ~ControlClient(void) {}
+                       virtual ~ControlClient(void);
 
                        /**
                         * Constructor.
 
                        /**
                         * Constructor.
@@ -59,7 +92,35 @@ namespace Server {
                         *                         control.
                         * \param port Puerto al cual conectarse.
                         */
                         *                         control.
                         * \param port Puerto al cual conectarse.
                         */
-                       ControlClient(std::string host = "localhost", int port = 7522);
+                       ControlClient(const std::string& host = "localhost",
+                                       const Connection::Port& port = 7522);
+
+                       /**
+                        * Envía un comando al servidor.
+                        *
+                        * \param command Comando a enviar.
+                        */
+                       void send(const Command& command);
+
+                       /**
+                        * Obtiene la señal para indicar que se conectó.
+                        */
+                       SignalConnected& signal_connected(void);
+
+                       /**
+                        * Obtiene la señal para indicar que se recibió una respuesta OK.
+                        */
+                       SignalOKReceived& signal_ok_received(void);
+
+                       /**
+                        * Obtiene la señal para indicar que se recibió un error.
+                        */
+                       SignalErrorReceived& signal_error_received(void);
+
+                       /**
+                        * Obtiene la señal que avisa cuando se recibió un cuadro.
+                        */
+                       Receiver::SignalFrameReceived& signal_frame_received(void);
 
        };
 
 
        };