In the current read scheme for Openfire, it is possible that due to variable width encoding that we sometimes only create a string with a partial character.
This breaks the message text and causes encoding issues when read.
This change modifies the way the characters are read to use an bytearrayoutputstream and only do the string conversion once.
Since we only do the string creation once after the full buffer is read, we no longer have encoding issues with broken unicode characters.
In the current read scheme for Openfire, it is possible that due
to variable width encoding that we sometimes only create a
string with a partial character.
This breaks the message text and causes encoding issues when read.
This change modifies the way the characters are
read to use an bytearrayoutputstream and
only do the string conversion once.
Since we only do the string creation once after the full
buffer is read, we no longer have encoding
issues with broken unicode characters.
https://github.com/igniterealtime/Openfire/pull/535