]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Model/src/union.cpp
Se corrige un bug.
[z.facultad/75.42/plaqui.git] / Model / src / union.cpp
1
2 #include "union.h"
3 #include <iostream>
4
5 using namespace PlaQui::Model;
6
7 Union::Union(const std::string &_name):Transport(_name)
8 {
9         in_slots = 2;
10         out_slots = 1;
11         max_flow = actual_flow = 0.0f;
12         in_on_zero = 0;
13         in_ready = 0;
14 }
15
16 Union::~Union()
17 {
18 }
19
20 void Union::recieve_msg(int msg, IConector *who, void *data)
21 {
22         int pos = OUT;
23
24         // Verifico si esta conectado a mi entrada o a mi salida
25         std::list<IConector *>::iterator i;
26         for(i=in_list.begin(); i!=in_list.end(); i++) {
27                 if ((*i) == who) pos = IN;
28         }
29         
30         switch (msg) {
31                 case MSG_QUERY_MAX_FLOW_OUT: {
32                         // Me preguntan por el flujo máximo.
33                         // Primero me actualizo, y luego respondo
34                         float m_data =  *((float *)data)*2;
35                         float tmp;
36
37                         if (m_data == 0) {
38                                 in_on_zero++;
39                                 tmp = 0.0f;
40                                 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
41                                 if (in_on_zero == 1) {
42                                         if (in_ready == 0)
43                                                 tmp = max_flow;
44                                         else
45                                                 tmp = max_flow/2.0f;
46                                 }
47                                 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &tmp);
48                         } else {
49                                 switch (in_on_zero) {
50                                         case 0:
51                                                 actual_flow = (m_data<actual_flow)?m_data:actual_flow;
52                                                 actual_flow = (actual_flow<max_flow)?actual_flow:max_flow;
53                                         break;
54                                         case 1:
55                                                 if (in_ready == 1)
56                                                         actual_flow = actual_flow/2.0f;
57                                                 else
58                                                         actual_flow = max_flow/2.0f;
59                                         break;
60                                         case 2:
61                                                 actual_flow = 0;
62                                 }
63                                 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
64                                 std::cout << in_on_zero << " " << actual_flow << std::endl;
65                                 tmp = (in_on_zero==0)?actual_flow/2.0f:actual_flow;
66                                 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
67                         }
68                         updated = true;
69                         if (pos == IN) in_ready++;
70                 }
71                 break;
72                 case MSG_RESPONSE_MAX_FLOW: {
73                         float max = *((float *)data);
74                         if (pos == OUT) {
75                                 if (max < actual_flow)  actual_flow = max;
76                                 if (in_on_zero == 2) actual_flow = 0;
77                         } else {
78                                         if (((2*max) < actual_flow) && (max != 0))
79                                                 actual_flow = 2*max;
80                         }
81                 }
82                 break;
83                 default:
84                         Transport::recieve_msg(msg, who, data);
85         }
86 }
87
88 void Union::update(int dir)
89 {
90         // Si ya me actualice, no lo tengo que hacer de nuevo
91         if (updated) return;
92         // Seteo mi actualizar en true para evitar entrar de nuevo
93         // FIXME : 99999 == INFINITO!!
94         actual_flow = 99999;
95         updated = true;
96         switch (dir) {
97                 case IN:
98                         send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
99                 break;
100                 case OUT:
101                         send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
102         }
103 }
104
105 void Union::simulate()
106 {
107         if (!updated) {
108                 return;
109         }
110
111         std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
112         updated = false;
113         actual_flow = 99999;
114         in_on_zero = 0;
115         in_ready = 0;
116 }
117