chiark
/
gitweb
/
~mdw
/
adns
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Copyright dates fixed; various TODOs added.
[adns]
/
client
/
adnstest.c
diff --git
a/client/adnstest.c
b/client/adnstest.c
index 2c011558c3e564e89ab80d841dd647b5a71239b9..ea9ed2a35bd1e7c98ca41fa164d281f0356b1a3d 100644
(file)
--- a/
client/adnstest.c
+++ b/
client/adnstest.c
@@
-3,7
+3,7
@@
* - simple test program, not part of the library
*/
/*
* - simple test program, not part of the library
*/
/*
- * This file is part of adns, which is Copyright (C) 1997
, 1998
Ian Jackson
+ * This file is part of adns, which is Copyright (C) 1997
-1999
Ian Jackson
*
* 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
@@
-25,6
+25,10
@@
#include <assert.h>
#include <stdlib.h>
#include <assert.h>
#include <stdlib.h>
+#ifndef OUTPUTSTREAM
+# define OUTPUTSTREAM stdout
+#endif
+
#include "adns.h"
static void failure(const char *what, adns_status st) {
#include "adns.h"
static void failure(const char *what, adns_status st) {
@@
-66,13
+70,21
@@
int main(int argc, char *const *argv) {
adns_state ads;
adns_query *qus, qu;
adns_answer *ans;
adns_state ads;
adns_query *qus, qu;
adns_answer *ans;
- const char *rrtn, *fmtn, *const *domlist;
+ const char *initstring, *rrtn, *fmtn;
+ const char *const *domlist;
char *show, *cp;
int len, i, qc, qi, tc, ti, ch;
adns_status r, ri;
const adns_rrtype *types;
adns_rrtype *types_a;
char *show, *cp;
int len, i, qc, qi, tc, ti, ch;
adns_status r, ri;
const adns_rrtype *types;
adns_rrtype *types_a;
+ if (argv[0] && argv[1] && argv[1][0] == '/') {
+ initstring= argv[1]+1;
+ argv++;
+ } else {
+ initstring= 0;
+ }
+
if (argv[0] && argv[1] && argv[1][0] == ':') {
for (cp= argv[1]+1, tc=1; (ch= *cp); cp++)
if (ch==',') tc++;
if (argv[0] && argv[1] && argv[1][0] == ':') {
for (cp= argv[1]+1, tc=1; (ch= *cp); cp++)
if (ch==',') tc++;
@@
-82,7
+94,7
@@
int main(int argc, char *const *argv) {
types_a[ti]= strtoul(cp,&cp,10);
if ((ch= *cp)) {
if (ch != ',') {
types_a[ti]= strtoul(cp,&cp,10);
if ((ch= *cp)) {
if (ch != ',') {
- fputs("usage: dtest [:<typenum>,...] [<domain> ...]\n",stderr);
+ fputs("usage: dtest [
/<initstring>] [
:<typenum>,...] [<domain> ...]\n",stderr);
exit(4);
}
cp++;
exit(4);
}
cp++;
@@
-102,7
+114,11
@@
int main(int argc, char *const *argv) {
qus= malloc(sizeof(qus)*qc*tc);
if (!qus) { perror("malloc qus"); exit(3); }
qus= malloc(sizeof(qus)*qc*tc);
if (!qus) { perror("malloc qus"); exit(3); }
- r= adns_init(&ads,adns_if_debug|adns_if_noautosys,0);
+ if (initstring) {
+ r= adns_init_strcfg(&ads,adns_if_debug|adns_if_noautosys,stdout,initstring);
+ } else {
+ r= adns_init(&ads,adns_if_debug|adns_if_noautosys,0);
+ }
if (r) failure("init",r);
for (qi=0; qi<qc; qi++) {
if (r) failure("init",r);
for (qi=0; qi<qc; qi++) {
@@
-116,7
+132,7
@@
int main(int argc, char *const *argv) {
failure("submit",r);
} else {
ri= adns_rr_info(types[ti], &rrtn,&fmtn,0, 0,0);
failure("submit",r);
} else {
ri= adns_rr_info(types[ti], &rrtn,&fmtn,0, 0,0);
- putc
har(' '
);
+ putc
(' ',stdout
);
dumptype(ri,rrtn,fmtn);
fprintf(stdout," submitted\n");
}
dumptype(ri,rrtn,fmtn);
fprintf(stdout," submitted\n");
}
@@
-141,7
+157,7
@@
int main(int argc, char *const *argv) {
for (i=0; i<ans->nrrs; i++) {
r= adns_rr_info(ans->type, 0,0,0, ans->rrs.bytes+i*len,&show);
if (r) failure("info",r);
for (i=0; i<ans->nrrs; i++) {
r= adns_rr_info(ans->type, 0,0,0, ans->rrs.bytes+i*len,&show);
if (r) failure("info",r);
-
printf(
" %s\n",show);
+
fprintf(stdout,
" %s\n",show);
free(show);
}
}
free(show);
}
}