fix incorrect end pointer in some cases when wcsrtombs stops early
authorRich Felker <dalias@aerifal.cx>
Mon, 2 Jun 2014 20:21:47 +0000 (16:21 -0400)
committerRich Felker <dalias@aerifal.cx>
Mon, 2 Jun 2014 20:21:47 +0000 (16:21 -0400)
commit8fba4458afb7304b32ca887e4a3990c6029131f9
tree26b883a992a8bc2a8617fc76cb298c7819f19c7a
parent76f440cff73878a7359e944618a7722dfd23bdec
fix incorrect end pointer in some cases when wcsrtombs stops early

when wcsrtombs stopped due to hitting zero remaining space in the
output buffer, it was wrongly clearing the position pointer as if it
had completed the conversion successfully.

this commit rearranges the code somewhat to make a clear separation
between the cases of ending due to running out of output buffer space,
and ending due to reaching the end of input or an illegal sequence in
the input. the new branches have been arranged with the hope of
optimizing more common cases, too.
src/multibyte/wcsrtombs.c