From 6a59182e81ad9186699ec6931e5a40851fce0df0 Mon Sep 17 00:00:00 2001
From: Daniel Stenberg <daniel@haxx.se>
Date: Wed, 22 Nov 2006 22:54:41 +0000
Subject: [PATCH] Michael Wallner fixed this problem: When I set domains in the
 options struct, and there are domain/search entries in /etc/resolv.conf, the
 domains of the options struct will be overridden.

---
 CHANGES     | 4 ++++
 ares_init.c | 4 ++--
 2 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/CHANGES b/CHANGES
index fe2fd6a0..bfe2e4ae 100644
--- a/CHANGES
+++ b/CHANGES
@@ -4,6 +4,10 @@
 
 - Install ares_dns.h too
 
+- Michael Wallner fixed this problem: When I set domains in the options
+  struct, and there are domain/search entries in /etc/resolv.conf, the domains
+  of the options struct will be overridden.
+
 * November 6
 
 - Yang Tse removed a couple of potential zero size memory allocations.
diff --git a/ares_init.c b/ares_init.c
index 7246bc48..e32633fd 100644
--- a/ares_init.c
+++ b/ares_init.c
@@ -592,11 +592,11 @@ DhcpNameServer
       return (errno == ENOENT) ? ARES_SUCCESS : ARES_EFILE;
     while ((status = ares__read_line(fp, &line, &linesize)) == ARES_SUCCESS)
     {
-      if ((p = try_config(line, "domain")))
+      if ((p = try_config(line, "domain")) && channel->ndomains == -1)
         status = config_domain(channel, p);
       else if ((p = try_config(line, "lookup")) && !channel->lookups)
         status = config_lookup(channel, p, "bind", "file");
-      else if ((p = try_config(line, "search")))
+      else if ((p = try_config(line, "search")) && channel->ndomains == -1)
         status = set_search(channel, p);
       else if ((p = try_config(line, "nameserver")) && channel->nservers == -1)
         status = config_nameserver(&servers, &nservers, p);