diff options
| author | 2011-10-07 13:28:18 -0700 | |
|---|---|---|
| committer | 2011-10-07 13:28:18 -0700 | |
| commit | de27227026e01c26a9debef77e4e268f242e713e (patch) | |
| tree | 267a1bbe60b4a1a5f5955e55517dce699c8c9e0f /libs/utils/Unicode.cpp | |
| parent | cc0bf53f214d8c9029ce27ac3985dc5c18d5130a (diff) | |
Fix regression in CursorWindow.copyStingToBuffer.
Bug: 5332296
Change-Id: Iff9eed786f0a8293b6156f883a66a322ddad5e99
Diffstat (limited to 'libs/utils/Unicode.cpp')
| -rw-r--r-- | libs/utils/Unicode.cpp | 13 | 
1 files changed, 7 insertions, 6 deletions
| diff --git a/libs/utils/Unicode.cpp b/libs/utils/Unicode.cpp index 78c61b4fc6..41cbf035e5 100644 --- a/libs/utils/Unicode.cpp +++ b/libs/utils/Unicode.cpp @@ -542,11 +542,7 @@ ssize_t utf8_to_utf16_length(const uint8_t* u8str, size_t u8len)      return u16measuredLen;  } -/** - * Convert a UTF-8 string to UTF-16. The destination UTF-16 buffer must have - * space for NULL at the end. - */ -void utf8_to_utf16(const uint8_t* u8str, size_t u8len, char16_t* u16str) +char16_t* utf8_to_utf16_no_null_terminator(const uint8_t* u8str, size_t u8len, char16_t* u16str)  {      const uint8_t* const u8end = u8str + u8len;      const uint8_t* u8cur = u8str; @@ -569,7 +565,12 @@ void utf8_to_utf16(const uint8_t* u8str, size_t u8len, char16_t* u16str)          u8cur += u8len;      } -    *u16cur = 0; +    return u16cur; +} + +void utf8_to_utf16(const uint8_t* u8str, size_t u8len, char16_t* u16str) { +    char16_t* end = utf8_to_utf16_no_null_terminator(u8str, u8len, u16str); +    *end = 0;  }  } |