avoid sprintf. use snprintf. simplify cases where 1st arg is 0.

This commit is contained in:
itojun 2002-08-16 12:03:41 +00:00
parent a71878134b
commit 0b6566bcda

View File

@ -1,4 +1,4 @@
/* $NetBSD: inet_neta.c,v 1.11 2000/01/22 22:19:15 mycroft Exp $ */ /* $NetBSD: inet_neta.c,v 1.12 2002/08/16 12:03:41 itojun Exp $ */
/* /*
* Copyright (c) 1996 by Internet Software Consortium. * Copyright (c) 1996 by Internet Software Consortium.
@ -22,7 +22,7 @@
#if 0 #if 0
static const char rcsid[] = "Id: inet_neta.c,v 8.2 1996/08/08 06:54:44 vixie Exp "; static const char rcsid[] = "Id: inet_neta.c,v 8.2 1996/08/08 06:54:44 vixie Exp ";
#else #else
__RCSID("$NetBSD: inet_neta.c,v 1.11 2000/01/22 22:19:15 mycroft Exp $"); __RCSID("$NetBSD: inet_neta.c,v 1.12 2002/08/16 12:03:41 itojun Exp $");
#endif #endif
#endif #endif
@ -41,12 +41,6 @@ __RCSID("$NetBSD: inet_neta.c,v 1.11 2000/01/22 22:19:15 mycroft Exp $");
__weak_alias(inet_neta,_inet_neta) __weak_alias(inet_neta,_inet_neta)
#endif #endif
#ifdef SPRINTF_CHAR
# define SPRINTF(x) strlen(sprintf/**/x)
#else
# define SPRINTF(x) ((size_t)sprintf x)
#endif
/* /*
* char * * char *
* inet_neta(src, dst, size) * inet_neta(src, dst, size)
@ -65,31 +59,37 @@ inet_neta(src, dst, size)
size_t size; size_t size;
{ {
char *odst = dst; char *odst = dst;
char *tp; char *ep;
int advance;
_DIAGASSERT(dst != NULL); _DIAGASSERT(dst != NULL);
if (src == 0x00000000) {
if (size < sizeof "0.0.0.0")
goto emsgsize;
strlcpy(dst, "0.0.0.0", size);
return dst;
}
ep = dst + size;
while (src & 0xffffffff) { while (src & 0xffffffff) {
u_char b = (u_char)((src & 0xff000000) >> 24); u_char b = (u_char)((src & 0xff000000) >> 24);
src <<= 8; src <<= 8;
if (b) { if (b) {
if (size < sizeof "255.") if (ep - dst < sizeof "255.")
goto emsgsize; goto emsgsize;
tp = dst; advance = snprintf(dst, (size_t)(ep - dst), "%u", b);
dst += SPRINTF((dst, "%u", b)); if (advance <= 0 || advance >= ep - dst)
goto emsgsize;
dst += advance;
if (src != 0L) { if (src != 0L) {
if (dst + 1 >= ep)
goto emsgsize;
*dst++ = '.'; *dst++ = '.';
*dst = '\0'; *dst = '\0';
} }
size -= (size_t)(dst - tp);
} }
} }
if (dst == odst) {
if (size < sizeof "0.0.0.0")
goto emsgsize;
strcpy(dst, "0.0.0.0");
}
return (odst); return (odst);
emsgsize: emsgsize: