1*ad30f8e7SGabor Kovesdan 2*ad30f8e7SGabor KovesdanTYPE ROWCOL 3*ad30f8e7SGabor KovesdanNAME UCS/ARABIC 4*ad30f8e7SGabor KovesdanSRC_ZONE 0x0000-0xFB02 5*ad30f8e7SGabor KovesdanOOB_MODE INVALID 6*ad30f8e7SGabor KovesdanDST_INVALID 0x100 7*ad30f8e7SGabor KovesdanDST_UNIT_BITS 16 8*ad30f8e7SGabor Kovesdan 9*ad30f8e7SGabor KovesdanBEGIN_MAP 10*ad30f8e7SGabor Kovesdan#======================================================================= 11*ad30f8e7SGabor Kovesdan# File name: ARABIC.TXT 12*ad30f8e7SGabor Kovesdan# 13*ad30f8e7SGabor Kovesdan# Contents: Map (external version) from Mac OS Arabic 14*ad30f8e7SGabor Kovesdan# character set to Unicode 2.1 and later. 15*ad30f8e7SGabor Kovesdan# 16*ad30f8e7SGabor Kovesdan# Copyright: (c) 1994-2002, 2005 by Apple Computer, Inc., all rights 17*ad30f8e7SGabor Kovesdan# reserved. 18*ad30f8e7SGabor Kovesdan# 19*ad30f8e7SGabor Kovesdan# Contact: charsets@apple.com 20*ad30f8e7SGabor Kovesdan# 21*ad30f8e7SGabor Kovesdan# Changes: 22*ad30f8e7SGabor Kovesdan# 23*ad30f8e7SGabor Kovesdan# c02 2005-Apr-04 Update header comments. Matches internal xml 24*ad30f8e7SGabor Kovesdan# <c1.2> and Text Encoding Converter 2.0. 25*ad30f8e7SGabor Kovesdan# b3,c1 2002-Dec-19 Add comments about character display and 26*ad30f8e7SGabor Kovesdan# direction overrides. Update URLs, notes. 27*ad30f8e7SGabor Kovesdan# Matches internal utom<b4>. 28*ad30f8e7SGabor Kovesdan# b02 1999-Sep-22 Update contact e-mail address. Matches 29*ad30f8e7SGabor Kovesdan# internal utom<b1>, ufrm<b1>, and Text 30*ad30f8e7SGabor Kovesdan# Encoding Converter version 1.5. 31*ad30f8e7SGabor Kovesdan# n10 1998-Feb-05 Show required Unicode character 32*ad30f8e7SGabor Kovesdan# directionality in a different way. Matches 33*ad30f8e7SGabor Kovesdan# internal utom<n4>, ufrm<n21>, and Text 34*ad30f8e7SGabor Kovesdan# Encoding Converter version 1.3. Update 35*ad30f8e7SGabor Kovesdan# header comments; include information on 36*ad30f8e7SGabor Kovesdan# loose mapping of digits. 37*ad30f8e7SGabor Kovesdan# n07 1997-Jul-17 Update to match internal utom<n2>, ufrm<n17>: 38*ad30f8e7SGabor Kovesdan# Change standard mapping for 0xC0 from U+066D 39*ad30f8e7SGabor Kovesdan# to U+274A. Add direction overrides to 40*ad30f8e7SGabor Kovesdan# mappings for 0x25, 0x2C, 0x3B, 0x3F. Add 41*ad30f8e7SGabor Kovesdan# information on variants. 42*ad30f8e7SGabor Kovesdan# n03 1995-Apr-18 First version (after fixing some typos). 43*ad30f8e7SGabor Kovesdan# Matches internal ufrm<n11>. 44*ad30f8e7SGabor Kovesdan# 45*ad30f8e7SGabor Kovesdan# Standard header: 46*ad30f8e7SGabor Kovesdan# ---------------- 47*ad30f8e7SGabor Kovesdan# 48*ad30f8e7SGabor Kovesdan# Apple, the Apple logo, and Macintosh are trademarks of Apple 49*ad30f8e7SGabor Kovesdan# Computer, Inc., registered in the United States and other countries. 50*ad30f8e7SGabor Kovesdan# Unicode is a trademark of Unicode Inc. For the sake of brevity, 51*ad30f8e7SGabor Kovesdan# throughout this document, "Macintosh" can be used to refer to 52*ad30f8e7SGabor Kovesdan# Macintosh computers and "Unicode" can be used to refer to the 53*ad30f8e7SGabor Kovesdan# Unicode standard. 54*ad30f8e7SGabor Kovesdan# 55*ad30f8e7SGabor Kovesdan# Apple Computer, Inc. ("Apple") makes no warranty or representation, 56*ad30f8e7SGabor Kovesdan# either express or implied, with respect to this document and the 57*ad30f8e7SGabor Kovesdan# included data, its quality, accuracy, or fitness for a particular 58*ad30f8e7SGabor Kovesdan# purpose. In no event will Apple be liable for direct, indirect, 59*ad30f8e7SGabor Kovesdan# special, incidental, or consequential damages resulting from any 60*ad30f8e7SGabor Kovesdan# defect or inaccuracy in this document or the included data. 61*ad30f8e7SGabor Kovesdan# 62*ad30f8e7SGabor Kovesdan# These mapping tables and character lists are subject to change. 63*ad30f8e7SGabor Kovesdan# The latest tables should be available from the following: 64*ad30f8e7SGabor Kovesdan# 65*ad30f8e7SGabor Kovesdan# <http://www.unicode.org/Public/MAPPINGS/VENDORS/APPLE/> 66*ad30f8e7SGabor Kovesdan# 67*ad30f8e7SGabor Kovesdan# For general information about Mac OS encodings and these mapping 68*ad30f8e7SGabor Kovesdan# tables, see the file "README.TXT". 69*ad30f8e7SGabor Kovesdan# 70*ad30f8e7SGabor Kovesdan# Format: 71*ad30f8e7SGabor Kovesdan# ------- 72*ad30f8e7SGabor Kovesdan# 73*ad30f8e7SGabor Kovesdan# Three tab-separated columns; 74*ad30f8e7SGabor Kovesdan# '#' begins a comment which continues to the end of the line. 75*ad30f8e7SGabor Kovesdan# Column #1 is the Mac OS Arabic code (in hex as 0xNN). 76*ad30f8e7SGabor Kovesdan# Column #2 is the corresponding Unicode (in hex as 0xNNNN), 77*ad30f8e7SGabor Kovesdan# possibly preceded by a tag indicating required directionality 78*ad30f8e7SGabor Kovesdan# (i.e. <LR>+0xNNNN or <RL>+0xNNNN). 79*ad30f8e7SGabor Kovesdan# Column #3 is a comment containing the Unicode name. 80*ad30f8e7SGabor Kovesdan# 81*ad30f8e7SGabor Kovesdan# The entries are in Mac OS Arabic code order. 82*ad30f8e7SGabor Kovesdan# 83*ad30f8e7SGabor Kovesdan# Control character mappings are not shown in this table, following 84*ad30f8e7SGabor Kovesdan# the conventions of the standard UTC mapping tables. However, the 85*ad30f8e7SGabor Kovesdan# Mac OS Arabic character set uses the standard control characters at 86*ad30f8e7SGabor Kovesdan# 0x00-0x1F and 0x7F. 87*ad30f8e7SGabor Kovesdan# 88*ad30f8e7SGabor Kovesdan# Notes on Mac OS Arabic: 89*ad30f8e7SGabor Kovesdan# ----------------------- 90*ad30f8e7SGabor Kovesdan# 91*ad30f8e7SGabor Kovesdan# This is a legacy Mac OS encoding; in the Mac OS X Carbon and Cocoa 92*ad30f8e7SGabor Kovesdan# environments, it is only supported via transcoding to and from 93*ad30f8e7SGabor Kovesdan# Unicode. 94*ad30f8e7SGabor Kovesdan# 95*ad30f8e7SGabor Kovesdan# 1. General 96*ad30f8e7SGabor Kovesdan# 97*ad30f8e7SGabor Kovesdan# The Mac OS Arabic character set is intended to cover Arabic as 98*ad30f8e7SGabor Kovesdan# used in North Africa, the Arabian peninsula, and the Levant. It 99*ad30f8e7SGabor Kovesdan# also contains several characters needed for Urdu and/or Farsi. 100*ad30f8e7SGabor Kovesdan# 101*ad30f8e7SGabor Kovesdan# The Mac OS Arabic character set is essentially a superset of ISO 102*ad30f8e7SGabor Kovesdan# 8859-6. The 8859-6 code points that are interpreted differently 103*ad30f8e7SGabor Kovesdan# in the Mac OS Arabic set are as follows: 104*ad30f8e7SGabor Kovesdan# 0xA0 is NO-BREAK SPACE in 8859-6 and right-left SPACE in Mac OS 105*ad30f8e7SGabor Kovesdan# Arabic; NO-BREAK is 0x81 in Mac OS Arabic. 106*ad30f8e7SGabor Kovesdan# 0xA4 is CURRENCY SIGN in 8859-6 and right-left DOLLAR SIGN in 107*ad30f8e7SGabor Kovesdan# Mac OS Arabic. 108*ad30f8e7SGabor Kovesdan# 0xAD is SOFT HYPHEN in 8859-6 and right-left HYPHEN-MINUS in 109*ad30f8e7SGabor Kovesdan# Mac OS Arabic. 110*ad30f8e7SGabor Kovesdan# ISO 8859-6 specifies that codes 0x30-0x39 can be rendered either 111*ad30f8e7SGabor Kovesdan# with European digit shapes or Arabic digit shapes. This is also 112*ad30f8e7SGabor Kovesdan# true in Mac OS Arabic, which determines from context which digit 113*ad30f8e7SGabor Kovesdan# shapes to use (see below). 114*ad30f8e7SGabor Kovesdan# 115*ad30f8e7SGabor Kovesdan# The Mac OS Arabic character set uses the C1 controls area and other 116*ad30f8e7SGabor Kovesdan# code points which are undefined in ISO 8859-6 for additional 117*ad30f8e7SGabor Kovesdan# graphic characters: additional Arabic letters for Farsi and Urdu, 118*ad30f8e7SGabor Kovesdan# some accented Roman letters for European languages (such as French), 119*ad30f8e7SGabor Kovesdan# and duplicates of some of the punctuation, symbols, and digits in 120*ad30f8e7SGabor Kovesdan# the ASCII block. The duplicate punctuation, symbol, and digit 121*ad30f8e7SGabor Kovesdan# characters have right-left directionality, while the ASCII versions 122*ad30f8e7SGabor Kovesdan# have left-right directionality. See the next section for more 123*ad30f8e7SGabor Kovesdan# information on this. 124*ad30f8e7SGabor Kovesdan# 125*ad30f8e7SGabor Kovesdan# Mac OS Arabic characters 0xEB-0xF2 are non-spacing/combining marks. 126*ad30f8e7SGabor Kovesdan# 127*ad30f8e7SGabor Kovesdan# 2. Directional characters and roundtrip fidelity 128*ad30f8e7SGabor Kovesdan# 129*ad30f8e7SGabor Kovesdan# The Mac OS Arabic character set was developed in 1986-1987. At that 130*ad30f8e7SGabor Kovesdan# time the bidirectional line layout algorithm used in the Mac OS 131*ad30f8e7SGabor Kovesdan# Arabic system was fairly simple; it used only a few direction 132*ad30f8e7SGabor Kovesdan# classes (instead of the 19 now used in the Unicode bidirectional 133*ad30f8e7SGabor Kovesdan# algorithm). In order to permit users to handle some tricky layout 134*ad30f8e7SGabor Kovesdan# problems, certain punctuation and symbol characters were encoded 135*ad30f8e7SGabor Kovesdan# twice, one with a left-right direction attribute and the other with 136*ad30f8e7SGabor Kovesdan# a right-left direction attribute. 137*ad30f8e7SGabor Kovesdan# 138*ad30f8e7SGabor Kovesdan# For example, plus sign is encoded at 0x2B with a left-right 139*ad30f8e7SGabor Kovesdan# attribute, and at 0xAB with a right-left attribute. However, there 140*ad30f8e7SGabor Kovesdan# is only one PLUS SIGN character in Unicode. This leads to some 141*ad30f8e7SGabor Kovesdan# interesting problems when mapping between Mac OS Arabic and Unicode; 142*ad30f8e7SGabor Kovesdan# see below. 143*ad30f8e7SGabor Kovesdan# 144*ad30f8e7SGabor Kovesdan# A related problem is that even when a particular character is 145*ad30f8e7SGabor Kovesdan# encoded only once in Mac OS Arabic, it may have a different 146*ad30f8e7SGabor Kovesdan# direction attribute than the corresponding Unicode character. 147*ad30f8e7SGabor Kovesdan# 148*ad30f8e7SGabor Kovesdan# For example, the Mac OS Arabic character at 0x93 is HORIZONTAL 149*ad30f8e7SGabor Kovesdan# ELLIPSIS with strong right-left direction. However, the Unicode 150*ad30f8e7SGabor Kovesdan# character HORIZONTAL ELLIPSIS has direction class neutral. 151*ad30f8e7SGabor Kovesdan# 152*ad30f8e7SGabor Kovesdan# 3. Behavior of ASCII-range numbers in WorldScript 153*ad30f8e7SGabor Kovesdan# 154*ad30f8e7SGabor Kovesdan# Mac OS Arabic also has two sets of digit codes. 155*ad30f8e7SGabor Kovesdan# 156*ad30f8e7SGabor Kovesdan# The digits at 0x30-0x39 may be displayed using either European 157*ad30f8e7SGabor Kovesdan# digit forms or Arabic digit forms, depending on context. If there 158*ad30f8e7SGabor Kovesdan# is a "strong European" character such as a Latin letter on either 159*ad30f8e7SGabor Kovesdan# side of a sequence consisting of digits 0x30-0x39 and possibly comma 160*ad30f8e7SGabor Kovesdan# 0x2C or period 0x2E, then the characters will be displayed using 161*ad30f8e7SGabor Kovesdan# European forms (This will happen even if there are neutral characters 162*ad30f8e7SGabor Kovesdan# between the digits and the strong European character). Otherwise, the 163*ad30f8e7SGabor Kovesdan# digits will be displayed using Arabic forms, the comma will be 164*ad30f8e7SGabor Kovesdan# displayed as Arabic thousands separator, and the period as Arabic 165*ad30f8e7SGabor Kovesdan# decimal separator. In any case, 0x2C, 0x2E, and 0x30-0x39 are always 166*ad30f8e7SGabor Kovesdan# left-right. 167*ad30f8e7SGabor Kovesdan# 168*ad30f8e7SGabor Kovesdan# The digits at 0xB0-0xB9 are always displayed using Arabic digit 169*ad30f8e7SGabor Kovesdan# shapes, and moreover, these digits always have strong right-left 170*ad30f8e7SGabor Kovesdan# directionality. These are mainly intended for special layout 171*ad30f8e7SGabor Kovesdan# purposes such as part numbers, etc. 172*ad30f8e7SGabor Kovesdan# 173*ad30f8e7SGabor Kovesdan# 4. Font variants 174*ad30f8e7SGabor Kovesdan# 175*ad30f8e7SGabor Kovesdan# The table in this file gives the Unicode mappings for the standard 176*ad30f8e7SGabor Kovesdan# Mac OS Arabic encoding. This encoding is supported by the Cairo font 177*ad30f8e7SGabor Kovesdan# (the system font for Arabic), and is the encoding supported by the 178*ad30f8e7SGabor Kovesdan# text processing utilities. However, the other Arabic fonts actually 179*ad30f8e7SGabor Kovesdan# implement slightly different encodings; this mainly affects the code 180*ad30f8e7SGabor Kovesdan# points 0xAA and 0xC0. For these code points the standard Mac OS 181*ad30f8e7SGabor Kovesdan# Arabic encoding has the following mappings: 182*ad30f8e7SGabor Kovesdan# 0xAA -> <RL>+0x002A ASTERISK, right-left 183*ad30f8e7SGabor Kovesdan# 0xC0 -> <RL>+0x274A EIGHT TEARDROP-SPOKED PROPELLER ASTERISK, 184*ad30f8e7SGabor Kovesdan# right-left 185*ad30f8e7SGabor Kovesdan# This mapping of 0xAA is consistent with the normal convention for 186*ad30f8e7SGabor Kovesdan# Mac OS Arabic and Hebrew that the right-left duplicates have codes 187*ad30f8e7SGabor Kovesdan# that are equal to the ASCII code of the left-right character plus 188*ad30f8e7SGabor Kovesdan# 0x80. However, in all of the other fonts, 0xAA is MULTIPLY SIGN, and 189*ad30f8e7SGabor Kovesdan# right-left ASTERISK may be at a different code point. The other 190*ad30f8e7SGabor Kovesdan# variants are described below. 191*ad30f8e7SGabor Kovesdan# 192*ad30f8e7SGabor Kovesdan# The TrueType variant is used for most of the Arabic TrueType fonts: 193*ad30f8e7SGabor Kovesdan# Baghdad, Geeza, Kufi, Nadeem. It differs from the standard variant 194*ad30f8e7SGabor Kovesdan# in the following way: 195*ad30f8e7SGabor Kovesdan# 0xAA -> <RL>+0x00D7 MULTIPLICATION SIGN, right-left 196*ad30f8e7SGabor Kovesdan# 0xC0 -> <RL>+0x002A ASTERISK, right-left 197*ad30f8e7SGabor Kovesdan# 198*ad30f8e7SGabor Kovesdan# The Thuluth variant is used for the Arabic Postscript-only fonts: 199*ad30f8e7SGabor Kovesdan# Thuluth and Thuluth bold. It differs from the standard variant in 200*ad30f8e7SGabor Kovesdan# the following way: 201*ad30f8e7SGabor Kovesdan# 0xAA -> <RL>+0x00D7 MULTIPLICATION SIGN, right-left 202*ad30f8e7SGabor Kovesdan# 0xC0 -> 0x066D ARABIC FIVE POINTED STAR 203*ad30f8e7SGabor Kovesdan# 204*ad30f8e7SGabor Kovesdan# The AlBayan variant is used for the Arabic TrueType font Al Bayan. 205*ad30f8e7SGabor Kovesdan# It differs from the standard variant in the following way: 206*ad30f8e7SGabor Kovesdan# 0x81 -> no mapping (glyph just has authorship information, etc.) 207*ad30f8e7SGabor Kovesdan# 0xA3 -> 0xFDFA ARABIC LIGATURE SALLALLAHOU ALAYHE WASALLAM 208*ad30f8e7SGabor Kovesdan# 0xA4 -> 0xFDF2 ARABIC LIGATURE ALLAH ISOLATED FORM 209*ad30f8e7SGabor Kovesdan# 0xAA -> <RL>+0x00D7 MULTIPLICATION SIGN, right-left 210*ad30f8e7SGabor Kovesdan# 0xDC -> <RL>+0x25CF BLACK CIRCLE, right-left 211*ad30f8e7SGabor Kovesdan# 0xFC -> <RL>+0x25A0 BLACK SQUARE, right-left 212*ad30f8e7SGabor Kovesdan# 213*ad30f8e7SGabor Kovesdan# Unicode mapping issues and notes: 214*ad30f8e7SGabor Kovesdan# --------------------------------- 215*ad30f8e7SGabor Kovesdan# 216*ad30f8e7SGabor Kovesdan# 1. Matching the direction of Mac OS Arabic characters 217*ad30f8e7SGabor Kovesdan# 218*ad30f8e7SGabor Kovesdan# When Mac OS Arabic encodes a character twice but with different 219*ad30f8e7SGabor Kovesdan# direction attributes for the two code points - as in the case of 220*ad30f8e7SGabor Kovesdan# plus sign mentioned above - we need a way to map both Mac OS Arabic 221*ad30f8e7SGabor Kovesdan# code points to Unicode and back again without loss of information. 222*ad30f8e7SGabor Kovesdan# With the plus sign, for example, mapping one of the Mac OS Arabic 223*ad30f8e7SGabor Kovesdan# characters to a code in the Unicode corporate use zone is 224*ad30f8e7SGabor Kovesdan# undesirable, since both of the plus sign characters are likely to 225*ad30f8e7SGabor Kovesdan# be used in text that is interchanged. 226*ad30f8e7SGabor Kovesdan# 227*ad30f8e7SGabor Kovesdan# The problem is solved with the use of direction override characters 228*ad30f8e7SGabor Kovesdan# and direction-dependent mappings. When mapping from Mac OS Arabic 229*ad30f8e7SGabor Kovesdan# to Unicode, we use direction overrides as necessary to force the 230*ad30f8e7SGabor Kovesdan# direction of the resulting Unicode characters. 231*ad30f8e7SGabor Kovesdan# 232*ad30f8e7SGabor Kovesdan# The required direction is indicated by a direction tag in the 233*ad30f8e7SGabor Kovesdan# mappings. A tag of <LR> means the corresponding Unicode character 234*ad30f8e7SGabor Kovesdan# must have a strong left-right context, and a tag of <RL> indicates 235*ad30f8e7SGabor Kovesdan# a right-left context. 236*ad30f8e7SGabor Kovesdan# 237*ad30f8e7SGabor Kovesdan# For example, the mapping of 0x2B is given as <LR>+0x002B; the 238*ad30f8e7SGabor Kovesdan# mapping of 0xAB is given as <RL>+0x002B. If we map an isolated 239*ad30f8e7SGabor Kovesdan# instance of 0x2B to Unicode, it should be mapped as follows (LRO 240*ad30f8e7SGabor Kovesdan# indicates LEFT-RIGHT OVERRIDE, PDF indicates POP DIRECTION 241*ad30f8e7SGabor Kovesdan# FORMATTING): 242*ad30f8e7SGabor Kovesdan# 243*ad30f8e7SGabor Kovesdan# 0x2B -> 0x202D (LRO) + 0x002B (PLUS SIGN) + 0x202C (PDF) 244*ad30f8e7SGabor Kovesdan# 245*ad30f8e7SGabor Kovesdan# When mapping several characters in a row that require direction 246*ad30f8e7SGabor Kovesdan# forcing, the overrides need only be used at the beginning and end. 247*ad30f8e7SGabor Kovesdan# For example: 248*ad30f8e7SGabor Kovesdan# 249*ad30f8e7SGabor Kovesdan# 0x24 0x20 0x28 0x29 -> 0x202D 0x0024 0x0020 0x0028 0x0029 0x202C 250*ad30f8e7SGabor Kovesdan# 251*ad30f8e7SGabor Kovesdan# If neutral characters that require direction forcing are already 252*ad30f8e7SGabor Kovesdan# between strong-direction characters with matching directionality, 253*ad30f8e7SGabor Kovesdan# then direction overrides need not be used. Direction overrides are 254*ad30f8e7SGabor Kovesdan# always needed to map the right-left digits at 0xB0-0xB9. 255*ad30f8e7SGabor Kovesdan# 256*ad30f8e7SGabor Kovesdan# When mapping from Unicode to Mac OS Arabic, the Unicode 257*ad30f8e7SGabor Kovesdan# bidirectional algorithm should be used to determine resolved 258*ad30f8e7SGabor Kovesdan# direction of the Unicode characters. The mapping from Unicode to 259*ad30f8e7SGabor Kovesdan# Mac OS Arabic can then be disambiguated by the use of the resolved 260*ad30f8e7SGabor Kovesdan# direction: 261*ad30f8e7SGabor Kovesdan# 262*ad30f8e7SGabor Kovesdan# Unicode 0x002B -> Mac OS Arabic 0x2B (if L) or 0xAB (if R) 263*ad30f8e7SGabor Kovesdan# 264*ad30f8e7SGabor Kovesdan# However, this also means the direction override characters should 265*ad30f8e7SGabor Kovesdan# be discarded when mapping from Unicode to Mac OS Arabic (after 266*ad30f8e7SGabor Kovesdan# they have been used to determine resolved direction), since the 267*ad30f8e7SGabor Kovesdan# direction override information is carried by the code point itself. 268*ad30f8e7SGabor Kovesdan# 269*ad30f8e7SGabor Kovesdan# Even when direction overrides are not needed for roundtrip 270*ad30f8e7SGabor Kovesdan# fidelity, they are sometimes used when mapping Mac OS Arabic 271*ad30f8e7SGabor Kovesdan# characters to Unicode in order to achieve similar text layout with 272*ad30f8e7SGabor Kovesdan# the resulting Unicode text. For example, the single Mac OS Arabic 273*ad30f8e7SGabor Kovesdan# ellipsis character has direction class right-left,and there is no 274*ad30f8e7SGabor Kovesdan# left-right version. However, the Unicode HORIZONTAL ELLIPSIS 275*ad30f8e7SGabor Kovesdan# character has direction class neutral (which means it may end up 276*ad30f8e7SGabor Kovesdan# with a resolved direction of left-right if surrounded by left-right 277*ad30f8e7SGabor Kovesdan# characters). When mapping the Mac OS Arabic ellipsis to Unicode, it 278*ad30f8e7SGabor Kovesdan# is surrounded with a direction override to help preserve proper 279*ad30f8e7SGabor Kovesdan# text layout. The resolved direction is not needed or used when 280*ad30f8e7SGabor Kovesdan# mapping the Unicode HORIZONTAL ELLIPSIS back to Mac OS Arabic. 281*ad30f8e7SGabor Kovesdan# 282*ad30f8e7SGabor Kovesdan# 2. Mapping the Mac OS Arabic digits 283*ad30f8e7SGabor Kovesdan# 284*ad30f8e7SGabor Kovesdan# The main table below contains mappings that should be used when 285*ad30f8e7SGabor Kovesdan# strict round-trip fidelity is required. However, for numeric 286*ad30f8e7SGabor Kovesdan# values, the mappings in that table will produce Unicode characters 287*ad30f8e7SGabor Kovesdan# that may appear different than the Mac OS Arabic text displayed on 288*ad30f8e7SGabor Kovesdan# a Mac OS system using WorldScript. This is because WorldScript 289*ad30f8e7SGabor Kovesdan# uses context-dependent display for the 0x30-0x39 digits. 290*ad30f8e7SGabor Kovesdan# 291*ad30f8e7SGabor Kovesdan# If roundtrip fidelity is not required, then the following 292*ad30f8e7SGabor Kovesdan# alternate mappings should be used when a sequence of 0x30-0x39 293*ad30f8e7SGabor Kovesdan# digits - possibly including 0x2C and 0x2E - occurs in an Arabic 294*ad30f8e7SGabor Kovesdan# context (that is, when the first "strong" character on either side 295*ad30f8e7SGabor Kovesdan# of the digit sequence is Arabic, or there is no strong character): 296*ad30f8e7SGabor Kovesdan# 297*ad30f8e7SGabor Kovesdan# 0x2C 0x066C # ARABIC THOUSANDS SEPARATOR 298*ad30f8e7SGabor Kovesdan# 0x2E 0x066B # ARABIC DECIMAL SEPARATOR 299*ad30f8e7SGabor Kovesdan# 0x30 0x0660 # ARABIC-INDIC DIGIT ZERO 300*ad30f8e7SGabor Kovesdan# 0x31 0x0661 # ARABIC-INDIC DIGIT ONE 301*ad30f8e7SGabor Kovesdan# 0x32 0x0662 # ARABIC-INDIC DIGIT TWO 302*ad30f8e7SGabor Kovesdan# 0x33 0x0663 # ARABIC-INDIC DIGIT THREE 303*ad30f8e7SGabor Kovesdan# 0x34 0x0664 # ARABIC-INDIC DIGIT FOUR 304*ad30f8e7SGabor Kovesdan# 0x35 0x0665 # ARABIC-INDIC DIGIT FIVE 305*ad30f8e7SGabor Kovesdan# 0x36 0x0666 # ARABIC-INDIC DIGIT SIX 306*ad30f8e7SGabor Kovesdan# 0x37 0x0667 # ARABIC-INDIC DIGIT SEVEN 307*ad30f8e7SGabor Kovesdan# 0x38 0x0668 # ARABIC-INDIC DIGIT EIGHT 308*ad30f8e7SGabor Kovesdan# 0x39 0x0669 # ARABIC-INDIC DIGIT NINE 309*ad30f8e7SGabor Kovesdan# 310*ad30f8e7SGabor Kovesdan# Details of mapping changes in each version: 311*ad30f8e7SGabor Kovesdan# ------------------------------------------- 312*ad30f8e7SGabor Kovesdan# 313*ad30f8e7SGabor Kovesdan# Changes from version n03 to version n07: 314*ad30f8e7SGabor Kovesdan# 315*ad30f8e7SGabor Kovesdan# - Change mapping for 0xC0 from U+066D to U+274A. 316*ad30f8e7SGabor Kovesdan# 317*ad30f8e7SGabor Kovesdan# - Add direction overrides (required directionality) to mappings 318*ad30f8e7SGabor Kovesdan# for 0x25, 0x2C, 0x3B, 0x3F. 319*ad30f8e7SGabor Kovesdan# 320*ad30f8e7SGabor Kovesdan################## 321*ad30f8e7SGabor Kovesdan0x0000 - 0x007F = 0x00 - 322*ad30f8e7SGabor Kovesdan0x00A0 = 0x81 323*ad30f8e7SGabor Kovesdan0x00AB = 0x8C 324*ad30f8e7SGabor Kovesdan0x00BB = 0x98 325*ad30f8e7SGabor Kovesdan0x00C4 = 0x80 326*ad30f8e7SGabor Kovesdan0x00C7 = 0x82 327*ad30f8e7SGabor Kovesdan0x00C9 = 0x83 328*ad30f8e7SGabor Kovesdan0x00D1 = 0x84 329*ad30f8e7SGabor Kovesdan0x00D6 = 0x85 330*ad30f8e7SGabor Kovesdan0x00DC = 0x86 331*ad30f8e7SGabor Kovesdan0x00E0 = 0x88 332*ad30f8e7SGabor Kovesdan0x00E1 = 0x87 333*ad30f8e7SGabor Kovesdan0x00E2 = 0x89 334*ad30f8e7SGabor Kovesdan0x00E4 = 0x8A 335*ad30f8e7SGabor Kovesdan0x00E7 = 0x8D 336*ad30f8e7SGabor Kovesdan0x00E8 = 0x8F 337*ad30f8e7SGabor Kovesdan0x00E9 = 0x8E 338*ad30f8e7SGabor Kovesdan0x00EA = 0x90 339*ad30f8e7SGabor Kovesdan0x00EB = 0x91 340*ad30f8e7SGabor Kovesdan0x00ED = 0x92 341*ad30f8e7SGabor Kovesdan0x00EE = 0x94 342*ad30f8e7SGabor Kovesdan0x00EF = 0x95 343*ad30f8e7SGabor Kovesdan0x00F1 = 0x96 344*ad30f8e7SGabor Kovesdan0x00F3 = 0x97 345*ad30f8e7SGabor Kovesdan0x00F4 = 0x99 346*ad30f8e7SGabor Kovesdan0x00F6 = 0x9A 347*ad30f8e7SGabor Kovesdan0x00F7 = 0x9B 348*ad30f8e7SGabor Kovesdan0x00F9 = 0x9D 349*ad30f8e7SGabor Kovesdan0x00FA = 0x9C 350*ad30f8e7SGabor Kovesdan0x00FB = 0x9E 351*ad30f8e7SGabor Kovesdan0x00FC = 0x9F 352*ad30f8e7SGabor Kovesdan0x060C = 0xAC 353*ad30f8e7SGabor Kovesdan0x061B = 0xBB 354*ad30f8e7SGabor Kovesdan0x061F = 0xBF 355*ad30f8e7SGabor Kovesdan0x0621 = 0xC1 356*ad30f8e7SGabor Kovesdan0x0622 = 0xC2 357*ad30f8e7SGabor Kovesdan0x0623 = 0xC3 358*ad30f8e7SGabor Kovesdan0x0624 = 0xC4 359*ad30f8e7SGabor Kovesdan0x0625 = 0xC5 360*ad30f8e7SGabor Kovesdan0x0626 = 0xC6 361*ad30f8e7SGabor Kovesdan0x0627 = 0xC7 362*ad30f8e7SGabor Kovesdan0x0628 = 0xC8 363*ad30f8e7SGabor Kovesdan0x0629 = 0xC9 364*ad30f8e7SGabor Kovesdan0x062A = 0xCA 365*ad30f8e7SGabor Kovesdan0x062B = 0xCB 366*ad30f8e7SGabor Kovesdan0x062C = 0xCC 367*ad30f8e7SGabor Kovesdan0x062D = 0xCD 368*ad30f8e7SGabor Kovesdan0x062E = 0xCE 369*ad30f8e7SGabor Kovesdan0x062F = 0xCF 370*ad30f8e7SGabor Kovesdan0x0630 = 0xD0 371*ad30f8e7SGabor Kovesdan0x0631 = 0xD1 372*ad30f8e7SGabor Kovesdan0x0632 = 0xD2 373*ad30f8e7SGabor Kovesdan0x0633 = 0xD3 374*ad30f8e7SGabor Kovesdan0x0634 = 0xD4 375*ad30f8e7SGabor Kovesdan0x0635 = 0xD5 376*ad30f8e7SGabor Kovesdan0x0636 = 0xD6 377*ad30f8e7SGabor Kovesdan0x0637 = 0xD7 378*ad30f8e7SGabor Kovesdan0x0638 = 0xD8 379*ad30f8e7SGabor Kovesdan0x0639 = 0xD9 380*ad30f8e7SGabor Kovesdan0x063A = 0xDA 381*ad30f8e7SGabor Kovesdan0x0640 = 0xE0 382*ad30f8e7SGabor Kovesdan0x0641 = 0xE1 383*ad30f8e7SGabor Kovesdan0x0642 = 0xE2 384*ad30f8e7SGabor Kovesdan0x0643 = 0xE3 385*ad30f8e7SGabor Kovesdan0x0644 = 0xE4 386*ad30f8e7SGabor Kovesdan0x0645 = 0xE5 387*ad30f8e7SGabor Kovesdan0x0646 = 0xE6 388*ad30f8e7SGabor Kovesdan0x0647 = 0xE7 389*ad30f8e7SGabor Kovesdan0x0648 = 0xE8 390*ad30f8e7SGabor Kovesdan0x0649 = 0xE9 391*ad30f8e7SGabor Kovesdan0x064A = 0xEA 392*ad30f8e7SGabor Kovesdan0x064B = 0xEB 393*ad30f8e7SGabor Kovesdan0x064C = 0xEC 394*ad30f8e7SGabor Kovesdan0x064D = 0xED 395*ad30f8e7SGabor Kovesdan0x064E = 0xEE 396*ad30f8e7SGabor Kovesdan0x064F = 0xEF 397*ad30f8e7SGabor Kovesdan0x0650 = 0xF0 398*ad30f8e7SGabor Kovesdan0x0651 = 0xF1 399*ad30f8e7SGabor Kovesdan0x0652 = 0xF2 400*ad30f8e7SGabor Kovesdan0x0660 = 0xB0 401*ad30f8e7SGabor Kovesdan0x0661 = 0xB1 402*ad30f8e7SGabor Kovesdan0x0662 = 0xB2 403*ad30f8e7SGabor Kovesdan0x0663 = 0xB3 404*ad30f8e7SGabor Kovesdan0x0664 = 0xB4 405*ad30f8e7SGabor Kovesdan0x0665 = 0xB5 406*ad30f8e7SGabor Kovesdan0x0666 = 0xB6 407*ad30f8e7SGabor Kovesdan0x0667 = 0xB7 408*ad30f8e7SGabor Kovesdan0x0668 = 0xB8 409*ad30f8e7SGabor Kovesdan0x0669 = 0xB9 410*ad30f8e7SGabor Kovesdan0x066A = 0xA5 411*ad30f8e7SGabor Kovesdan0x066D = 0xC0 412*ad30f8e7SGabor Kovesdan0x0679 = 0xF4 413*ad30f8e7SGabor Kovesdan0x067E = 0xF3 414*ad30f8e7SGabor Kovesdan0x0686 = 0xF5 415*ad30f8e7SGabor Kovesdan0x0688 = 0xF9 416*ad30f8e7SGabor Kovesdan0x0691 = 0xFA 417*ad30f8e7SGabor Kovesdan0x0698 = 0xFE 418*ad30f8e7SGabor Kovesdan0x06A4 = 0xF7 419*ad30f8e7SGabor Kovesdan0x06AF = 0xF8 420*ad30f8e7SGabor Kovesdan0x06BA = 0x8B 421*ad30f8e7SGabor Kovesdan0x06D2 = 0xFF 422*ad30f8e7SGabor Kovesdan0x06D5 = 0xF6 423*ad30f8e7SGabor Kovesdan0x2026 = 0x93 424*ad30f8e7SGabor Kovesdan0x274A = 0xC0 425*ad30f8e7SGabor KovesdanEND_MAP 426