inet_ntop() and copies the output (but not the trailing null) into the buffer.
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: rdata.c,v 1.141 2001/01/09 21:51:20 bwelling Exp $ */
+/* $Id: rdata.c,v 1.142 2001/01/25 20:14:36 bwelling Exp $ */
#include <config.h>
#include <ctype.h>
static isc_result_t
str_totext(const char *source, isc_buffer_t *target);
+static isc_result_t
+inet_totext(int af, isc_region_t *src, isc_buffer_t *target);
+
static isc_boolean_t
buffer_empty(isc_buffer_t *source);
return (ISC_R_SUCCESS);
}
+static isc_result_t
+inet_totext(int af, isc_region_t *src, isc_buffer_t *target) {
+ char tmpbuf[64];
+
+ /* Note - inet_ntop doesn't do size checking on its input. */
+ if (inet_ntop(af, src->base, tmpbuf, sizeof(tmpbuf)) == NULL)
+ return (ISC_R_NOSPACE);
+ if (strlen(tmpbuf) > isc_buffer_availablelength(target))
+ return (ISC_R_NOSPACE);
+ isc_buffer_putstr(target, tmpbuf);
+ return (ISC_R_SUCCESS);
+}
+
static isc_boolean_t
buffer_empty(isc_buffer_t *source) {
return((source->current == source->active) ? ISC_TRUE : ISC_FALSE);
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: a_1.c,v 1.21 2001/01/09 21:54:58 bwelling Exp $ */
+/* $Id: a_1.c,v 1.22 2001/01/25 20:14:38 bwelling Exp $ */
/* reviewed: Thu Mar 16 15:58:36 PST 2000 by brister */
UNUSED(tctx);
- isc_buffer_availableregion(target, ®ion);
- if (inet_ntop(AF_INET, rdata->data,
- (char *)region.base, region.length) == NULL)
- return (ISC_R_NOSPACE);
-
- isc_buffer_add(target, strlen((char *)region.base));
- return (ISC_R_SUCCESS);
+ dns_rdata_toregion(rdata, ®ion);
+ return (inet_totext(AF_INET, ®ion, target));
}
static inline isc_result_t
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: a6_38.c,v 1.40 2001/01/09 21:55:00 bwelling Exp $ */
+/* $Id: a6_38.c,v 1.41 2001/01/25 20:14:39 bwelling Exp $ */
/* draft-ietf-ipngwg-dns-lookups-03.txt */
static inline isc_result_t
totext_in_a6(ARGS_TOTEXT) {
- isc_region_t tr;
- isc_region_t sr;
+ isc_region_t sr, ar;
unsigned char addr[16];
unsigned char prefixlen;
unsigned char octets;
memcpy(&addr[octets], sr.base, 16 - octets);
mask = 0xff >> (prefixlen % 8);
addr[octets] &= mask;
- isc_buffer_availableregion(target, &tr);
- if (inet_ntop(AF_INET6, addr,
- (char *)tr.base, tr.length) == NULL)
- return (ISC_R_NOSPACE);
-
- isc_buffer_add(target, strlen((char *)tr.base));
+ ar.base = addr;
+ ar.length = sizeof(addr);
+ RETERR(inet_totext(AF_INET6, &ar, target));
isc_region_consume(&sr, 16 - octets);
}
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: a_1.c,v 1.42 2001/01/09 21:55:03 bwelling Exp $ */
+/* $Id: a_1.c,v 1.43 2001/01/25 20:14:40 bwelling Exp $ */
/* Reviewed: Thu Mar 16 16:52:50 PST 2000 by bwelling */
UNUSED(tctx);
- isc_buffer_availableregion(target, ®ion);
- if (inet_ntop(AF_INET, rdata->data,
- (char *)region.base, region.length) == NULL)
- return (ISC_R_NOSPACE);
-
- isc_buffer_add(target, strlen((char *)region.base));
- return (ISC_R_SUCCESS);
+ dns_rdata_toregion(rdata, ®ion);
+ return (inet_totext(AF_INET, ®ion, target));
}
static inline isc_result_t
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: aaaa_28.c,v 1.32 2001/01/09 21:55:05 bwelling Exp $ */
+/* $Id: aaaa_28.c,v 1.33 2001/01/25 20:14:41 bwelling Exp $ */
/* Reviewed: Thu Mar 16 16:52:50 PST 2000 by bwelling */
REQUIRE(rdata->rdclass == 1);
REQUIRE(rdata->length == 16);
- isc_buffer_availableregion(target, ®ion);
- if (inet_ntop(AF_INET6, rdata->data,
- (char *)region.base, region.length) == NULL)
- return (ISC_R_NOSPACE);
-
- isc_buffer_add(target, strlen((char *)region.base));
- return (ISC_R_SUCCESS);
+ dns_rdata_toregion(rdata, ®ion);
+ return (inet_totext(AF_INET6, ®ion, target));
}
static inline isc_result_t
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: wks_11.c,v 1.39 2001/01/09 21:55:21 bwelling Exp $ */
+/* $Id: wks_11.c,v 1.40 2001/01/25 20:14:42 bwelling Exp $ */
/* Reviewed: Fri Mar 17 15:01:49 PST 2000 by explorer */
static inline isc_result_t
totext_in_wks(ARGS_TOTEXT) {
isc_region_t sr;
- isc_region_t tr;
unsigned short proto;
char buf[sizeof "65535"];
unsigned int i, j;
REQUIRE(rdata->type == 11);
REQUIRE(rdata->rdclass == 1);
- REQUIRE(rdata->length != 0);
+ REQUIRE(rdata->length >= 5);
dns_rdata_toregion(rdata, &sr);
- isc_buffer_availableregion(target, &tr);
- if (inet_ntop(AF_INET, sr.base, (char *)tr.base, tr.length) == NULL)
- return (ISC_R_NOSPACE);
- isc_buffer_add(target, strlen((char *)tr.base));
+ RETERR(inet_totext(AF_INET, &sr, target));
isc_region_consume(&sr, 4);
proto = uint8_fromregion(&sr);