From: Ricardo Markiewicz Date: Mon, 20 Oct 2003 22:33:06 +0000 (+0000) Subject: - Se agrega codigo para desconectar un objeto X-Git-Tag: svn_import~394 X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/commitdiff_plain/48227aedaabfe971362c80f5f9eb4be29e2a64ed?ds=inline - Se agrega codigo para desconectar un objeto - Se arregla un bug que hacia que cuando un objeto se conectaba se incrementaban las cantidades de entradas o salidas. --- diff --git a/Model/src/iconector.cpp b/Model/src/iconector.cpp index 778da63..c1beafa 100644 --- a/Model/src/iconector.cpp +++ b/Model/src/iconector.cpp @@ -19,7 +19,7 @@ IConector::~IConector() int IConector::send_msg(int where, int msg) { // Recorro toda la lista y envĂ­o el mensage a cada - // elemento conectado + // elemento conectado en "where" std::list::iterator it; switch (where) { case IN: @@ -40,8 +40,10 @@ void IConector::recieve_msg(int msg, IConector *who) // Manejo los mensages que yo conozco switch (msg) { case MSG_DISCONECT: - // FIXME: sacar el elemento who de la lista! - return; + // Elimino el objeto de las listas, si es que + // existe en alguna de las dos. + entradas.remove(who); + salidas.remove(who); } } @@ -51,18 +53,16 @@ bool IConector::connect(IConector *obj, int place) case IN: if (entradas.size() <= cant_entradas) { entradas.push_back(obj); - cant_entradas++; } else { return false; // no se pudo conectar! } case OUT: if (salidas.size() <= cant_salidas) { salidas.push_back(obj); - cant_salidas++; } else { return false; // no se pudo conectar! } -} + } // se pudo conectar sin problemas return true;