xref: /freebsd/share/i18n/csmapper/APPLE/UCS%ARABIC.src (revision d0b2dbfa0ecf2bbc9709efc5e20baf8e4b44bbbf)
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