X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/802f79cdb0d688127b8a639cd3173d801a1466cd..e860608dbbbbaa43d0f241ab7a43da7c4608e192:/Server/include/plaqui/server/controlclient.h diff --git a/Server/include/plaqui/server/controlclient.h b/Server/include/plaqui/server/controlclient.h index 8341a5f..54b10be 100644 --- a/Server/include/plaqui/server/controlclient.h +++ b/Server/include/plaqui/server/controlclient.h @@ -28,7 +28,9 @@ #ifndef PLAQUI_CONTROLCLIENT_H #define PLAQUI_CONTROLCLIENT_H +#include "plaqui/server/command.h" #include "plaqui/server/connection.h" +#include "plaqui/server/receiver.h" // TODO TEMPRORAL #include namespace PlaQui { @@ -38,28 +40,90 @@ namespace Server { /// 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 SignalConnected; + + /// Tipo de señal para indicar que se recibió una respuesta OK. + typedef SigC::Signal1 SignalOKReceived; + + /// Tipo de señal para indicar que se recibió un error. + typedef SigC::Signal1 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: /** - * Atiende la conexión. + * Realiza la conexión al servidor. */ - virtual void real_run(void); + virtual void real_run(void) throw(); public: /** * Destructor. */ - virtual ~ControlClient(void) {} + virtual ~ControlClient(void); /** * Constructor. * - * \param host Host al cual conectarse para enviar comandos de + * \param _host Host al cual conectarse para enviar comandos de * control. - * \param port Puerto al cual conectarse. + * \param _port Puerto al cual conectarse. + */ + ControlClient(const std::string& _host = "localhost", + const Connection::Port& _port = 7522) throw(sockerr); + + /** + * 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. */ - ControlClient(std::string host = "localhost", int port = 7522); + Receiver::SignalFrameReceived& signal_frame_received(void); };