diff options
author | Jukka Rissanen <jukka.rissanen@linux.intel.com> | 2012-01-03 14:36:28 +0200 |
---|---|---|
committer | Daniel Wagner <daniel.wagner@bmw-carit.de> | 2012-01-05 11:09:16 +0100 |
commit | 70ce3cd0a6130605a5f3c1f4f334bd501bece184 (patch) | |
tree | 70b21b96f9c5b9e8b7b534c7da0def4bf8650150 /src/service.c | |
parent | 097f0059d972e639d75ac7d0b27db759fbf05e5c (diff) | |
download | connman-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.c | 27 |
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; } |