X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fprotocol_edge.c;h=5949a38e7bea336fdbdcb1ca1dd994a29abb6d61;hp=e1e2ca01cd61973636b6d48d64dd750164107d98;hb=1d7706a8506d8073def0965da809960c6ad8bf9a;hpb=eefa28059ab989c915a7d95fb4ae728abd7ce713 diff --git a/src/protocol_edge.c b/src/protocol_edge.c index e1e2ca01..5949a38e 100644 --- a/src/protocol_edge.c +++ b/src/protocol_edge.c @@ -17,7 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id: protocol_edge.c,v 1.1.4.19 2003/07/22 20:55:20 guus Exp $ + $Id: protocol_edge.c,v 1.1.4.21 2003/08/28 15:27:12 guus Exp $ */ #include "system.h" @@ -36,7 +36,7 @@ #include "utils.h" #include "xalloc.h" -bool send_add_edge(connection_t *c, edge_t *e) +bool send_add_edge(connection_t *c, const edge_t *e) { bool x; char *address, *port; @@ -163,7 +163,7 @@ bool add_edge_h(connection_t *c) return true; } -bool send_del_edge(connection_t *c, edge_t *e) +bool send_del_edge(connection_t *c, const edge_t *e) { cp(); @@ -250,5 +250,15 @@ bool del_edge_h(connection_t *c) 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; }