aboutsummaryrefslogtreecommitdiff
path: root/ares/ares_cancel.c
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2004-04-01 08:25:58 +0000
committerDaniel Stenberg <daniel@haxx.se>2004-04-01 08:25:58 +0000
commit6c9d96e811b7ad4d8830714011c31e5c33506829 (patch)
treeb1561963996ac5adb20d77c5259df4ffcd96216a /ares/ares_cancel.c
parentf840e5192c5119109b71b6433ee3ef0b779037f3 (diff)
Dirk Manske's ares_cancel() function was added.
Diffstat (limited to 'ares/ares_cancel.c')
-rw-r--r--ares/ares_cancel.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/ares/ares_cancel.c b/ares/ares_cancel.c
new file mode 100644
index 000000000..b127ed112
--- /dev/null
+++ b/ares/ares_cancel.c
@@ -0,0 +1,44 @@
+/* Copyright 1998 by the Massachusetts Institute of Technology.
+ *
+ * Permission to use, copy, modify, and distribute this
+ * software and its documentation for any purpose and without
+ * fee is hereby granted, provided that the above copyright
+ * notice appear in all copies and that both that copyright
+ * notice and this permission notice appear in supporting
+ * documentation, and that the name of M.I.T. not be used in
+ * advertising or publicity pertaining to distribution of the
+ * software without specific, written prior permission.
+ * M.I.T. makes no representations about the suitability of
+ * this software for any purpose. It is provided "as is"
+ * without express or implied warranty.
+ */
+
+#include <stdlib.h>
+#include "ares.h"
+#include "ares_private.h"
+
+/*
+ * ares_cancel() cancels a ongoing request/resolve that might be going on on
+ * the given channel. It does NOT kill the channel, use ares_destroy() for
+ * that.
+ */
+void ares_cancel(ares_channel channel)
+{
+ struct query *query, *next;
+ int i;
+
+ for (query = channel->queries; query; query = next)
+ {
+ next = query->next;
+ query->callback(query->arg, ARES_ETIMEOUT, NULL, 0);
+ free(query->tcpbuf);
+ free(query->skip_server);
+ free(query);
+ }
+ channel->queries = NULL;
+ if (!(channel->flags & ARES_FLAG_STAYOPEN))
+ {
+ for (i = 0; i < channel->nservers; i++)
+ ares__close_sockets(&channel->servers[i]);
+ }
+}