diff options
| author | Lennart Poettering <lennart@poettering.net> | 2015-11-25 20:47:27 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2015-11-25 21:59:16 +0100 | 
| commit | 801ad6a6a9cd8fbd58b9f9c27f20dbb3c87d47dd (patch) | |
| tree | db95ac0b7a04e4c0a0135d64c3077391eaea7356 /src/resolve/resolved-dns-answer.h | |
| parent | 7f220d94a938a99c77400fa0ca30485e269bae7c (diff) | |
resolved: fully support DNS search domains
This adds support for searching single-label hostnames in a set of
configured search domains.
A new object DnsQueryCandidate is added that links queries to scopes.
It keeps track of the search domain last used for a query on a specific
link. Whenever a host name was unsuccessfuly resolved on a scope all its
transactions are flushed out and replaced by a new set, with the next
search domain appended.
This also adds a new flag SD_RESOLVED_NO_SEARCH to disable search domain
behaviour. The "systemd-resolve-host" tool is updated to make this
configurable via --search=.
Fixes #1697
Diffstat (limited to 'src/resolve/resolved-dns-answer.h')
| -rw-r--r-- | src/resolve/resolved-dns-answer.h | 8 | 
1 files changed, 4 insertions, 4 deletions
| diff --git a/src/resolve/resolved-dns-answer.h b/src/resolve/resolved-dns-answer.h index b5b1ad56ba..8814919deb 100644 --- a/src/resolve/resolved-dns-answer.h +++ b/src/resolve/resolved-dns-answer.h @@ -61,7 +61,7 @@ DEFINE_TRIVIAL_CLEANUP_FUNC(DnsAnswer*, dns_answer_unref);  #define DNS_ANSWER_FOREACH(kk, a)                                       \          for (unsigned _i = ({                                           \ -                                (kk) = ((a) && (a)->n_rrs > 0 ? (a)->items[0].rr : NULL); \ +                                (kk) = ((a) && (a)->n_rrs > 0) ? (a)->items[0].rr : NULL; \                                  0;                                      \                             });                                          \               (a) && ((_i) < (a)->n_rrs);                                \ @@ -69,9 +69,9 @@ DEFINE_TRIVIAL_CLEANUP_FUNC(DnsAnswer*, dns_answer_unref);  #define DNS_ANSWER_FOREACH_IFINDEX(kk, ifindex, a)                      \          for (unsigned _i = ({                                           \ -                                (kk) = ((a) && (a)->n_rrs > 0 ? (a)->items[0].rr : NULL); \ -                                (ifindex) = ((a) && (a)->n_rrs > 0 ? (a)->items[0].ifindex : 0); \ +                                (kk) = ((a) && (a)->n_rrs > 0) ? (a)->items[0].rr : NULL; \ +                                (ifindex) = ((a) && (a)->n_rrs > 0) ? (a)->items[0].ifindex : 0; \                                  0;                                      \                             });                                          \               (a) && ((_i) < (a)->n_rrs);                                \ -             _i++, (kk) = (_i < (a)->n_rrs ? (a)->items[_i].rr : NULL), (ifindex) = (_i < (a)->n_rrs ? (a)->items[_i].ifindex : 0)) +             _i++, (kk) = ((_i < (a)->n_rrs) ? (a)->items[_i].rr : NULL), (ifindex) = ((_i < (a)->n_rrs) ? (a)->items[_i].ifindex : 0)) | 
