From 1649e680f62450a29589c23c64a67267e9e439f2 Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Tue, 11 Dec 2012 20:13:29 +0100 Subject: Curl_conncache_foreach: allow callback to break loop ... and have it take a proper 'struct connectdata *' as first argument --- lib/conncache.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'lib/conncache.c') diff --git a/lib/conncache.c b/lib/conncache.c index 4bca7ba51..a3a90f879 100644 --- a/lib/conncache.c +++ b/lib/conncache.c @@ -180,10 +180,13 @@ void Curl_conncache_remove_conn(struct conncache *connc, /* This function iterates the entire connection cache and calls the function func() with the connection pointer as the first argument - and the supplied 'param' argument as the other */ + and the supplied 'param' argument as the other, + + Return 0 from func() to continue the loop, return 1 to abort it. + */ void Curl_conncache_foreach(struct conncache *connc, void *param, - void (*func)(void *conn, void *param)) + int (*func)(struct connectdata *conn, void *param)) { struct curl_hash_iterator iter; struct curl_llist_element *curr; @@ -208,7 +211,8 @@ void Curl_conncache_foreach(struct conncache *connc, conn = curr->ptr; curr = curr->next; - func(conn, param); + if(1 == func(conn, param)) + return; } he = Curl_hash_next_element(&iter); -- cgit v1.2.3