A bidirectional text contains two
text direction
A writing system comprises a set of symbols, called a ''script'', as well as the rules by which the script represents a particular language. The earliest writing appeared during the late 4th millennium BC. Throughout history, each independen ...
alities,
right-to-left
A writing system comprises a set of symbols, called a ''script'', as well as the rules by which the script represents a particular language. The earliest writing appeared during the late 4th millennium BC. Throughout history, each independen ...
(RTL) and
left-to-right (LTR). It generally involves text containing different types of
alphabet
An alphabet is a standard set of letter (alphabet), letters written to represent particular sounds in a spoken language. Specifically, letters largely correspond to phonemes as the smallest sound segments that can distinguish one word from a ...
s, but may also refer to
boustrophedon
Boustrophedon () is a style of writing in which alternate lines of writing are reversed, with letters also written in reverse, mirror-style. This is in contrast to modern European languages, where lines always begin on the same side, usually the l ...
, which is changing text direction in each row.
An example is the RTL Hebrew name Sarah: , spelled sin (ש) on the right, resh (ר) in the middle, and heh (ה) on the left. Many computer programs failed to display this correctly, because they were designed to display text in one direction only.
Some so-called
right-to-left scripts such as the
Persian script
Persian may refer to:
* People and things from Iran, historically called ''Persia'' in the English language
** Persians, the majority ethnic group in Iran, not to be conflated with the Iranic peoples
** Persian language, an Iranian language of the ...
and Arabic are mostly, but not exclusively, right-to-left—mathematical expressions, numeric dates and numbers bearing units are embedded from left to right. That also happens if text from a left-to-right language such as English is embedded in them; or vice versa, if Arabic is embedded in a left-to-right script such as English.
Bidirectional script support
Bidirectional script support is the capability of a
computer
A computer is a machine that can be Computer programming, programmed to automatically Execution (computing), carry out sequences of arithmetic or logical operations (''computation''). Modern digital electronic computers can perform generic set ...
system to correctly display bidirectional text. The term is often shortened to "BiDi" or "bidi".
Early computer installations were designed only to support a single
writing system
A writing system comprises a set of symbols, called a ''script'', as well as the rules by which the script represents a particular language. The earliest writing appeared during the late 4th millennium BC. Throughout history, each independen ...
, typically for left-to-right scripts based on the
Latin alphabet
The Latin alphabet, also known as the Roman alphabet, is the collection of letters originally used by the Ancient Rome, ancient Romans to write the Latin language. Largely unaltered except several letters splitting—i.e. from , and from � ...
only. Adding new
character set
Character encoding is the process of assigning numbers to graphical characters, especially the written characters of human language, allowing them to be stored, transmitted, and transformed using computers. The numerical values that make up a c ...
s and
character encoding
Character encoding is the process of assigning numbers to graphical character (computing), characters, especially the written characters of human language, allowing them to be stored, transmitted, and transformed using computers. The numerical v ...
s enabled a number of other left-to-right scripts to be supported, but did not easily support right-to-left scripts such as
Arabic
Arabic (, , or , ) is a Central Semitic languages, Central Semitic language of the Afroasiatic languages, Afroasiatic language family spoken primarily in the Arab world. The International Organization for Standardization (ISO) assigns lang ...
or
Hebrew
Hebrew (; ''ʿÎbrit'') is a Northwest Semitic languages, Northwest Semitic language within the Afroasiatic languages, Afroasiatic language family. A regional dialect of the Canaanite languages, it was natively spoken by the Israelites and ...
, and mixing the two was not practical. Right-to-left scripts were introduced through encodings like
ISO/IEC 8859-6 and
ISO/IEC 8859-8, storing the letters (usually) in writing and reading order. It is possible to simply flip the left-to-right display order to a right-to-left display order, but doing this sacrifices the ability to correctly display left-to-right scripts. With bidirectional script support, it is possible to mix characters from different scripts on the same page, regardless of writing direction.
In particular, the
Unicode
Unicode or ''The Unicode Standard'' or TUS is a character encoding standard maintained by the Unicode Consortium designed to support the use of text in all of the world's writing systems that can be digitized. Version 16.0 defines 154,998 Char ...
standard provides foundations for complete BiDi support, with detailed rules as to how mixtures of left-to-right and right-to-left scripts are to be encoded and displayed.
Unicode bidi support
The Unicode standard calls for characters to be ordered 'logically', i.e. in the sequence they are intended to be interpreted, as opposed to 'visually', the sequence they appear. This distinction is relevant for bidi support because at any bidi transition, the visual presentation ceases to be the 'logical' one. Thus, in order to offer bidi support, Unicode prescribes an algorithm for how to convert the logical sequence of characters into the correct visual presentation. For this purpose, the Unicode encoding standard divides all its characters into one of four types: 'strong', 'weak', 'neutral', and 'explicit formatting'.
Strong characters
Strong characters are those with a definite direction. Examples of this type of character include most alphabetic characters, syllabic characters, Han ideographs, non-European or non-Arabic digits, and punctuation characters that are specific to only those scripts.
Weak characters
Weak characters are those with vague direction. Examples of this type of character include European digits, Eastern Arabic-Indic digits, arithmetic symbols, and currency symbols.
Neutral characters
Neutral characters have direction indeterminable without context. Examples include paragraph separators, tabs, and most other whitespace characters. Punctuation symbols that are common to many scripts, such as the colon, comma, full-stop, and the no-break-space also fall within this category.
Explicit formatting
Explicit formatting characters, also referred to as "directional formatting characters", are special Unicode sequences that direct the algorithm to modify its default behavior. These characters are subdivided into "marks", "embeddings", "isolates", and "overrides". Their effects continue until the occurrence of either a paragraph separator, or a "pop" character.
Marks
If a "weak" character is followed by another "weak" character, the algorithm will look at the first neighbouring "strong" character. Sometimes this leads to unintentional display errors. These errors are corrected or prevented with "pseudo-strong" characters. Such
Unicode control characters
Many Unicode characters are used to control the interpretation or display of text, but these characters themselves have no visual or spatial representation. For example, the null character ( ) is used in C-programming application environment ...
are called ''marks''. The mark ( or ) is to be inserted into a location to make an enclosed weak character inherit its writing direction.
For example, to correctly display the for an English name brand (LTR) in an Arabic (RTL) passage, an LRM mark is inserted after the trademark symbol if the symbol is not followed by LTR text (e.g. ""). If the LRM mark is not added, the weak character ™ will be neighbored by a strong LTR character and a strong RTL character. Hence, in an RTL context, it will be considered to be RTL, and displayed in an incorrect order (e.g. "").
Embeddings
The "embedding" directional formatting characters are the classical Unicode method of explicit formatting, and as of Unicode 6.3, are being discouraged in favor of "isolates". An "embedding" signals that a piece of text is to be treated as directionally distinct. The text within the scope of the embedding formatting characters is not independent of the surrounding text. Also, characters within an embedding can affect the ordering of characters outside. Unicode 6.3 recognized that directional embeddings usually have too strong an effect on their surroundings and are thus unnecessarily difficult to use.
Isolates
The "isolate" directional formatting characters signal that a piece of text is to be treated as directionally isolated from its surroundings. As of Unicode 6.3, these are the formatting characters that are being encouraged in new documents – once target platforms are known to support them. These formatting characters were introduced after it became apparent that directional embeddings usually have too strong an effect on their surroundings and are thus unnecessarily difficult to use. Unlike the legacy 'embedding' directional formatting characters, 'isolate' characters have no effect on the ordering of the text outside their scope. Isolates can be nested, and may be placed within embeddings and overrides.
Overrides
The "override" directional formatting characters allow for special cases, such as for part numbers (e.g. to force a part number made of mixed English, digits and Hebrew letters to be written from right to left), and are recommended to be avoided wherever possible. As is true of the other directional formatting characters, "overrides" can be nested one inside another, and in embeddings and isolates.
= Using Unicode to override
=
Using will switch the text direction from left-to-right to right-to-left. Similarly, using will switch the text direction from right-to-left to left-to-right. Refer to th
Unicode Bidirectional Algorithm
Pops
The "pop" directional formatting character, encoded at , terminates the scope of the most recent "embedding", "override", or "isolate".
Runs
In the algorithm, each sequence of concatenated strong characters is called a "run". A "weak" character that is located between two "strong" characters with the same orientation will inherit their orientation. A "weak" character that is located between two "strong" characters with a different writing direction will inherit the main context's writing direction (in an LTR document the character will become LTR, in an RTL document, it will become RTL).
Table of possible BiDi character types
Security
Unicode bidirectional characters are used in the
Trojan Source vulnerability.
Visual Studio Code
Visual Studio Code, commonly referred to as VS Code, is an integrated development environment developed by Microsoft for Windows, Linux, macOS and web browsers. Features include support for debugging, syntax highlighting, intelligent code comp ...
highlights BiDi control characters since version 1.62 released in October 2021.
Visual Studio highlights BiDi control characters since version 17.0.3 released on December 14, 2021.
Scripts using bidirectional text
Egyptian hieroglyphs
Egyptian hieroglyphs were written bidirectionally, where the signs that had a distinct "head" or "tail" faced the beginning of the line.
Chinese characters and other CJK scripts
Chinese characters
Chinese characters are logographs used Written Chinese, to write the Chinese languages and others from regions historically influenced by Chinese culture. Of the four independently invented writing systems accepted by scholars, they represe ...
can be written in either direction as well as vertically (top to bottom then right to left), especially in signs (such as plaques), but the orientation of the individual characters does not change. This can often be seen on tour buses in China, where the company name customarily runs from the front of the vehicle to its rear — that is, from right to left on the right side of the bus, and from left to right on the left side of the bus. English texts on the right side of the vehicle are also quite commonly written in reverse order. (See pictures of tour bus and post vehicle below.)
Likewise, other
CJK scripts made up of the same square characters, such as the
Japanese writing system
The modern Japanese writing system uses a combination of Logogram, logographic kanji, which are adopted Chinese characters, and Syllabary, syllabic kana. Kana itself consists of a pair of syllabary, syllabaries: hiragana, used primarily for n ...
and
Korean writing system
Korean is the native language for about 81 million people, mostly of Korean descent. It is the national language of both South Korea and North Korea. In the south, the language is known as () and in the north, it is known as (). Since the tu ...
, can also be written in any direction, although horizontally left-to-right, top-to-bottom and vertically top-to-bottom right-to-left are the two most common forms.
Image:Yangzhou-tour-bus--right-side-3182.jpg, The right side (text runs from right to left, including the English text)
Image:Yangzhou-tour-bus--leftt-side-3184.jpg, The left side (text runs from left to right)
Image:Hainan Airlines - Boeing 737-86N.jpg, On the right side of this Hainan Airlines
Hainan Airlines is an airline headquartered in Haikou, Hainan, China. It is the largest civilian-run enterprise, civilian-run and majority State ownership, state-owned air transport company, making it the fourth-largest airline in terms of flee ...
aircraft, the text runs from right to left ().
Image:Hainan Airlines.JPG, The left side of this Hainan Airlines aircraft, however, shows the text running from left to right ().
File:VM 5485 China Post Office car at Zhengzhou Train Station.jpg, A photo that shows text on both sides of a China Post vehicle. On the right door, appears as .
Boustrophedon
Boustrophedon
Boustrophedon () is a style of writing in which alternate lines of writing are reversed, with letters also written in reverse, mirror-style. This is in contrast to modern European languages, where lines always begin on the same side, usually the l ...
is a writing style found in ancient
Greek inscriptions, in
Old Sabaic (an
Old South Arabian language) and in
Hungarian runes. This method of writing alternates direction, and usually reverses the individual characters, on each successive line.
Moon type
Moon type is an embossed adaptation of the Latin alphabet invented as a
tactile alphabet for the blind.
Initially the text changed direction (but not character orientation) at the end of the lines.
Special embossed lines connected the end of a line and the beginning of the next.
Moon Type for the Blind
', Ramseyer Bible Collection, Kathryn A. Martin Library, University of Minnesota Duluth.
Around 1990, it changed to a
left-to-right orientation.
See also
*
Internationalization and localization
In computing, internationalization and localization (American English, American) or internationalisation and localisation (British English, British), often abbreviated i18n and l10n respectively, are means of adapting to different languages, regi ...
*
Horizontal and vertical writing in East Asian scripts
*
*
Cyrillic numerals
Cyrillic numerals are a numeral system derived from the Cyrillic script, developed in the First Bulgarian Empire in the late 10th century. It was used in the First Bulgarian Empire and by South Slavs, South and East Slavs, East Slavic peoples. ...
*
Right-to-left mark
*
Transformation of text
*
Boustrophedon
Boustrophedon () is a style of writing in which alternate lines of writing are reversed, with letters also written in reverse, mirror-style. This is in contrast to modern European languages, where lines always begin on the same side, usually the l ...
References
External links
Unicode Standards Annex #9The Bidirectional Algorithm
W3C guidelines on authoring techniques for bi-directional text- includes examples and good explanations
ICUInternational Components for Unicode
International Components for Unicode (ICU) is an open-source project of mature C/ C++ and Java libraries for Unicode support, software internationalization, and software globalization. ICU is widely portable to many operating systems and envir ...
contains an implementation of the bi-directional algorithm — along with other internationalization services
{{Unicode navigation
Character encoding
Unicode algorithms
Internationalization and localization
Writing direction