X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/0aacdcf95cf6d4f33a2201160d472ab84148d52b..49850f467dae860e12c7851a2f8a79132f87721e:/Model/src/exclusa.cpp?ds=sidebyside diff --git a/Model/src/exclusa.cpp b/Model/src/exclusa.cpp index 34b2fab..89554f8 100644 --- a/Model/src/exclusa.cpp +++ b/Model/src/exclusa.cpp @@ -31,6 +31,11 @@ void Exclusa::update(int dir) void Exclusa::simulate() { + std::list::iterator i = in_list.begin(); + if (i != in_list.end()) { + PlantItem *o = (PlantItem *)(*i); + set_color( o->get_color() ); + } std::cout << name << ": " << ((is_open)?"Abierta":"Cerrada") << std::endl; } @@ -39,14 +44,27 @@ 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; send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &temp); who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &temp); break; case MSG_RESPONSE_MAX_FLOW: - temp = *((float *)data); + if (is_open) + temp = *((float *)data); break; default: Control::recieve_msg(msg, who, 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; +} +