mirror of https://github.com/c-ares/c-ares.git
parent
8ede9dd9c9
commit
86ae23430c
5 changed files with 95 additions and 4 deletions
@ -0,0 +1,37 @@ |
||||
.\" $Id$ |
||||
.\" |
||||
.\" 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. |
||||
.\" |
||||
.TH ARES_CANCEL 3 "31 March 2004" |
||||
.SH NAME |
||||
ares_cancel \- Cancel a resolve |
||||
.SH SYNOPSIS |
||||
.nf |
||||
.B #include <ares.h> |
||||
.PP |
||||
.B int ares_cancel(ares_channel \fIchannel\fP) |
||||
.fi |
||||
.SH DESCRIPTION |
||||
The \fBares_cancel\fP function cancels all lookups/requests made on the the |
||||
name service channel identified by \fIchannel\fP. \fBares_cancel\fP invokes |
||||
the callbacks for each pending query on the channel, passing a status of |
||||
.BR ARES_ETIMEOUT . |
||||
These calls give the callbacks a chance to clean up any state which |
||||
might have been stored in their arguments. |
||||
.SH SEE ALSO |
||||
.BR ares_init (3) |
||||
.BR ares_destroy (3) |
||||
.SH AUTHOR |
||||
Dirk Manske |
@ -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]); |
||||
} |
||||
} |
Loading…
Reference in new issue