1 // vim: set noexpandtab tabstop=4 shiftwidth=4:
2 //----------------------------------------------------------------------------
4 //----------------------------------------------------------------------------
5 // This file is part of PlaQui.
7 // PlaQui is free software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the Free Software
9 // Foundation; either version 2 of the License, or (at your option) any later
12 // PlaQui is distributed in the hope that it will be useful, but WITHOUT ANY
13 // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 // FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 // You should have received a copy of the GNU General Public License along
18 // with PlaQui; if not, write to the Free Software Foundation, Inc., 59 Temple
19 // Place, Suite 330, Boston, MA 02111-1307 USA
20 //----------------------------------------------------------------------------
21 // Creado: sáb nov 15 17:29:44 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
28 #ifndef PLAQUI_PLANT_H
29 #define PLAQUI_PLANT_H
31 #include "plaqui/server/runnable.h"
32 #include "plaqui/server/transmitter.h"
33 #include "simulator.h"
34 #include <sigc++/signal.h>
41 class Plant: public Runnable {
43 /////////////////////////////////////////////////////////////////////
48 /// Tiempo por defecto a esperar entre iteraciones de la simulación.
49 static const unsigned DEFAULT_WAIT_TIME = 100000u;
51 /////////////////////////////////////////////////////////////////////
56 /// Lista de conexiones de control.
57 typedef std::list<Transmitter*> TransmitterList;
59 /////////////////////////////////////////////////////////////////////
64 /// Transmisiones del estado de las plantas.
65 TransmitterList transmissions;
67 /// Mutex para las transmisiones.
68 Glib::Mutex transmissions_mutex;
70 /// Simulador usado para calcular el estado de la planta.
71 Model::Simulator simulator;
73 /// Mutex para el simulador.
74 Glib::Mutex simulator_mutex;
76 /// Nombre del archivo donde esta el XML de la planta.
79 /// Tiempo que espera entre cada iteración de la simulación.
82 /// Mutex para el tiempo de espera.
83 Glib::Mutex wait_time_mutex;
85 /// Indica si la planta está pausada o simulando.
88 /// Mutex para el indicador de pausa.
89 Glib::Mutex paused_mutex;
91 /////////////////////////////////////////////////////////////////////
97 * Corre la planta (la monitorea o la simula).
99 virtual void real_run(void) throw();
106 virtual ~Plant(void);
109 * Constructor desde un archivo.
111 * \param filename Nombre del archivo de donde obtener la planta.
113 Plant(const std::string& filename);
116 * Comienza una transmisión del estado de la planta.
118 * \return true si comenzó la transmisión, false si hubo problemas.
120 bool transmission_start(string& host, Connection::Port& port);
123 * Comienza una transmisión del estado de la planta.
125 * \return true si detuvo la transmisión, false si no existía.
127 bool transmission_stop(const string& host,
128 const Connection::Port& port);
131 * Borra una transmisión de la lista de transmisiones al finalizar.
133 * \param transmission Transmisión a eliminar.
135 void on_transmission_finished(Transmitter* transmission);
138 * Abre (o cierra) un elemento de la planta.
140 * Sólo la bomba y la exclusa pueden ser abiertos y cerrados.
142 * \param element Nombre del elemento a abrir o cerrar.
143 * \param open true si se quiere abrir el elemento, false si se
146 * \return true si se abrió o cerró el elemento, false si no existía
147 * o si no era una bomba o exclusa.
149 bool set_open(const std::string& element, bool open = true);
152 * Setea la frecuencia de refresco de la simulación.
153 * Si se setea a cero, se usa el tiempo por omisión.
155 * \param hz Cantidad de veces por segundo que debe refrescarse la
158 void set_frequency(unsigned hz = 0u);
161 * Pausa (o reanuda) la simulación.
163 * \param paused true si se la quiere pausar, false para reanudar.
165 void set_paused(bool paused = true);
168 * Obtiene el XML de la planta.
170 const std::string get_xml(void) const;
178 #endif // PLAQUI_PLANT_H