+
+#include "splitter.h"
+#include <iostream>
+
+using namespace PlaQui::Model;
+
+Splitter::Splitter(const std::string &_name):Transport(_name)
+{
+ in_slots = 1;
+ out_slots = 2;
+ max_flow = actual_flow = 0.0f;
+}
+
+Splitter::~Splitter()
+{
+}
+
+void Splitter::recieve_msg(int msg, IConector *who, void *data)
+{
+ int pos = OUT;
+
+ // Verifico si esta conectado a mi entrada
+ std::list<IConector *>::iterator i;
+ 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.
+ // Primero me actualizo, y luego respondo
+ actual_flow = *((float *)data);
+
+ if (max_flow < actual_flow) actual_flow = max_flow;
+
+ actual_flow /= 2.0f;
+
+ send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, &actual_flow);
+
+ // Listo, mi flujo ahora es el doble de lo que me pueden
+ // dar las salidas
+ actual_flow *= 2.0f;
+ who->recieve_msg(MSG_RESPONSE_MAX_FLOW, this, &actual_flow);
+ updated = true;
+ }
+ break;
+ case MSG_RESPONSE_MAX_FLOW: {
+ float max = *((float *)data);
+ if (pos == OUT) {
+ if (max < actual_flow) actual_flow = max;
+ if (max_flow < actual_flow) actual_flow = max_flow;
+ } else {
+ if (((2*max) < actual_flow) && (max != 0))
+ actual_flow = 2*max;
+ }
+ }
+ break;
+ default:
+ Transport::recieve_msg(msg, who, data);
+ }
+}
+
+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
+ // actual_flow = 99999;
+ updated = true;
+ switch (dir) {
+ case IN:
+ send_msg(IN, MSG_QUERY_MAX_FLOW_IN, (void *)&max_flow);
+ break;
+ case OUT:
+ send_msg(OUT, MSG_QUERY_MAX_FLOW_OUT, (void *)&max_flow);
+ }
+}
+
+void Splitter::simulate()
+{
+ if (!updated) {
+ return;
+ }
+
+ std::cout << name << "::Flujo actual = " << actual_flow << std::endl;
+ updated = false;
+ actual_flow = 99999;
+}
+