6/7/2026 at 12:11:39 AM
That was a long time ago.Traditionally, character's under Unix were encoded in a locale-specific manner: ISO 8859-1 in Western Europe, ISO 8859-2 in Eastern Europe, EUC-JP in Japan, etc. In the 1990s, there was a major push to get XFree86 (the ancestor of X.Org) to switch to locale-independent UTF-8, lead mainly by Markus Kuhn and Bruno Haible.
The link is to Markus Kuhn's web page, which appears to describe the UTF_8 software available around 1998 or so.
by jech
6/7/2026 at 1:48:23 AM
UTF-8 is not locale independent. You cannot correctly render multilingual UTF-8 text without also specifying its locale, and some transformations like uppercase/lowercase also depend on the locale.by sheept
6/7/2026 at 2:11:47 AM
Eg: some cjk characters render differently based on whether mainland China, Taiwan, or Japan. One example 骨 (from my old notes so tiny chance this example is incorrect)by sourcegrift
6/7/2026 at 9:34:24 AM
Yeah, 骨 is one but IMHO the best example is 返 -- it renders differently in every CJK locale.by cyphar
6/7/2026 at 2:37:04 AM
> You cannot correctly render multilingual UTF-8 text without also specifying its localeYou can render it pretty well, not perfect, but good enough to actually read it, as opposed to not being able to render it at all or rendering mojibake à la Кракозябры instead.
by Joker_vD
6/7/2026 at 3:43:57 AM
At least touching Unicode strings in wrong locales only mildly corrupts the strings. Plenty of Win32 apps would crash if the system locale is in UTF-8.by numpad0
6/7/2026 at 10:50:59 AM
UTF-8 is a character encoding and therefore it cannot serve as a locale. There is no UTF-8 language, punctuation, date and number formats…by throw1234567891
6/7/2026 at 11:47:27 AM
I mean, UTF-8 string handling is language (of the given bitstream, not necessarily the system) dependent, e.g. Turkish lowercase I, Chinese Hanzi vs Japanese Kanji at same codepoints, etc etc...by numpad0
6/7/2026 at 8:55:21 PM
> UTF-8 is not locale independent.The encoding itself is locale-independent. Some algorithms (rendering, casing, hyphenation etc.) depend on the locale.
This is unlike the older paradigm, where the encoding itself was dependent on the locale, making things like copy-paste between applications running in different locales problematic.
by jech