Private Use Areas
In Unicode, a Private Use Area is a range of code points that, by definition, will not be assigned characters by the Unicode Consortium. Three private use areas are defined: one in the Basic Multilingual Plane, and one each in, and nearly covering, planes 15 and 16. The code points in these areas cannot be considered as standardized characters in Unicode itself. They are intentionally left undefined so that third parties may define their own characters without conflicting with Unicode Consortium assignments. Under the Unicode Stability Policy, the Private Use Areas will remain allocated for that purpose in all future Unicode versions.
Assignments to Private Use Area characters need not be "private" in the sense of strictly internal to an organisation; a number of assignment schemes have been published by several organisations. Such publication may include a font that supports the definition, and software making use of the private-use characters. By definition, multiple private parties may assign different characters to the same code point, with the consequence that a user may see one private character from an installed font where a different one was intended.
Definition
Under the Unicode definition, code points in the Private Use Areas are assigned characters—they are not noncharacters, reserved, or unassigned. Their category is "Other, private use
", and no character names are specified. No representative glyphs are provided, and character semantics are left to private agreement. Private-use characters are assigned Unicode code points whose interpretation is not specified by this standard and whose use may be determined by private agreement among cooperating users. These characters are designated for private use and do not have defined, interpretable semantics except by private agreement.
No charts are provided for private-use characters, as any such characters are, by their very nature, defined only outside the context of this standard.
Assignment
In the Basic Multilingual Plane, the block titled Private Use Area has 6400 code points. Planes 15 and 16 are almost entirely assigned to two further Private Use Areas, Supplementary Private Use Area-A and Supplementary Private Use Area-B respectively.In order to encode characters from planes 15 and 16 in UTF-16, a further block of the BMP is assigned to High Private Use Surrogates.
Usage
Standardization initiative uses
Many people and institutions have created character collections for the PUA. Some of these private use agreements are published, so other PUA implementers can aim for unused or less used code points to prevent overlaps. Several characters and scripts previously encoded in private use agreements have actually been fully encoded in Unicode, necessitating mappings from the PUA to other Unicode code points.One of the more well-known and broadly implemented PUA agreements is maintained by the ConScript Unicode Registry. The CSUR, which is not officially endorsed or associated with the Unicode Consortium, provides a mapping for constructed scripts, such as Klingon pIqaD and Ferengi script, Tengwar and Cirth, Alexander Melville Bell's Visible Speech, and Dr. Seuss' alphabet from On Beyond Zebra. The CSUR previously encoded the undeciphered Phaistos characters, as well as the Shavian and Deseret alphabets, which have all been accepted for official encoding in Unicode.
Another common PUA agreement is maintained by the Medieval Unicode Font Initiative. This project is attempting to support all of the scribal abbreviations, ligatures, precomposed characters, symbols, and alternate letterforms found in medieval texts written in the Latin alphabet. The express purpose of MUFI is to experimentally determine which characters are necessary to represent these texts, and to have those characters officially encoded in Unicode. As of Unicode version 5.1, 152 MUFI characters have been incorporated into the official Unicode encoding.
Some agreed-upon PUA character collections exist in part or whole because Unicode Consortium is in no hurry to encode them. Some, such as unrepresented languages, are likely to end up encoded in the future. Some unusual cases such as fictional languages are outside the usual scope of Unicode but not explicitly ruled out by the principles of Unicode, and may show up eventually. In other cases, the proposed encoding violates one or more Unicode principles and hence is unlikely to ever be officially recognized by Unicode—mostly where users want to directly encode alternate forms, ligatures, or base-character-plus-diacritic combinations.
Publishing organisation | Topic | PUA area used | Font |
CSUR | Artificial scripts | PUA and Plane 15 | Code2000 |
MUFI | Medieval scripts | PUA | several |
SIL | Phonetics and languages | PUA | |
TITUS | Ancient and medieval scripts | PUA | TITUS Cyberbit Basic |
- Emoji is an encoding for picture characters or emoticons used in Japanese wireless messages and webpages. With Unicode 6.0 and later, many of these have been encoded in the block Miscellaneous Symbols And Pictographs and elsewhere in the SMP.
- GB/T 20542-2006 and GB/T 22238-2008 are Chinese national standards that use the PUA to encode precomposed Tibetan ligatures.
- GB 18030 and GBK use the PUA to provisionally encode characters not found in Unicode standards.
- The Institute of the Estonian Language uses the PUA to encode Latin and Cyrillic precomposed characters that have no Unicode encoding.
- The uses a different mapping from the ConScript Unicode Registry that largely follows Michael Everson’s 2001-03-07 Tengwar discussion paper, but diverges in some details.
- The MARC 21 standard uses the PUA to encode East Asian characters present in MARC-8 that have no Unicode encoding.
- The SIL Corporate PUA uses the PUA to encode characters used in minority languages that have not yet been accepted into Unicode.
- The STIX Fonts project uses the PUA to provide a comprehensive font set of mathematical symbols and alphabets, many of which are also available in the SMP now, e.g. in the Mathematical Alphanumeric Symbols block.
- The Tamil Unicode New Encoding is a proposed scheme for encoding Tamil that overcomes perceived deficiencies in the current Unicode encoding.
Vendor use
- The Adobe Glyph List used to use the PUA for some of its glyphs.
- Apple lists a range of 1,280 characters in its developer documentation of U+F400–U+F8FF within the PUA for Apple’s use. Of those, only 311 are used in the range U+F700–U+F8FF and Apple ).
- * One of these is U+F8FF the Apple logo generally supported by Apple's 8-bit sets.
- WGL4 uses the PUA to encode duplicates of the ligatures fi fl.
- Microsoft's defunct Services For Macintosh feature used U+F001 through U+F029 as replacements for special characters allowed in HFS but forbidden in NTFS, and U+F02A for the Apple logo.
- In old versions of its RichEdit component, Microsoft mapped U+F020–U+F0FF within the PUA to symbol fonts. For any character in this range, RichEdit would show a character from a symbol font instead of the end-user-defined character
- uses U+F8FC–U+F8FE for ⌀, ± and ° respectively.
- Some fonts place Windows logo key at
U+F000
. - Number
U+F000
is a numeral succession starting at 13 or 18 in some video games like Agar.io. - On Ubuntu,
U+E0FF
is displayed as the "Circle Of Friends" logo andU+F200
is "ubuntu" in the Ubuntu with a superscripted "Circle Of Friends". - The font includes the Debian logo at
U+F100
- In the Linux Libertine font,
U+E000
displays Tux, the mascot of Linux - The Font Awesome icon font utilizes the PUA to display various glyphs.
- Powerline, a status line plugin for vim, use U+E0A0–U+E0A2 and U+E0B0–U+E0B3 for extra box-drawing characters.
- On the Fira Sans typeface used in Firefox OS,
U+E003
is displayed as the Mozilla logo. - Lotus Multi-Byte Character Set, the encoding and character set internally used by Lotus/IBM Lotus 1-2-3, Symphony, SmartSuite, Notes, Domino as well as a number of third-party products such as Microsoft Works, uses some characters in the Private Use Area for symbols not defined in Unicode. Of these,
U+F8FB
is known to be reserved for a crown currency symbol, andU+F8FC
andU+F8FD
were later mapped toU+FB02
andU+FB01
respectively. Additionally, when UTF-16 codes are embedded in LMBCS, the UTF-16 codes corresponding toU+F601
throughU+F6FF
are substituted for UTF-16 codes which would contain null bytes, since LMBCS is designed to not contain embedded null bytes. - IBM reserved several code page IDs for PUA code pages: Code page 1445, code page 1446, code page 1447, code page 1449.
Unicode PUA blocks
Private-use characters in other character sets
The concept of reserving specific code points for Private Use is based on similar earlier usage in other character sets. In particular, many otherwise obsolete characters in East Asian scripts continue to be used in specific names or other situations, and so some character sets for those scripts made allowance for private-use characters. The Unicode standard references these uses under the name "End User Character Definition".Additionally, the C1 control block contains two codes intended for private use "control functions" by ECMA-48: 0x91 and 0x92 . Unicode includes these at and but defines them as control characters, not private-use characters.
Encodings which do not have private use areas but have more or less unused areas, such as ISO/IEC 8859 and Shift JIS, have seen uncontrolled variants of these encodings evolve. For Unicode, software companies can use the Private Use Areas for their desired additions.