X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fconnection.c;h=0c5e7ef0297468b25bc0f9fac2109276856b345f;hb=0871c3095151bce6a4031a2662aa51b7193b855c;hp=5a7c43b860c4a14bc4bd11b75953eac301adcc30;hpb=9e917cc3b614d7a986416e6a2c3ea9ea583adacf;p=tinc diff --git a/src/connection.c b/src/connection.c index 5a7c43b8..0c5e7ef0 100644 --- a/src/connection.c +++ b/src/connection.c @@ -31,19 +31,23 @@ #include "utils.h" #include "xalloc.h" -list_t *connection_list; +list_t connection_list = { + .head = NULL, + .tail = NULL, + .count = 0, + .delete = (list_action_t) free_connection, +}; + connection_t *everyone; void init_connections(void) { - connection_list = list_alloc((list_action_t) free_connection); everyone = new_connection(); everyone->name = xstrdup("everyone"); everyone->hostname = xstrdup("BROADCAST"); } void exit_connections(void) { - list_delete_list(connection_list); - connection_list = NULL; + list_empty_list(&connection_list); free_connection(everyone); everyone = NULL; @@ -96,15 +100,15 @@ void free_connection(connection_t *c) { } void connection_add(connection_t *c) { - list_insert_tail(connection_list, c); + list_insert_tail(&connection_list, c); } void connection_del(connection_t *c) { - list_delete(connection_list, c); + list_delete(&connection_list, c); } bool dump_connections(connection_t *cdump) { - for list_each(connection_t, c, connection_list) { + for list_each(connection_t, c, &connection_list) { send_request(cdump, "%d %d %s %s %x %d %x", CONTROL, REQ_DUMP_CONNECTIONS, c->name, c->hostname, c->options, c->socket,