5 using namespace PlaQui::Model;
7 Splitter::Splitter(const std::string &_name):Transport(_name)
11 max_flow = actual_flow = 0.0f;
13 out_on_zero = out_ready = 0;
20 void Splitter::recieve_msg(int msg, IConector *who, void *data)
24 // Verifico si esta conectado a mi entrada
25 std::list<IConector *>::iterator i;
26 for(i=in_list.begin(); i!=in_list.end(); i++) {
27 if ((*i) == who) pos = IN;
31 case MSG_QUERY_MAX_FLOW_OUT: {
33 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &actual_flow);
35 // Me preguntan por el flujo máximo.
36 // Primero me actualizo, y luego respondo
37 float tmp = *((float *)data);
39 if (tmp < actual_flow) actual_flow = tmp;
41 if (max_flow < actual_flow) actual_flow = max_flow;
46 if (actual_flow == 0) {
49 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
51 // Listo, mi flujo ahora es el doble de lo que me pueden
54 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &actual_flow);
58 case MSG_RESPONSE_MAX_FLOW: {
59 float max = *((float *)data);
60 if (out_ready == 2) break;
62 std::cout << name << ":Split " << max << std::endl;
67 switch (out_on_zero) {
70 actual_flow = max_flow;
77 if (max < actual_flow) actual_flow = max;
78 if (max_flow < actual_flow) actual_flow = max_flow;
82 if (((2*max) < actual_flow) && (max != 0))
88 Transport::recieve_msg(msg, who, data);
92 void Splitter::update(int dir)
94 // Si ya me actualice, no lo tengo que hacer de nuevo
96 // Seteo mi actualizar en true para evitar entrar de nuevo
97 actual_flow = INFINITO;
101 send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
104 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
108 void Splitter::simulate()
115 std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
118 color_updated = false;
119 out_on_zero = out_ready = 0;