From: jhurst Date: Mon, 28 Jan 2019 08:56:13 +0000 (+0100) Subject: o Moved to re-entrant forms of wcrtomb() and mbrtowc() X-Git-Tag: rel_2_10_32~11 X-Git-Url: https://git.carlh.net/gitweb/?p=asdcplib.git;a=commitdiff_plain;h=6e07e413f784e870a78b77767f9546eaf8d20935 o Moved to re-entrant forms of wcrtomb() and mbrtowc() --- diff --git a/.gitignore b/.gitignore index dabec24..8aed0cc 100644 --- a/.gitignore +++ b/.gitignore @@ -68,3 +68,5 @@ src/kmrandgen src/kmuuidgen src/pinkwave src/wavesplit +src/phdr-unwrap +src/phdr-wrap diff --git a/src/MXFTypes.cpp b/src/MXFTypes.cpp index eda0783..a98a4d2 100755 --- a/src/MXFTypes.cpp +++ b/src/MXFTypes.cpp @@ -279,11 +279,14 @@ ASDCP::MXF::UTF16String::Unarchive(Kumu::MemIOReader* Reader) erase(); const ui16_t* p = (ui16_t*)Reader->CurrentData(); ui32_t length = Reader->Remainder() / 2; - char mb_buf[MB_LEN_MAX+1]; + char mb_buf[MB_LEN_MAX]; + + mbstate_t ps; + memset(&ps, 0, sizeof(mbstate_t)); for ( ui32_t i = 0; i < length; i++ ) { - int count = wctomb(mb_buf, KM_i16_BE(p[i])); + int count = wcrtomb(mb_buf, KM_i16_BE(p[i]), &ps); if ( count == -1 ) { @@ -316,9 +319,12 @@ ASDCP::MXF::UTF16String::Archive(Kumu::MemIOWriter* Writer) const ui32_t length = size(); ui32_t i = 0; + mbstate_t ps; + memset(&ps, 0, sizeof(mbstate_t)); + while ( i < length ) { - int count = mbtowc(&wcp, mbp+i, remainder); + int count = mbrtowc(&wcp, mbp+i, remainder, &ps); if ( count == -1 ) {