X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/b3b888e4ef034ddc35249ba97ea68ea3fb755ab2..3b0c56cf70eaac383f3cff2b3c76d1ec04595b92:/Model/src/exclusa.cpp diff --git a/Model/src/exclusa.cpp b/Model/src/exclusa.cpp index 74ec906..4253507 100644 --- a/Model/src/exclusa.cpp +++ b/Model/src/exclusa.cpp @@ -12,6 +12,7 @@ Exclusa::Exclusa(const std::string &_name):Control(_name) input = new ByPass(); output = new ByPass(); ((ByPass *)output)->set_control(this); + updated = false; } Exclusa::~Exclusa() @@ -22,6 +23,8 @@ Exclusa::~Exclusa() void Exclusa::update(int dir) { + if (updated) return; + // Primero me fijo si la entrada esta operando, es decir // si hay alguien conectado para automatizar. if (input->is_operational()) { @@ -29,32 +32,35 @@ void Exclusa::update(int dir) // mi estado is_open = input->get_output(); } + actual_flow = temp = INFINITO; } void Exclusa::simulate() { - std::list::iterator i = in_list.begin(); - if (i != in_list.end()) { - PlantItem *o = (PlantItem *)(*i); - set_color( o->get_color() ); - } #ifdef DEBUG std::cout << name << ": " << ((is_open)?"Abierta":"Cerrada") << std::endl; #endif + + updated = false; + color_updated = false; } void Exclusa::recieve_msg(int msg, IConector *who, void *data) { switch (msg) { case MSG_QUERY_MAX_FLOW_OUT: - temp = *((float *)data); - if (!is_open) temp = 0; + if (updated) { + who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &temp); + } + actual_flow = temp = *((float *)data); + if (!is_open) actual_flow = temp = 0; + updated = true; send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &temp); who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &temp); break; case MSG_RESPONSE_MAX_FLOW: if (is_open) - temp = *((float *)data); + actual_flow = temp = *((float *)data); break; default: Control::recieve_msg(msg, who, data); @@ -63,12 +69,10 @@ void Exclusa::recieve_msg(int msg, IConector *who, void *data) void Exclusa::get_state_as_xml(std::stringstream &out) { - // Datos comunes - // hack to avoid output problems :-) - actual_flow = temp; PlantItem::get_state_as_xml(out); out << "\t" << std::endl; out << "\t\t" << ((is_open)?"true":"false") << "" << std::endl; out << "\t" << std::endl; + temp = actual_flow = INFINITO; }