]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Model/src/union.cpp
* Se arregla un bug en el constructor al verificar conexiones
[z.facultad/75.42/plaqui.git] / Model / src / union.cpp
index 26c404a5697db4afb24442262eca5ae289941fbd..58bc8e1a06570df69e2bef416f4b19ef16ca80a8 100644 (file)
@@ -12,6 +12,7 @@ Union::Union(const std::string &_name):Transport(_name)
        in_on_zero = 0;
        in_ready = 0;
        actual_flow = 999999;
        in_on_zero = 0;
        in_ready = 0;
        actual_flow = 999999;
+       updated = false;
 }
 
 Union::~Union()
 }
 
 Union::~Union()
@@ -27,7 +28,6 @@ void Union::recieve_msg(int msg, IConector *who, void *data)
        for(i=in_list.begin(); i!=in_list.end(); i++) {
                if ((*i) == who) pos = IN;
        }
        for(i=in_list.begin(); i!=in_list.end(); i++) {
                if ((*i) == who) pos = IN;
        }
-       
        switch (msg) {
                case MSG_QUERY_MAX_FLOW_OUT: {
                        // Me preguntan por el flujo máximo.
        switch (msg) {
                case MSG_QUERY_MAX_FLOW_OUT: {
                        // Me preguntan por el flujo máximo.
@@ -35,6 +35,11 @@ void Union::recieve_msg(int msg, IConector *who, void *data)
                        float m_data =  *((float *)data)*2;
                        float tmp;
 
                        float m_data =  *((float *)data)*2;
                        float tmp;
 
+                       if (updated) {
+                               who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &actual_flow);
+                               break;
+                       }
+                       updated = true;
                        if (m_data == 0) {
                                in_on_zero++;
                                tmp = 0.0f;
                        if (m_data == 0) {
                                in_on_zero++;
                                tmp = 0.0f;