]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Model/src/union.cpp
definitivamente tengo que aprender a documentar en alguna de esas cosas raras que...
[z.facultad/75.42/plaqui.git] / Model / src / union.cpp
index 3b6a266f28c9b2fdb4efd3cb42a24cd0ebf394f2..36ae347b7e1ad6ad716d46181a8c9cec701e170e 100644 (file)
@@ -8,9 +8,10 @@ Union::Union(const std::string &_name):Transport(_name)
 {
        in_slots = 2;
        out_slots = 1;
 {
        in_slots = 2;
        out_slots = 1;
-       max_flow = actual_flow = 0.0f;
+       max_flow = 0.0f;
        in_on_zero = 0;
        in_ready = 0;
        in_on_zero = 0;
        in_ready = 0;
+       actual_flow = 999999;
 }
 
 Union::~Union()
 }
 
 Union::~Union()
@@ -21,7 +22,7 @@ void Union::recieve_msg(int msg, IConector *who, void *data)
 {
        int pos = OUT;
 
 {
        int pos = OUT;
 
-       // Verifico si esta conectado a mi entrada
+       // Verifico si esta conectado a mi entrada o a mi salida
        std::list<IConector *>::iterator i;
        for(i=in_list.begin(); i!=in_list.end(); i++) {
                if ((*i) == who) pos = IN;
        std::list<IConector *>::iterator i;
        for(i=in_list.begin(); i!=in_list.end(); i++) {
                if ((*i) == who) pos = IN;
@@ -32,38 +33,52 @@ void Union::recieve_msg(int msg, IConector *who, void *data)
                        // Me preguntan por el flujo máximo.
                        // Primero me actualizo, y luego respondo
                        float m_data =  *((float *)data)*2;
                        // Me preguntan por el flujo máximo.
                        // Primero me actualizo, y luego respondo
                        float m_data =  *((float *)data)*2;
+                       float tmp;
 
                        if (m_data == 0) {
                                in_on_zero++;
 
                        if (m_data == 0) {
                                in_on_zero++;
+                               tmp = 0.0f;
+                               who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
+                               if (in_on_zero == 1) {
+                                       if (in_ready == 0)
+                                               tmp = max_flow;
+                                       else
+                                               tmp = actual_flow/2.0f;
+                               }
+                               send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &tmp);
+                       } else {
+                               switch (in_on_zero) {
+                                       case 0:
+                                               actual_flow = (m_data<actual_flow)?m_data:actual_flow;
+                                               actual_flow = (actual_flow<max_flow)?actual_flow:max_flow;
+                                       break;
+                                       case 1:
+                                               if (in_ready == 1)
+                                                       actual_flow = actual_flow/2.0f;
+                                               else
+                                                       actual_flow = max_flow/2.0f;
+                                       break;
+                                       case 2:
+                                               actual_flow = 0;
+                               }
+                               send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
+                               tmp = (in_on_zero==0)?actual_flow/2.0f:actual_flow;
+                               who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
                        }
                        }
-
-                       float tmp;
-                       switch (in_on_zero) {
-                               case 0:
-                                       actual_flow = (m_data<max_flow)?m_data:max_flow;
-                               break;
-                               case 1:
-                                       actual_flow = max_flow/2.0f;
-                               break;
-                               case 2:
-                                       actual_flow = 0;
-                       }
-                       send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
-
-                       // FIXME hay que resolver el problema de avisar a las
-                       // entradas el flujo correcto que deben enviar
-                       tmp = (in_on_zero==0)?actual_flow/2.0f:actual_flow;
-                       who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &tmp);
                        updated = true;
                        updated = true;
+                       if (pos == IN) in_ready++;
                }
                break;
                case MSG_RESPONSE_MAX_FLOW: {
                        float max = *((float *)data);
                        if (pos == OUT) {
                                if (max < actual_flow)  actual_flow = max;
                }
                break;
                case MSG_RESPONSE_MAX_FLOW: {
                        float max = *((float *)data);
                        if (pos == OUT) {
                                if (max < actual_flow)  actual_flow = max;
+                               if (in_on_zero == 2) actual_flow = 0;
                        } else {
                        } else {
-                                       if (((2*max) < actual_flow) && (max != 0))
+                                       if (((2*max) < actual_flow) && (max != 0)) {
                                                actual_flow = 2*max;
                                                actual_flow = 2*max;
+                                               if (in_on_zero == 1) actual_flow /= 2.0;
+                                       }
                        }
                }
                break;
                        }
                }
                break;
@@ -77,7 +92,8 @@ void Union::update(int dir)
        // Si ya me actualice, no lo tengo que hacer de nuevo
        if (updated) return;
        // Seteo mi actualizar en true para evitar entrar de nuevo
        // Si ya me actualice, no lo tengo que hacer de nuevo
        if (updated) return;
        // Seteo mi actualizar en true para evitar entrar de nuevo
-//     actual_flow = 99999;
+       // FIXME : 99999 == INFINITO!!
+       actual_flow = 99999;
        updated = true;
        switch (dir) {
                case IN:
        updated = true;
        switch (dir) {
                case IN:
@@ -90,13 +106,43 @@ void Union::update(int dir)
 
 void Union::simulate()
 {
 
 void Union::simulate()
 {
+       RGB c_in1, c_in2;
+       unsigned r=0,g=0,b=0;
+       float c_f1, c_f2; // para ver los flujos de cada uno
+
        if (!updated) {
                return;
        }
        if (!updated) {
                return;
        }
+       std::list<IConector *>::iterator i = in_list.begin();
+       if (i != in_list.end()) {
+               PlantItem *o = (PlantItem *)(*i);
+               c_in1 = o->get_color();
+               c_f1 = o->get_actual_flow();
+               i++;
+               o = (PlantItem *)(*i);
+               c_in2 = o->get_color();
+               c_f2 = o->get_actual_flow();
+       }
 
 
+       set_color( RGB(r,g,b) );
+       if ((c_f1 != 0) && (c_f2 != 0)) {
+               // Si ambas entradas traen flujo, sumo sus colores
+               r = ((c_in1.r()+c_in2.r())/2)%256;
+               g = ((c_in1.g()+c_in2.g())/2)%256;
+               b = ((c_in1.b()+c_in2.b())/2)%256;
+               set_color(RGB(r,g,b));
+       } else {
+               // Veo que entrada trae color
+               if (c_f1 != 0) {
+                       set_color( c_in1 );
+               }
+               if (c_f2 != 0) {
+                       set_color( c_in2 );
+               }
+       }
+               
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
        updated = false;
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
        updated = false;
-       actual_flow = 99999;
        in_on_zero = 0;
        in_ready = 0;
 }
        in_on_zero = 0;
        in_ready = 0;
 }