The main purpose of luit is to allow "legacy" applications that use character sets other than UTF-8 to work with contemporary terminal emulators.
luit may be required today when connecting to a "legacy" host that only supports an older encoding, such as ISO 8859-1. For example, instead of running "ssh legacy-machine", a user may have to run "LC_ALL=fr_FRluitsshlegacy-machine" to properly render French accented characters on a UTF-8 terminal.[2]
luit is also used to properly render the output of applications that use ISO 2022 character set switching. ISO 2022 is an older standard[3] that allowed an application to "switch" between different fonts, e.g., to mix line-drawing characters with text or to display text in multiple languages and character sets. UTF-8 itself does not support switching fonts; the encoding is stateless and gives each unique character (including line-drawing characters) its own numerical encoding. It can be used to translate between these two encodings.
Examples of programs that require translation to run correctly on a UTF-8 terminal include earlier versions of emacs/MULE,[4] and programs that use ISO 2022 shift sequences in ANSI escape codes that switch to an alternate character set in order to draw line-drawing characters.
luit is invoked automatically by xterm when necessary to translate program output into UTF-8,[5] for programs running on a local computer. When connecting remotely to another computer, the user must run luit directly.
luit interprets application output according to the locale's character set with ISO 2022 shifts and ECMA-48 escape sequences. If an application is speaking a different language than the locale's character set (one that may have matched the terminal emulator's expectations in the absence of luit), luit can misinterpret the application's output and produce corrupted output to the terminal.[6]
History
luit was written in 2001 by Juliusz Chroboczek,[4] when major Linuxdistributions began migrating to the Unicode character set from "legacy" encodings such as ISO 8859-1.[3] It has since become a widely installed base utility, present on more than half of all Linux computer systems by some estimates.[7][8] It is also part of IBM's AIX.[9]
Implementations
There are two versions of luit: one maintained by Thomas Dickey[5] as part of xterm, and another formerly updated by Freedesktop.org.[10][11] Some Linux distributions ship the latter version[12] as part of their X11 utilities package. However, while migrating to GitLab, the latter fork was discontinued because it was unmaintained.[13]