summaryrefslogtreecommitdiff
path: root/src/service.c
diff options
context:
space:
mode:
authorJukka Rissanen <jukka.rissanen@linux.intel.com>2012-01-03 14:36:28 +0200
committerDaniel Wagner <daniel.wagner@bmw-carit.de>2012-01-05 11:09:16 +0100
commit70ce3cd0a6130605a5f3c1f4f334bd501bece184 (patch)
tree70b21b96f9c5b9e8b7b534c7da0def4bf8650150 /src/service.c
parent097f0059d972e639d75ac7d0b27db759fbf05e5c (diff)
downloadconnman-70ce3cd0a6130605a5f3c1f4f334bd501bece184.tar.gz
connman-70ce3cd0a6130605a5f3c1f4f334bd501bece184.tar.bz2
connman-70ce3cd0a6130605a5f3c1f4f334bd501bece184.zip
service: Return all system defined nameservers when asked
The connman_service_get_nameservers() is changed to return all system defined nameservers. This means that the function now returns an allocated array of all nameservers and caller must deallocate the returned array. The change is needed so that we can combine the nameservers that are set by DHCP code and the IPv6 nameservers that are set by router advertisements.
Diffstat (limited to 'src/service.c')
-rw-r--r--src/service.c27
1 files changed, 24 insertions, 3 deletions
diff --git a/src/service.c b/src/service.c
index ef25069d..02f494b5 100644
--- a/src/service.c
+++ b/src/service.c
@@ -2127,9 +2127,30 @@ char **connman_service_get_nameservers(struct connman_service *service)
return NULL;
if (service->nameservers_config != NULL)
- return service->nameservers_config;
- else if (service->nameservers != NULL)
- return service->nameservers;
+ return g_strdupv(service->nameservers_config);
+ else if (service->nameservers != NULL ||
+ service->nameservers_auto != NULL) {
+ int len = 0, len_auto = 0, i;
+ char **nameservers;
+
+ if (service->nameservers != NULL)
+ len = g_strv_length(service->nameservers);
+ if (service->nameservers_auto != NULL)
+ len_auto = g_strv_length(service->nameservers_auto);
+
+ nameservers = g_try_new0(char *, len + len_auto + 1);
+ if (nameservers == NULL)
+ return NULL;
+
+ for (i = 0; i < len; i++)
+ nameservers[i] = g_strdup(service->nameservers[i]);
+
+ for (i = 0; i < len_auto; i++)
+ nameservers[i + len] =
+ g_strdup(service->nameservers_auto[i]);
+
+ return nameservers;
+ }
return NULL;
}