aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--networking/nslookup.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/networking/nslookup.c b/networking/nslookup.c
index f4fd407dd..dd4b1ffed 100644
--- a/networking/nslookup.c
+++ b/networking/nslookup.c
@@ -138,6 +138,9 @@ static void set_default_dns(const char *server)
138{ 138{
139 len_and_sockaddr *lsa; 139 len_and_sockaddr *lsa;
140 140
141 if (!server)
142 return;
143
141 /* NB: this works even with, say, "[::1]:5353"! :) */ 144 /* NB: this works even with, say, "[::1]:5353"! :) */
142 lsa = xhost2sockaddr(server, 53); 145 lsa = xhost2sockaddr(server, 53);
143 146
@@ -181,9 +184,17 @@ int nslookup_main(int argc, char **argv)
181 /* (but it also says "may be enabled in /etc/resolv.conf") */ 184 /* (but it also says "may be enabled in /etc/resolv.conf") */
182 /*_res.options |= RES_USE_INET6;*/ 185 /*_res.options |= RES_USE_INET6;*/
183 186
184 if (argv[2]) 187 set_default_dns(argv[2]);
185 set_default_dns(argv[2]);
186 188
187 server_print(); 189 server_print();
190
191 /* getaddrinfo and friends are free to request a resolver
192 * reinitialization. Just in case, set_default_dns() again
193 * after getaddrinfo (in server_print). This reportedly helps
194 * with bug 675 "nslookup does not properly use second argument"
195 * at least on Debian Wheezy and Openwrt AA (eglibc based).
196 */
197 set_default_dns(argv[2]);
198
188 return print_host(argv[1], "Name:"); 199 return print_host(argv[1], "Name:");
189} 200}