X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/6e0194f46ac77c18bfeabf84ef94a32f23e41073..e6d0648eb6af32d0e8db4876430f20dcc7d8d920:/Server/include/plaqui/server/runnable.h diff --git a/Server/include/plaqui/server/runnable.h b/Server/include/plaqui/server/runnable.h index 39a221f..2d34e6c 100644 --- a/Server/include/plaqui/server/runnable.h +++ b/Server/include/plaqui/server/runnable.h @@ -29,16 +29,46 @@ #define PLAQUI_RUNNABLE_H #include +#include -namespace Plaqui { +namespace PlaQui { + +namespace Server { /// ealizauna tarea (generalmente en un thread). class Runnable { + // Tipos. + + public: + + /// Tipo de señal para indicar que se finalizó la tarea. + typedef SigC::Signal0 SignalFinished; + + // Atributos. + private: - // Thread en el cual correr la tarea. + + /// Thread en el cual correr la tarea. Glib::Thread* thread; + /// Indica si se debe frinalizar la tarea. + bool stop; + + /// Señal que indica que se finalizó la tarea. + SignalFinished finished; + + // Métodos. + + private: + + /** + * Corre la tarea controlando cuando termina. + * + * \param runner Objeto con la tarea a realizar. + */ + static void static_run(Runnable* runner); + protected: /// Realiza la terea. @@ -57,15 +87,35 @@ namespace Plaqui { Runnable(void); /** - * Comienza la tares. + * Comienza la tarea. * * \param detach Si es true se corre en un thread propio. Si no no * retorna hasta que finaliza. */ virtual void run(bool detach = true); + /** + * 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); + + /** + * Obtiene la señal que avisa cuando la tarea es finalizada. + * + * \see finish(). + */ + SignalFinished& signal_finished(void); + }; } +} + #endif // PLAQUI_RUNNABLE_H