refactor name_from_dns in hostname lookup backend
authorNatanael Copa <ncopa@alpinelinux.org>
Wed, 15 Jun 2016 18:27:46 +0000 (20:27 +0200)
committerRich Felker <dalias@aerifal.cx>
Wed, 29 Jun 2016 15:59:25 +0000 (11:59 -0400)
loop over an address family / resource record mapping to avoid
repetitive code.

src/network/lookup_name.c

index d3d97b48d1aebf889bb33eeb2a8dc92ed003b82b..fb7303a309618feaf02ccc1e9c1bc186c135b8ef 100644 (file)
@@ -141,20 +141,19 @@ static int name_from_dns(struct address buf[static MAXADDRS], char canon[static
        int qlens[2], alens[2];
        int i, nq = 0;
        struct dpc_ctx ctx = { .addrs = buf, .canon = canon };
-
-       if (family != AF_INET6) {
-               qlens[nq] = __res_mkquery(0, name, 1, RR_A, 0, 0, 0,
-                       qbuf[nq], sizeof *qbuf);
-               if (qlens[nq] == -1)
-                       return EAI_NONAME;
-               nq++;
-       }
-       if (family != AF_INET) {
-               qlens[nq] = __res_mkquery(0, name, 1, RR_AAAA, 0, 0, 0,
-                       qbuf[nq], sizeof *qbuf);
-               if (qlens[nq] == -1)
-                       return EAI_NONAME;
-               nq++;
+       static const struct { int af; int rr; } afrr[2] = {
+               { .af = AF_INET6, .rr = RR_A },
+               { .af = AF_INET, .rr = RR_AAAA },
+       };
+
+       for (i=0; i<2; i++) {
+               if (family != afrr[i].af) {
+                       qlens[nq] = __res_mkquery(0, name, 1, afrr[i].rr,
+                               0, 0, 0, qbuf[nq], sizeof *qbuf);
+                       if (qlens[nq] == -1)
+                               return EAI_NONAME;
+                       nq++;
+               }
        }
 
        if (__res_msend_rc(nq, qp, qlens, ap, alens, sizeof *abuf, conf) < 0)