chiark
/
gitweb
/
~mdw
/
adns
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Regression test scripts set EF_DISABLE_BANNER (for Electric Fence).
[adns]
/
src
/
query.c
diff --git
a/src/query.c
b/src/query.c
index a676376587ca7053ef758b3511c305d1f0054a38..b9e6d4dffb91ed7d57ceb4e87afd08e9d2d7bb29 100644
(file)
--- a/
src/query.c
+++ b/
src/query.c
@@
-5,7
+5,12
@@
* - query submission and cancellation (user-visible and internal)
*/
/*
* - query submission and cancellation (user-visible and internal)
*/
/*
- * This file is part of adns, which is Copyright (C) 1997-1999 Ian Jackson
+ * This file is
+ * Copyright (C) 1997-1999 Ian Jackson <ian@davenant.greenend.org.uk>
+ *
+ * It is part of adns, which is
+ * Copyright (C) 1997-1999 Ian Jackson <ian@davenant.greenend.org.uk>
+ * Copyright (C) 1999 Tony Finch <dot@dotat.at>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@
-100,7
+105,6
@@
static void query_submit(adns_state ads, adns_query qu,
memcpy(qu->query_dgram,qu->vb.buf,qu->vb.used);
adns__query_send(qu,now);
memcpy(qu->query_dgram,qu->vb.buf,qu->vb.used);
adns__query_send(qu,now);
- adns__autosys(ads,now);
}
adns_status adns__internal_submit(adns_state ads, adns_query *query_r,
}
adns_status adns__internal_submit(adns_state ads, adns_query *query_r,
@@
-238,6
+242,7
@@
int adns_submit(adns_state ads,
}
query_simple(ads,qu, owner,ol, typei,flags, now);
}
}
query_simple(ads,qu, owner,ol, typei,flags, now);
}
+ adns__autosys(ads,now);
adns__consistency(ads,qu,cc_entex);
return 0;
adns__consistency(ads,qu,cc_entex);
return 0;
@@
-346,7
+351,6
@@
static void cancel_children(adns_query qu) {
ncqu= cqu->siblings.next;
adns_cancel(cqu);
}
ncqu= cqu->siblings.next;
adns_cancel(cqu);
}
- LIST_INIT(qu->children);
}
void adns__reset_preserved(adns_query qu) {
}
void adns__reset_preserved(adns_query qu) {
@@
-371,6
+375,7
@@
void adns_cancel(adns_query qu) {
ads= qu->ads;
adns__consistency(ads,qu,cc_entex);
ads= qu->ads;
adns__consistency(ads,qu,cc_entex);
+ if (qu->parent) LIST_UNLINK_PART(qu->parent->children,qu,siblings.);
switch (qu->state) {
case query_tosend: case query_tcpwait: case query_tcpsent:
LIST_UNLINK(ads->timew,qu);
switch (qu->state) {
case query_tosend: case query_tcpwait: case query_tcpsent:
LIST_UNLINK(ads->timew,qu);
@@
-474,8
+479,8
@@
void adns__query_done(adns_query qu) {
} else {
makefinal_query(qu);
LIST_LINK_TAIL(qu->ads->output,qu);
} else {
makefinal_query(qu);
LIST_LINK_TAIL(qu->ads->output,qu);
+ qu->state= query_done;
}
}
- qu->state= query_done;
}
void adns__query_fail(adns_query qu, adns_status stat) {
}
void adns__query_fail(adns_query qu, adns_status stat) {