diff options
author | Martynas Venckus <martynas@cvs.openbsd.org> | 2008-07-10 18:18:56 +0000 |
---|---|---|
committer | Martynas Venckus <martynas@cvs.openbsd.org> | 2008-07-10 18:18:56 +0000 |
commit | b0f65514e7a9c23e2daac1919fb5889a6c9ef40b (patch) | |
tree | ba9f52556a3f8c4dd5a9cc0f6177b534bf1d7b76 /lib/libc | |
parent | 4eca66d499b6dac6961c0cafcf5e72cf17dba1cd (diff) |
- handle sign of negative zero. use sign dtoa sets
- remove 'value < 0' cruft, dtoa already clears sign bit for us
discussed with, and tested by phessler@
ok millert@, who noticed to remove now-unused variable, and phessler@
Diffstat (limited to 'lib/libc')
-rw-r--r-- | lib/libc/stdio/vfprintf.c | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/lib/libc/stdio/vfprintf.c b/lib/libc/stdio/vfprintf.c index bdbb7c12271..fd2b944e0af 100644 --- a/lib/libc/stdio/vfprintf.c +++ b/lib/libc/stdio/vfprintf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vfprintf.c,v 1.47 2008/05/16 20:42:52 millert Exp $ */ +/* $OpenBSD: vfprintf.c,v 1.48 2008/07/10 18:18:55 martynas Exp $ */ /*- * Copyright (c) 1990 The Regents of the University of California. * All rights reserved. @@ -149,7 +149,7 @@ __sbprintf(FILE *fp, const char *fmt, va_list ap) extern char *__dtoa(double, int, int, int *, int *, char **); extern void __freedtoa(char *); -static char *cvt(double, int, int, char *, int *, int, int *); +static char *cvt(double, int, int, int *, int *, int, int *); static int exponent(char *, int, int); #else /* no FLOATING_POINT */ @@ -200,7 +200,7 @@ vfprintf(FILE *fp, const char *fmt0, __va_list ap) mbstate_t ps; #ifdef FLOATING_POINT char *decimal_point = localeconv()->decimal_point; - char softsign; /* temporary negative sign for floats */ + int softsign; /* temporary negative sign for floats */ double _double; /* double precision arguments %[eEfgG] */ int expt; /* integer value of exponent */ int expsize; /* character count for expstr */ @@ -1257,10 +1257,10 @@ __grow_type_table(unsigned char **typetable, int *tablesize) #ifdef FLOATING_POINT static char * -cvt(double value, int ndigits, int flags, char *sign, int *decpt, int ch, +cvt(double value, int ndigits, int flags, int *sign, int *decpt, int ch, int *length) { - int mode, dsgn; + int mode; char *digits, *bp, *rve; if (ch == 'f') { @@ -1276,12 +1276,7 @@ cvt(double value, int ndigits, int flags, char *sign, int *decpt, int ch, mode = 2; /* ndigits significant digits */ } - if (value < 0) { - value = -value; - *sign = '-'; - } else - *sign = '\000'; - digits = __dtoa(value, mode, ndigits, decpt, &dsgn, &rve); + digits = __dtoa(value, mode, ndigits, decpt, sign, &rve); if ((ch != 'g' && ch != 'G') || flags & ALT) {/* Print trailing zeros */ bp = digits + ndigits; if (ch == 'f') { |