16 #include "iconector.h"
17 #include "libxml/parser.h"
24 Simulator(const std::string &filename);
27 void add_pump(const std::string &name, float max_flow, RGB color);
28 void add_union(const std::string &name, float max_flow);
29 void add_splitter(const std::string &name, float max_flow);
30 void add_conduct(const std::string &name, float max_flow);
31 void add_exclusa(const std::string &name, bool open);
32 void add_tank(const std::string &name, float capacity, float initial, RGB color);
33 void add_drainage(const std::string &name);
35 /** Retorna el estado de todos los items como un XML */
36 std::string get_state_as_xml();
38 /** Conecta 2 elementos
40 * Esta funcion conecta el elemanto name1 con el elemento name2.
41 * El parámetro flag define donde se conecta name2 respecto de name1.
42 * Es decir, si flag = IConector::OUT, name2 se conecta a la salida de
44 * \return true si se pudo conectar
46 bool connect(const std::string &name1, const std::string &name2, int flag);
50 /// Tipos de elementos
51 enum {PUMP, UNION, SPLITTER, CONDUCT, EXCLUSA, TANK, DRAINAGE};
53 bool pump_deactivate(const std::string &name);
55 // Los mantengo en listas separadas para ahorrar
56 // CPU y no tener que usar dinamic_cast
57 std::list<Pump *> pump_lst;
58 std::list<Union *> union_lst;
59 std::list<Splitter *> split_lst;
60 std::list<Conduct *> conduct_lst;
61 std::list<Tank *> tank_lst;
62 std::list<Drainage *> drainage_lst;
63 std::list<Exclusa *> exclusa_lst;
65 // Tambien tengo una lista generica!
66 std::list<PlantItem *> items;
69 IConector *find(const std::string &name);
71 // Conecta todos los items desde el XML
72 void do_connections(xmlNodePtr nodo);
75 void loadBomba(xmlNodePtr nodo);
76 void loadConduct(xmlNodePtr nodo);
77 void loadExclusa(xmlNodePtr nodo);
78 void loadTank(xmlNodePtr nodo);
79 void loadUnion(xmlNodePtr nodo);
80 void loadDrain(xmlNodePtr nodo);
82 // Frame. Define el orden para los cuadros del XML
83 unsigned long int frame;
89 #endif // _SIMULADOR_H_