From 54bd43263c26dc8d8ffb3cf818dacc493e132a4a Mon Sep 17 00:00:00 2001 From: millert <> Date: Wed, 2 Apr 2003 02:43:50 +0000 Subject: [PATCH] use strlcpy(); assumes buf is at least ndigit bytes long which is as safe as we can get. deraadt@ OK --- src/lib/libc/stdlib/gcvt.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/src/lib/libc/stdlib/gcvt.c b/src/lib/libc/stdlib/gcvt.c index c1a96b17..fda487d7 100644 --- a/src/lib/libc/stdlib/gcvt.c +++ b/src/lib/libc/stdlib/gcvt.c @@ -1,4 +1,4 @@ -/* $OpenBSD: gcvt.c,v 1.1 2002/12/02 15:38:54 millert Exp $ */ +/* $OpenBSD: gcvt.c,v 1.2 2003/04/02 02:43:50 millert Exp $ */ /* * Copyright (c) 2002 Todd C. Miller @@ -28,7 +28,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static char rcsid[] = "$OpenBSD: gcvt.c,v 1.1 2002/12/02 15:38:54 millert Exp $"; +static char rcsid[] = "$OpenBSD: gcvt.c,v 1.2 2003/04/02 02:43:50 millert Exp $"; #endif /* LIBC_SCCS and not lint */ #include @@ -49,8 +49,11 @@ gcvt(double value, int ndigit, char *buf) } digits = __dtoa(value, 2, ndigit, &decpt, &sign, NULL); - if (decpt == 9999) - return (strcpy(buf, digits)); + if (decpt == 9999) { + /* Infinity or NaN, assume buffer is at least ndigit long. */ + strlcpy(buf, digits, ndigit); + return (buf); + } dst = buf; if (sign)