diff options
author | rubidium <rubidium@openttd.org> | 2007-12-11 21:25:48 +0000 |
---|---|---|
committer | rubidium <rubidium@openttd.org> | 2007-12-11 21:25:48 +0000 |
commit | ad022c535c438d8966db0c2f4949b5c5df9d7261 (patch) | |
tree | 5fc20d4a9bf4fa33d1b67ba1c06c10f70990d9bb | |
parent | 745da6563f8b9ad21530110c91b6a8ee3d68aa5c (diff) | |
download | openttd-ad022c535c438d8966db0c2f4949b5c5df9d7261.tar.xz |
(svn r11622) -Codechange: support the unicode version of the 'control' characters.
-rw-r--r-- | src/newgrf_text.cpp | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/src/newgrf_text.cpp b/src/newgrf_text.cpp index dac8300fd..1de167266 100644 --- a/src/newgrf_text.cpp +++ b/src/newgrf_text.cpp @@ -207,9 +207,13 @@ char *TranslateTTDPatchCodes(const char *str) } for (;;) { - const char *tmp = str; // Used for UTF-8 decoding - - c = (byte)*str++; + if (unicode && Utf8EncodedCharLen(*str) != 0) { + c = Utf8Consume(&str); + /* 'Magic' range of control codes. */ + if (GB(c, 8, 8) == 0xE0) c = GB(c, 0, 8); + } else { + c = (byte)*str++; + } if (c == 0) break; switch (c) { @@ -290,12 +294,6 @@ char *TranslateTTDPatchCodes(const char *str) case 0xB7: d += Utf8Encode(d, SCC_PLANE); break; case 0xB8: d += Utf8Encode(d, SCC_SHIP); break; default: - if (unicode) { - d += Utf8Encode(d, Utf8Consume(&tmp)); - str = tmp; - break; - } - /* Validate any unhandled character */ if (!IsValidChar(c, CS_ALPHANUMERAL)) c = '?'; d += Utf8Encode(d, c); |