]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/tcpserver.h
Se implementa una señal entre Thread con Glib::Dispatch .. no se si soluciona el...
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / tcpserver.h
index 1cd344f4da3599eea86ddade2da09cfc7df9783c..17ce3b12ca79c71d9dc95578e2c4c905e3b13cab 100644 (file)
@@ -65,7 +65,7 @@ namespace Server {
                                /// Host.
                                std::string host;
                                /// Port.
-                               unsigned port;
+                               Connection::Port port;
                        };
 
                        /// Lista de información de conexiones de control.
@@ -78,12 +78,12 @@ namespace Server {
                        /// Socket para escuchar conexiones.
                        sockinetbuf socket;
 
-                       /// Mutex para las conexiones.
-                       Glib::Mutex connections_mutex;
-
                        /// Conexiones de control.
                        ConnectionList connections;
 
+                       /// Mutex para las conexiones.
+                       Glib::Mutex connections_mutex;
+
                // Métodos.
 
                private:
@@ -116,7 +116,18 @@ namespace Server {
                         *
                         * \param port Puerto en el cual escuchar.
                         */
-                       TCPServer(int port);
+                       TCPServer(const Connection::Port& port);
+
+                       /**
+                        * Finaliza la tarea.
+                        *
+                        * \param attach Si es true, la función no retorna hasta que no
+                        *               finalice la tearea (no recomendable).
+                        *
+                        * \note Para saber cuando la tarea fue finalizada puede utilizar
+                        *       la señal signal_finished().
+                        */
+                       virtual void finish(bool attach = false);
 
                        /**
                         * Se encarga de borrar una conexión de la lista cuando finaliza.
@@ -125,6 +136,12 @@ namespace Server {
                         */
                        void on_connection_finished(Connection* connection);
 
+                       /**
+                        * Detiene una conexión.
+                        */
+                       bool disconnect(const std::string& host,
+                                       const Connection::Port& port);
+
                        /**
                         * Obtiene una lista conexiones de control abiertas.
                         */