From 6e07e413f784e870a78b77767f9546eaf8d20935 Mon Sep 17 00:00:00 2001 From: jhurst Date: Mon, 28 Jan 2019 09:56:13 +0100 Subject: o Moved to re-entrant forms of wcrtomb() and mbrtowc() --- src/MXFTypes.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'src/MXFTypes.cpp') 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 ) { -- cgit v1.2.3