]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Model/include/simulador.h
- Se agrega el método HTTPRequest::method_str() para obtener el método como un
[z.facultad/75.42/plaqui.git] / Model / include / simulador.h
1
2
3 #ifndef _SIMULADOR_H_
4 #define _SIMULADOR_H_
5
6 #include <list>
7 #include <string>
8 #include "pump.h"
9 #include "splitter.h"
10 #include "union.h"
11 #include "conduct.h"
12 #include "tank.h"
13 #include "exclusa.h"
14 #include "drainage.h"
15 #include "iconector.h"
16
17 namespace PlaQui {
18 namespace Model {
19
20 class Simulador {
21 public:
22         Simulador();
23         ~Simulador();
24
25         void add_pump(const std::string &name);
26         void add_union(const std::string &name);
27         void add_splitter(const std::string &name);
28         void add_conduct(const std::string &name);
29         void add_exclusa(const std::string &name);
30         void add_tank(const std::string &name);
31         void add_drainage(const std::string &name);
32
33         /** Conecta 2 elementos
34          *
35          *  Esta funcion conecta el elemanto name1 con el elemento name2.
36          *  El parámetro flag define donde se conecta name2 respecto de name1.
37          *  Es decir, si flag = IConector::OUT, name2 se conecta a la salida de
38          *  name1
39          *  \return true si se pudo conectar
40          */
41         bool connect(const std::string &name1, const std::string &name2, int flag);
42
43         void simulate();
44
45         /// Tipos de elementos
46         enum {PUMP, UNION, SPLITTER, CONDUCT, EXCLUSA, TANK, DRAINAGE};
47 protected:
48         // Los mantengo en listas separadas para ahorrar
49         // CPU y no tener que usar dinamic_cast
50         std::list<Pump *> pump_lst;
51         std::list<Union *> union_lst;
52         std::list<Splitter *> split_lst;
53         std::list<Conduct *> conduct_lst;
54         std::list<Tank *> tank_lst;
55         std::list<Drainage *> drainage_lst;
56         std::list<Exclusa *> exclusa_lst;
57
58         // Tambien tengo una lista generica!
59         std::list<PlantItem *> items;
60
61         // Utilidades
62         IConector *find(const std::string &name);
63 };
64
65 }
66 }
67
68 #endif // _SIMULADOR_H_
69