Remove dynamic exceptions
[anna.git] / include / anna / core / mt / Runnable.hpp
1 // ANNA - Anna is Not Nothingness Anymore                                                         //
2 //                                                                                                //
3 // (c) Copyright 2005-2015 Eduardo Ramos Testillano & Francisco Ruiz Rayo                         //
4 //                                                                                                //
5 // See project site at http://redmine.teslayout.com/projects/anna-suite                           //
6 // See accompanying file LICENSE or copy at http://www.teslayout.com/projects/public/anna.LICENSE //
7
8
9 #ifndef anna_core_mt_Runnable_hpp
10 #define anna_core_mt_Runnable_hpp
11
12 #include <string>
13
14 #include <anna/core/functions.hpp>
15
16 #include <anna/core/RuntimeException.hpp>
17 #include <anna/core/mt/Mutex.hpp>
18
19 namespace anna {
20
21 class Thread;
22
23 /**
24    Clase generica para implementar clases que deben realizar una unica accion concreta y que puede ser
25    lanzada desde un Thread.
26 */
27 class Runnable : public Mutex {
28 public:
29   // Accesores
30   /**
31      Devuelve el nombre logico de esta instancia.
32      @return El nombre logico de esta instancia.
33   */
34   const std::string& getId() const { return a_id; }
35
36   /**
37      Devuelve el valor del indicador de parada.
38      \return el valor del indicador de parada.
39      \warning La implementacion particular del metodo run deberia comprobar este valor
40      periodicamente.
41   */
42   bool hasRequestedStop() const { return a_requestedStop == true; }
43
44   /**
45      Devuelve \em true si la instancia esta en ejecucion dentro de su propio thread o \em false en otro caso.
46      \return \em true si la instancia esta en ejecucion dentro de su propio thread o \em false en otro caso.
47   */
48   bool isRunning() const { return a_isRunning; }
49
50   /**
51      Solicita la parada de esta instancia.
52   */
53   void requestStop() noexcept(false);
54
55   /**
56      Devuelve una cadena con la informacion relevante de este objeto.
57      \return Una cadena con la informacion relevante de este objeto.
58   */
59   virtual std::string asString() const
60   {
61     std::string result("anna::Runnable { Id: ");
62     result += a_id;
63     result += functions::asText(" | Running: ", a_isRunning);
64     result += functions::asText(" | RequestedStop: ", a_requestedStop);
65     return result += " }";
66   }
67
68 protected:
69   /**
70      Constructor.
71   */
72   Runnable() : a_id("<none>"), a_requestedStop(false), a_isRunning(false) {;}
73
74   /**
75     Constructor.
76     @param id Nombre logico de esta instancia.
77   */
78   Runnable(const std::string& id) : a_id(id), a_requestedStop(false), a_isRunning(false) {;}
79
80   /**
81     Constructor.
82     @param id Nombre logico de esta clase.
83   */
84   Runnable(const char* id) : a_id(id), a_requestedStop(false), a_isRunning(false) {;}
85
86   /**
87      Establece el nombre logico de esta instancia.
88      \param id Nuevo nombre logico de esta instancia.
89   */
90   void setId(const std::string& id) { a_id = id; }
91
92   /**
93      Establece el indicador que informa sobre si esta instancia esta en ejecucion o no.
94      \param isRunning Indicador que informa sobre si esta instancia esta en ejecucion.
95      \warning Uso interno. Se invoca automaticamente desde Thread.
96   */
97   void setIsRunning(const bool isRunning) {  a_isRunning = isRunning; }
98
99   /**
100      Metodo que se debe reescribir para inicializar el contenido de la clase justo antes de comenzar
101      su ejecucion.
102   */
103   virtual void initialize() noexcept(false) {;}
104
105   /**
106      Metodo que debe reescribir para realizar la accion concreta. Por defecto invocara do_action mientras
107      que no se invoque la metodo requestStop de la instancia.
108   */
109   virtual void run() noexcept(false);
110
111   /**
112      Metodo que se debe reescribir para finalizar la ejecucion de esta instancia.
113      \warning La re-implementacion de este metodo siempre debera invocar a la implementacion
114      original que esta re-escribiiendo.
115   */
116   virtual void terminate() { a_requestedStop = false; }
117
118   /**
119      Metodo indicado por Runnable::run en tanto en cuanto no se invoque a requestStop.
120   */
121   virtual void do_action() noexcept(false) = 0;
122
123 private:
124   std::string a_id;
125   bool a_requestedStop;
126   bool a_isRunning;
127
128   friend class Thread;
129 };
130
131 #define anna_complete_runnable(Class) void do_action () {;}
132
133 } //namespace anna
134
135 #endif
136