X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=client%2Fadnstest.c;h=d8003dcde676a467acd00c2e6c119556779903fa;hb=a6536d8becc65c37fbeab7bc0793c6dd55bea977;hp=56cf45fa679e5ed8d99252c35725a2b647a59657;hpb=ffbda80c54147d112c125f208f6611daf09358b3;p=adns.git diff --git a/client/adnstest.c b/client/adnstest.c index 56cf45f..d8003dc 100644 --- a/client/adnstest.c +++ b/client/adnstest.c @@ -39,25 +39,58 @@ static const adns_rrtype defaulttypes[]= { adns_r_ns_raw, adns_r_cname, adns_r_ptr_raw, + adns_r_mx_raw, + adns_r_txt, + adns_r_rp_raw, + adns_r_addr, + adns_r_ns, + adns_r_mx, + adns_r_ptr, adns_r_none }; -int main(int argc, const char *const *argv) { +static void dumptype(adns_status ri, const char *rrtn, const char *fmtn) { + fprintf(stdout, "%s(%s)%s%s", + ri ? "?" : rrtn, ri ? "?" : fmtn ? fmtn : "-", + ri ? " " : "", ri ? adns_strerror(ri) : ""); +} + +int main(int argc, char *const *argv) { adns_state ads; adns_query *qus, qu; adns_answer *ans; - const char *rrtn, *fmtn; - char *show; - int len, i, qc, qi, tc, ti; + const char *rrtn, *fmtn, *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; - if (argv[0] && argv[1]) argv++; - else argv= defaultargv; - - types= defaulttypes; + if (argv[0] && argv[1] && argv[1][0] == ':') { + for (cp= argv[1]+1, tc=1; (ch= *cp); cp++) + if (ch==',') tc++; + types_a= malloc(sizeof(*types_a)*tc); + if (!types_a) { perror("malloc types"); exit(3); } + for (cp= argv[1]+1, ti=0; ti,...] [ ...]\n",stderr); + exit(4); + } + cp++; + } + } + types= types_a; + argv++; + } else { + types= defaulttypes; + } + + if (argv[0] && argv[1]) domlist= (const char *const*)argv+1; + else domlist= defaultargv; - for (qc=0; qc[argv]; qc++); + for (qc=0; qc[domlist]; qc++); for (tc=0; types[tc] != adns_r_none; tc++); qus= malloc(sizeof(qus)*qc*tc); if (!qus) { perror("malloc qus"); exit(3); } @@ -67,25 +100,35 @@ int main(int argc, const char *const *argv) { for (qi=0; qitype, &rrtn,&fmtn,&len, 0,0); - fprintf(stdout, "%s: %s; nrrs=%d; cname=%s; ", - argv[qi], adns_strerror(ans->status), + fprintf(stdout, "%s type ", domlist[qi]); + dumptype(ri,rrtn,fmtn); + fprintf(stdout, ": %s; nrrs=%d; cname=%s\n", + adns_strerror(ans->status), ans->nrrs, ans->cname ? ans->cname : "$"); - fprintf(stdout, "type %s(%s) %s\n", - ri ? "?" : rrtn, ri ? "?" : fmtn ? fmtn : "-", - adns_strerror(ri)); if (ans->nrrs) { assert(!ri); for (i=0; inrrs; i++) {