]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Model/src/splitter.cpp
El diagrama de clases del modelo esta listo para salir del horno
[z.facultad/75.42/plaqui.git] / Model / src / splitter.cpp
index d9733794166ad84b1a88bcd369cb6c295bbb7d68..cd3ccad169eb7d057e291ae15c9c763bf7b71df1 100644 (file)
@@ -9,6 +9,7 @@ Splitter::Splitter(const std::string &_name):Transport(_name)
        in_slots = 1;
        out_slots = 2;
        max_flow = actual_flow = 0.0f;
        in_slots = 1;
        out_slots = 2;
        max_flow = actual_flow = 0.0f;
+       updated = true;
 }
 
 Splitter::~Splitter()
 }
 
 Splitter::~Splitter()
@@ -27,6 +28,9 @@ void Splitter::recieve_msg(int msg, IConector *who, void *data)
        
        switch (msg) {
                case MSG_QUERY_MAX_FLOW_OUT: {
        
        switch (msg) {
                case MSG_QUERY_MAX_FLOW_OUT: {
+                       if (updated) {
+                               who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &actual_flow);
+                       }
                        // Me preguntan por el flujo máximo.
                        // Primero me actualizo, y luego respondo
                        actual_flow =  *((float *)data);
                        // Me preguntan por el flujo máximo.
                        // Primero me actualizo, y luego respondo
                        actual_flow =  *((float *)data);
@@ -68,7 +72,7 @@ void Splitter::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;
+       actual_flow = INFINITO;
        updated = true;
        switch (dir) {
                case IN:
        updated = true;
        switch (dir) {
                case IN:
@@ -85,14 +89,10 @@ void Splitter::simulate()
                return;
        }
 
                return;
        }
 
-       std::list<IConector *>::iterator i = in_list.begin();
-       if (i != in_list.end()) {
-               PlantItem *o = (PlantItem *)(*i);
-               set_color( o->get_color() );
-       }
 #ifdef DEBUG
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
 #endif
        updated = false;
 #ifdef DEBUG
        std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
 #endif
        updated = false;
+       color_updated = false;
 }
 
 }