X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fstdio%2Fvfprintf.c;h=f19058d3c0cb04a97ca81c0befec93c838cab172;hb=77f15d108ee021d4dfbeebe793661131c4470d4d;hp=2245d1da5dedeed4eb698098c4faaf502b6c4597;hpb=f9569662c08d371b85c77f025dd5c6e00b4a4c8b;p=musl diff --git a/src/stdio/vfprintf.c b/src/stdio/vfprintf.c index 2245d1da..f19058d3 100644 --- a/src/stdio/vfprintf.c +++ b/src/stdio/vfprintf.c @@ -330,9 +330,10 @@ static int fmt_fp(FILE *f, long double y, int w, int p, int fl, int t) else if (i==i/2 && d+1==z) small=0x10p-1; else small=0x11p-1; if (pl && *prefix=='-') round*=-1, small*=-1; + *d -= x; /* Decide whether to round by probing round+small */ if (round+small != round) { - *d = *d - x + i; + *d = *d + i; while (*d > 999999999) { *d--=0; (*d)++; @@ -341,6 +342,7 @@ static int fmt_fp(FILE *f, long double y, int w, int p, int fl, int t) for (i=10, e=9*(r-a); *a>=i; i*=10, e++); } } + if (z>d+1) z=d+1; for (; !z[-1] && z>a; z--); } @@ -633,8 +635,8 @@ static int printf_core(FILE *f, const char *fmt, va_list *ap, union arg *nl_arg, int vfprintf(FILE *f, const char *fmt, va_list ap) { va_list ap2; - int nl_type[NL_ARGMAX] = {0}; - union arg nl_arg[NL_ARGMAX]; + int nl_type[NL_ARGMAX+1] = {0}; + union arg nl_arg[NL_ARGMAX+1]; unsigned char internal_buf[80], *saved_buf = 0; int ret;