avoid sprintf. use snprintf. simplify cases where 1st arg is 0.
This commit is contained in:
parent
a71878134b
commit
0b6566bcda
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user