mirror of
git://git.musl-libc.org/musl
synced 2024-12-12 09:45:45 +00:00
fix fwprintf missing output to open_wmemstream FILEs
open_wmemstream's write method was written assuming no buffering,
since it sets the FILE up with buf_len of zero in order to avoid
issues with position/seeking. however, as a consequence of commit
bd57e2b43a
, a FILE being written to by
the printf core has a temporary local buffer for the duration of the
operation if it was unbuffered to begin with. since this was
disregarded by the wide memstream's write method, output produced
through this code path, particularly numeric fields, was missing from
the output wchar buffer.
copy the equivalent logic for using the buffered data from the
byte-oriented open_memstream.
This commit is contained in:
parent
a636fd630f
commit
25085c85a0
@ -40,8 +40,12 @@ fail:
|
||||
static size_t wms_write(FILE *f, const unsigned char *buf, size_t len)
|
||||
{
|
||||
struct cookie *c = f->cookie;
|
||||
size_t len2;
|
||||
size_t len2 = f->wpos - f->wbase;
|
||||
wchar_t *newbuf;
|
||||
if (len2) {
|
||||
f->wpos = f->wbase;
|
||||
if (wms_write(f, f->wbase, len2) < len2) return 0;
|
||||
}
|
||||
if (len + c->pos >= c->space) {
|
||||
len2 = 2*c->space+1 | c->pos+len+1;
|
||||
if (len2 > SSIZE_MAX/4) return 0;
|
||||
|
Loading…
Reference in New Issue
Block a user