de-duplicate dn_expand, fix return value and signature, clean up
authorRich Felker <dalias@aerifal.cx>
Wed, 14 Aug 2013 21:58:20 +0000 (17:58 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 14 Aug 2013 21:58:20 +0000 (17:58 -0400)
commitfcc522c92335783293ac19df318415cd97fbf66b
tree35de93be8123cb7cd075994087d132e3c8bbb906
parentcccc1844be95549e5b6c91ffc1f2c2ba3d3aab16
de-duplicate dn_expand, fix return value and signature, clean up

the duplicate code in dn_expand and its incorrect return values are
both results of the history of the code: the version in __dns.c was
originally written with no awareness of the legacy resolver API, and
was later copy-and-paste duplicated to provide the legacy API.

this commit is the first of a series that will restructure the
internal dns code to share as much code as possible with the legacy
resolver API functions.

I have also removed the loop detection logic, since the output buffer
length limit naturally prevents loops. in order to avoid long runtime
when encountering a loop if the caller provided a ridiculously long
buffer, the caller-provided length is clamped at the maximum dns name
length.
include/resolv.h
src/network/__dns.c
src/network/dn_expand.c