5 using namespace PlaQui::Model;
7 Union::Union(const std::string &_name):Transport(_name)
11 max_flow = actual_flow = 0.0f;
20 void Union::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: {
32 // Me preguntan por el flujo máximo.
33 // Primero me actualizo, y luego respondo
34 float m_data = *((float *)data)*2;
43 actual_flow = (m_data<max_flow)?m_data:max_flow;
46 actual_flow = max_flow/2.0f;
51 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
53 // FIXME hay que resolver el problema de avisar a las
54 // entradas el flujo correcto que deben enviar
55 tmp = (in_on_zero==0)?actual_flow/2.0f:actual_flow;
56 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
60 case MSG_RESPONSE_MAX_FLOW: {
61 float max = *((float *)data);
63 if (max < actual_flow) actual_flow = max;
65 if (((2*max) < actual_flow) && (max != 0))
71 Transport::recieve_msg(msg, who, data);
75 void Union::update(int dir)
77 // Si ya me actualice, no lo tengo que hacer de nuevo
79 // Seteo mi actualizar en true para evitar entrar de nuevo
80 // actual_flow = 99999;
84 send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
87 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
91 void Union::simulate()
97 std::cout << name << "::Flujo actual = " << actual_flow << std::endl;