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 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;
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;
40 who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
41 if (in_on_zero == 1) {
47 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &tmp);
51 actual_flow = (m_data<actual_flow)?m_data:actual_flow;
52 actual_flow = (actual_flow<max_flow)?actual_flow:max_flow;
56 actual_flow = actual_flow/2.0f;
58 actual_flow = max_flow/2.0f;
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);
69 if (pos == IN) in_ready++;
72 case MSG_RESPONSE_MAX_FLOW: {
73 float max = *((float *)data);
75 if (max < actual_flow) actual_flow = max;
76 if (in_on_zero == 2) actual_flow = 0;
78 if (((2*max) < actual_flow) && (max != 0))
84 Transport::recieve_msg(msg, who, data);
88 void Union::update(int dir)
90 // Si ya me actualice, no lo tengo que hacer de nuevo
92 // Seteo mi actualizar en true para evitar entrar de nuevo
93 // FIXME : 99999 == INFINITO!!
98 send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
101 send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
105 void Union::simulate()
111 std::cout << name << "::Flujo actual = " << actual_flow << std::endl;