Remove old edges from unreachable nodes to us. This prevents the hosts/NAME-up
script from being called twice in some situations.
This commit is contained in:
parent
ffb55e6904
commit
762cc2d279
2 changed files with 23 additions and 2 deletions
13
src/net.c
13
src/net.c
|
@ -17,7 +17,7 @@
|
||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
|
||||||
$Id: net.c,v 1.35.4.198 2003/08/22 15:04:26 guus Exp $
|
$Id: net.c,v 1.35.4.199 2003/08/28 15:27:11 guus Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "system.h"
|
#include "system.h"
|
||||||
|
@ -186,6 +186,17 @@ void terminate_connection(connection_t *c, bool report)
|
||||||
/* Run MST and SSSP algorithms */
|
/* Run MST and SSSP algorithms */
|
||||||
|
|
||||||
graph();
|
graph();
|
||||||
|
|
||||||
|
/* If the node is not reachable anymore but we remember it had an edge to us, clean it up */
|
||||||
|
|
||||||
|
if(report && !c->node->status.reachable) {
|
||||||
|
edge_t *e;
|
||||||
|
e = lookup_edge(c->node, myself);
|
||||||
|
if(e) {
|
||||||
|
send_del_edge(broadcast, e);
|
||||||
|
edge_del(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if this was our outgoing connection */
|
/* Check if this was our outgoing connection */
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
|
||||||
$Id: protocol_edge.c,v 1.1.4.20 2003/07/24 12:08:16 guus Exp $
|
$Id: protocol_edge.c,v 1.1.4.21 2003/08/28 15:27:12 guus Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "system.h"
|
#include "system.h"
|
||||||
|
@ -250,5 +250,15 @@ bool del_edge_h(connection_t *c)
|
||||||
|
|
||||||
graph();
|
graph();
|
||||||
|
|
||||||
|
/* If the node is not reachable anymore but we remember it had an edge to us, clean it up */
|
||||||
|
|
||||||
|
if(!to->status.reachable) {
|
||||||
|
e = lookup_edge(to, myself);
|
||||||
|
if(e) {
|
||||||
|
send_del_edge(broadcast, e);
|
||||||
|
edge_del(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue