22586
|
1 |
"{ Encoding: utf8 }"
|
|
2 |
|
|
3 |
"
|
|
4 |
COPYRIGHT (c) 2004 by eXept Software AG
|
|
5 |
All Rights Reserved
|
|
6 |
|
|
7 |
This software is furnished under a license and may be used
|
|
8 |
only in accordance with the terms of that license and with the
|
|
9 |
inclusion of the above copyright notice. This software may not
|
|
10 |
be provided or otherwise made available to, or used by, any
|
|
11 |
other person. No title to or ownership of the software is
|
|
12 |
hereby transferred.
|
|
13 |
"
|
|
14 |
"{ Package: 'stx:libbasic' }"
|
|
15 |
|
|
16 |
"{ NameSpace: CharacterEncoderImplementations }"
|
|
17 |
|
|
18 |
SingleByteEncoder subclass:#MS_CP1252
|
|
19 |
instanceVariableNames:''
|
|
20 |
classVariableNames:''
|
|
21 |
poolDictionaries:''
|
|
22 |
category:'Collections-Text-Encodings'
|
|
23 |
!
|
|
24 |
|
|
25 |
!MS_CP1252 class methodsFor:'documentation'!
|
|
26 |
|
|
27 |
copyright
|
|
28 |
"
|
|
29 |
COPYRIGHT (c) 2004 by eXept Software AG
|
|
30 |
All Rights Reserved
|
|
31 |
|
|
32 |
This software is furnished under a license and may be used
|
|
33 |
only in accordance with the terms of that license and with the
|
|
34 |
inclusion of the above copyright notice. This software may not
|
|
35 |
be provided or otherwise made available to, or used by, any
|
|
36 |
other person. No title to or ownership of the software is
|
|
37 |
hereby transferred.
|
|
38 |
"
|
|
39 |
!
|
|
40 |
|
|
41 |
documentation
|
|
42 |
"
|
|
43 |
Microsoft CP1252 is based on iso8859-1.
|
|
44 |
Codepoints 0x80–0x9F which are control characters
|
|
45 |
in iso8859 are mapped to special windows characters.
|
|
46 |
|
|
47 |
This is similar to MS_ANSI,
|
|
48 |
but will always return single byte chars
|
|
49 |
(in contrast to MS_ANSI)
|
|
50 |
|
|
51 |
[see with:]
|
|
52 |
CharacterEncoderImplementations::MS_Ansi showCharacterSet
|
|
53 |
CharacterEncoderImplementations::MS_CP1252 showCharacterSet
|
|
54 |
|
|
55 |
[author:]
|
|
56 |
Claus Gittinger
|
|
57 |
"
|
|
58 |
! !
|
|
59 |
|
|
60 |
!MS_CP1252 class methodsFor:'mapping'!
|
|
61 |
|
|
62 |
mapFileURL2_relativePathName
|
|
63 |
^ 'CP1252'
|
|
64 |
|
|
65 |
"
|
|
66 |
self generateCode
|
|
67 |
"
|
|
68 |
!
|
|
69 |
|
|
70 |
mapping
|
|
71 |
"
|
|
72 |
# From: http://std.dkuug.dk/i18n/charmaps/CP1252
|
|
73 |
|
|
74 |
<code_set_name> CP1252
|
|
75 |
<comment_char> %
|
|
76 |
<escape_char> /
|
|
77 |
% version: 1.0
|
|
78 |
% repertoiremap: mnemonic,ds
|
|
79 |
% source: UNICODE 1.0
|
|
80 |
|
|
81 |
% alias MS-ANSI
|
|
82 |
CHARMAP
|
|
83 |
<NU> /x00 <U0000> NULL (NUL)
|
|
84 |
<SH> /x01 <U0001> START OF HEADING (SOH)
|
|
85 |
<SX> /x02 <U0002> START OF TEXT (STX)
|
|
86 |
<EX> /x03 <U0003> END OF TEXT (ETX)
|
|
87 |
<ET> /x04 <U0004> END OF TRANSMISSION (EOT)
|
|
88 |
<EQ> /x05 <U0005> ENQUIRY (ENQ)
|
|
89 |
<AK> /x06 <U0006> ACKNOWLEDGE (ACK)
|
|
90 |
<BL> /x07 <U0007> BELL (BEL)
|
|
91 |
<BS> /x08 <U0008> BACKSPACE (BS)
|
|
92 |
<HT> /x09 <U0009> CHARACTER TABULATION (HT)
|
|
93 |
<LF> /x0A <U000A> LINE FEED (LF)
|
|
94 |
<VT> /x0B <U000B> LINE TABULATION (VT)
|
|
95 |
<FF> /x0C <U000C> FORM FEED (FF)
|
|
96 |
<CR> /x0D <U000D> CARRIAGE RETURN (CR)
|
|
97 |
<SO> /x0E <U000E> SHIFT OUT (SO)
|
|
98 |
<SI> /x0F <U000F> SHIFT IN (SI)
|
|
99 |
<DL> /x10 <U0010> DATALINK ESCAPE (DLE)
|
|
100 |
<D1> /x11 <U0011> DEVICE CONTROL ONE (DC1)
|
|
101 |
<D2> /x12 <U0012> DEVICE CONTROL TWO (DC2)
|
|
102 |
<D3> /x13 <U0013> DEVICE CONTROL THREE (DC3)
|
|
103 |
<D4> /x14 <U0014> DEVICE CONTROL FOUR (DC4)
|
|
104 |
<NK> /x15 <U0015> NEGATIVE ACKNOWLEDGE (NAK)
|
|
105 |
<SY> /x16 <U0016> SYNCHRONOUS IDLE (SYN)
|
|
106 |
<EB> /x17 <U0017> END OF TRANSMISSION BLOCK (ETB)
|
|
107 |
<CN> /x18 <U0018> CANCEL (CAN)
|
|
108 |
<EM> /x19 <U0019> END OF MEDIUM (EM)
|
|
109 |
<SB> /x1A <U001A> SUBSTITUTE (SUB)
|
|
110 |
<EC> /x1B <U001B> ESCAPE (ESC)
|
|
111 |
<FS> /x1C <U001C> FILE SEPARATOR (IS4)
|
|
112 |
<GS> /x1D <U001D> GROUP SEPARATOR (IS3)
|
|
113 |
<RS> /x1E <U001E> RECORD SEPARATOR (IS2)
|
|
114 |
<US> /x1F <U001F> UNIT SEPARATOR (IS1)
|
|
115 |
<SP> /x20 <U0020> SPACE
|
|
116 |
<!!> /x21 <U0021> EXCLAMATION MARK
|
|
117 |
<'> /x22 <U0022> QUOTATION MARK
|
|
118 |
<Nb> /x23 <U0023> NUMBER SIGN
|
|
119 |
<DO> /x24 <U0024> DOLLAR SIGN
|
|
120 |
<%> /x25 <U0025> PERCENT SIGN
|
|
121 |
<&> /x26 <U0026> AMPERSAND
|
|
122 |
<'> /x27 <U0027> APOSTROPHE
|
|
123 |
<(> /x28 <U0028> LEFT PARENTHESIS
|
|
124 |
<)> /x29 <U0029> RIGHT PARENTHESIS
|
|
125 |
<*> /x2A <U002A> ASTERISK
|
|
126 |
<+> /x2B <U002B> PLUS SIGN
|
|
127 |
<,> /x2C <U002C> COMMA
|
|
128 |
<-> /x2D <U002D> HYPHEN-MINUS
|
|
129 |
<.> /x2E <U002E> FULL STOP
|
|
130 |
<//> /x2F <U002F> SOLIDUS
|
|
131 |
<0> /x30 <U0030> DIGIT ZERO
|
|
132 |
<1> /x31 <U0031> DIGIT ONE
|
|
133 |
<2> /x32 <U0032> DIGIT TWO
|
|
134 |
<3> /x33 <U0033> DIGIT THREE
|
|
135 |
<4> /x34 <U0034> DIGIT FOUR
|
|
136 |
<5> /x35 <U0035> DIGIT FIVE
|
|
137 |
<6> /x36 <U0036> DIGIT SIX
|
|
138 |
<7> /x37 <U0037> DIGIT SEVEN
|
|
139 |
<8> /x38 <U0038> DIGIT EIGHT
|
|
140 |
<9> /x39 <U0039> DIGIT NINE
|
|
141 |
<:> /x3A <U003A> COLON
|
|
142 |
<;> /x3B <U003B> SEMICOLON
|
|
143 |
<<> /x3C <U003C> LESS-THAN SIGN
|
|
144 |
<=> /x3D <U003D> EQUALS SIGN
|
|
145 |
</>> /x3E <U003E> GREATER-THAN SIGN
|
|
146 |
<?> /x3F <U003F> QUESTION MARK
|
|
147 |
<At> /x40 <U0040> COMMERCIAL AT
|
|
148 |
<A> /x41 <U0041> LATIN CAPITAL LETTER A
|
|
149 |
<B> /x42 <U0042> LATIN CAPITAL LETTER B
|
|
150 |
<C> /x43 <U0043> LATIN CAPITAL LETTER C
|
|
151 |
<D> /x44 <U0044> LATIN CAPITAL LETTER D
|
|
152 |
<E> /x45 <U0045> LATIN CAPITAL LETTER E
|
|
153 |
<F> /x46 <U0046> LATIN CAPITAL LETTER F
|
|
154 |
<G> /x47 <U0047> LATIN CAPITAL LETTER G
|
|
155 |
<H> /x48 <U0048> LATIN CAPITAL LETTER H
|
|
156 |
<I> /x49 <U0049> LATIN CAPITAL LETTER I
|
|
157 |
<J> /x4A <U004A> LATIN CAPITAL LETTER J
|
|
158 |
<K> /x4B <U004B> LATIN CAPITAL LETTER K
|
|
159 |
<L> /x4C <U004C> LATIN CAPITAL LETTER L
|
|
160 |
<M> /x4D <U004D> LATIN CAPITAL LETTER M
|
|
161 |
<N> /x4E <U004E> LATIN CAPITAL LETTER N
|
|
162 |
<O> /x4F <U004F> LATIN CAPITAL LETTER O
|
|
163 |
<P> /x50 <U0050> LATIN CAPITAL LETTER P
|
|
164 |
<Q> /x51 <U0051> LATIN CAPITAL LETTER Q
|
|
165 |
<R> /x52 <U0052> LATIN CAPITAL LETTER R
|
|
166 |
<S> /x53 <U0053> LATIN CAPITAL LETTER S
|
|
167 |
<T> /x54 <U0054> LATIN CAPITAL LETTER T
|
|
168 |
<U> /x55 <U0055> LATIN CAPITAL LETTER U
|
|
169 |
<V> /x56 <U0056> LATIN CAPITAL LETTER V
|
|
170 |
<W> /x57 <U0057> LATIN CAPITAL LETTER W
|
|
171 |
<X> /x58 <U0058> LATIN CAPITAL LETTER X
|
|
172 |
<Y> /x59 <U0059> LATIN CAPITAL LETTER Y
|
|
173 |
<Z> /x5A <U005A> LATIN CAPITAL LETTER Z
|
|
174 |
<<(> /x5B <U005B> LEFT SQUARE BRACKET
|
|
175 |
<////> /x5C <U005C> REVERSE SOLIDUS
|
|
176 |
<)/>> /x5D <U005D> RIGHT SQUARE BRACKET
|
|
177 |
<'/>> /x5E <U005E> CIRCUMFLEX ACCENT
|
|
178 |
<_> /x5F <U005F> LOW LINE
|
|
179 |
<'!!> /x60 <U0060> GRAVE ACCENT
|
|
180 |
<a> /x61 <U0061> LATIN SMALL LETTER A
|
|
181 |
<b> /x62 <U0062> LATIN SMALL LETTER B
|
|
182 |
<c> /x63 <U0063> LATIN SMALL LETTER C
|
|
183 |
<d> /x64 <U0064> LATIN SMALL LETTER D
|
|
184 |
<e> /x65 <U0065> LATIN SMALL LETTER E
|
|
185 |
<f> /x66 <U0066> LATIN SMALL LETTER F
|
|
186 |
<g> /x67 <U0067> LATIN SMALL LETTER G
|
|
187 |
<h> /x68 <U0068> LATIN SMALL LETTER H
|
|
188 |
<i> /x69 <U0069> LATIN SMALL LETTER I
|
|
189 |
<j> /x6A <U006A> LATIN SMALL LETTER J
|
|
190 |
<k> /x6B <U006B> LATIN SMALL LETTER K
|
|
191 |
<l> /x6C <U006C> LATIN SMALL LETTER L
|
|
192 |
<m> /x6D <U006D> LATIN SMALL LETTER M
|
|
193 |
<n> /x6E <U006E> LATIN SMALL LETTER N
|
|
194 |
<o> /x6F <U006F> LATIN SMALL LETTER O
|
|
195 |
<p> /x70 <U0070> LATIN SMALL LETTER P
|
|
196 |
<q> /x71 <U0071> LATIN SMALL LETTER Q
|
|
197 |
<r> /x72 <U0072> LATIN SMALL LETTER R
|
|
198 |
<s> /x73 <U0073> LATIN SMALL LETTER S
|
|
199 |
<t> /x74 <U0074> LATIN SMALL LETTER T
|
|
200 |
<u> /x75 <U0075> LATIN SMALL LETTER U
|
|
201 |
<v> /x76 <U0076> LATIN SMALL LETTER V
|
|
202 |
<w> /x77 <U0077> LATIN SMALL LETTER W
|
|
203 |
<x> /x78 <U0078> LATIN SMALL LETTER X
|
|
204 |
<y> /x79 <U0079> LATIN SMALL LETTER Y
|
|
205 |
<z> /x7A <U007A> LATIN SMALL LETTER Z
|
|
206 |
<(!!> /x7B <U007B> LEFT CURLY BRACKET
|
|
207 |
<!!!!> /x7C <U007C> VERTICAL LINE
|
|
208 |
<!!)> /x7D <U007D> RIGHT CURLY BRACKET
|
|
209 |
<'?> /x7E <U007E> TILDE
|
|
210 |
<DT> /x7F <U007F> DELETE (DEL)
|
|
211 |
<.9> /x82 <U201A> SINGLE LOW-9 QUOTATION MARK
|
|
212 |
<f2> /x83 <U0192> LATIN SMALL LETTER F WITH HOOK
|
|
213 |
<:9> /x84 <U201E> DOUBLE LOW-9 QUOTATION MARK
|
|
214 |
<.3> /x85 <U2026> HORIZONTAL ELLIPSIS
|
|
215 |
<//-> /x86 <U2020> DAGGER
|
|
216 |
<//=> /x87 <U2021> DOUBLE DAGGER
|
|
217 |
<1/>> /x88 <U02C6> MODIFIER LETTER CIRCUMFLEX ACCENT
|
|
218 |
<%0> /x89 <U2030> PER MILLE SIGN
|
|
219 |
<S<> /x8A <U0160> LATIN CAPITAL LETTER S WITH CARON
|
|
220 |
<<1> /x8B <U2039> SINGLE LEFT-POINTING ANGLE QUOTATION MARK
|
|
221 |
<OE> /x8C <U0152> LATIN CAPITAL LIGATURE OE
|
|
222 |
<'6> /x91 <U2018> LEFT SINGLE QUOTATION MARK
|
|
223 |
<'9> /x92 <U2019> RIGHT SINGLE QUOTATION MARK
|
|
224 |
<'6> /x93 <U201C> LEFT DOUBLE QUOTATION MARK
|
|
225 |
<'9> /x94 <U201D> RIGHT DOUBLE QUOTATION MARK
|
|
226 |
<sb> /x95 <U2022> BULLET
|
|
227 |
<-N> /x96 <U2013> EN DASH
|
|
228 |
<-M> /x97 <U2014> EM DASH
|
|
229 |
<1?> /x98 <U02DC> SMALL TILDE
|
|
230 |
<TM> /x99 <U2122> TRADE MARK SIGN
|
|
231 |
<s<> /x9A <U0161> LATIN SMALL LETTER S WITH CARON
|
|
232 |
</>1> /x9B <U203A> SINGLE RIGHT-POINTING ANGLE QUOTATION MARK
|
|
233 |
<oe> /x9C <U0153> LATIN SMALL LIGATURE OE
|
|
234 |
<Y:> /x9F <U0178> LATIN CAPITAL LETTER Y WITH DIAERESIS
|
|
235 |
<NS> /xA0 <U00A0> NO-BREAK SPACE
|
|
236 |
<!!I> /xA1 <U00A1> INVERTED EXCLAMATION MARK
|
|
237 |
<Ct> /xA2 <U00A2> CENT SIGN
|
|
238 |
<Pd> /xA3 <U00A3> POUND SIGN
|
|
239 |
<Cu> /xA4 <U00A4> CURRENCY SIGN
|
|
240 |
<Ye> /xA5 <U00A5> YEN SIGN
|
|
241 |
<BB> /xA6 <U00A6> BROKEN BAR
|
|
242 |
<SE> /xA7 <U00A7> SECTION SIGN
|
|
243 |
<':> /xA8 <U00A8> DIAERESIS
|
|
244 |
<Co> /xA9 <U00A9> COPYRIGHT SIGN
|
|
245 |
<-a> /xAA <U00AA> FEMININE ORDINAL INDICATOR
|
|
246 |
<<<> /xAB <U00AB> LEFT-POINTING DOUBLE ANGLE QUOTATION MARK
|
|
247 |
<NO> /xAC <U00AC> NOT SIGN
|
|
248 |
<--> /xAD <U00AD> SOFT HYPHEN
|
|
249 |
<Rg> /xAE <U00AE> REGISTERED SIGN
|
|
250 |
<'m> /xAF <U00AF> MACRON
|
|
251 |
<DG> /xB0 <U00B0> DEGREE SIGN
|
|
252 |
<+-> /xB1 <U00B1> PLUS-MINUS SIGN
|
|
253 |
<2S> /xB2 <U00B2> SUPERSCRIPT TWO
|
|
254 |
<3S> /xB3 <U00B3> SUPERSCRIPT THREE
|
|
255 |
<''> /xB4 <U00B4> ACUTE ACCENT
|
|
256 |
<My> /xB5 <U00B5> MICRO SIGN
|
|
257 |
<PI> /xB6 <U00B6> PILCROW SIGN
|
|
258 |
<.M> /xB7 <U00B7> MIDDLE DOT
|
|
259 |
<',> /xB8 <U00B8> CEDILLA
|
|
260 |
<1S> /xB9 <U00B9> SUPERSCRIPT ONE
|
|
261 |
<-o> /xBA <U00BA> MASCULINE ORDINAL INDICATOR
|
|
262 |
</>/>> /xBB <U00BB> RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK
|
|
263 |
<14> /xBC <U00BC> VULGAR FRACTION ONE QUARTER
|
|
264 |
<12> /xBD <U00BD> VULGAR FRACTION ONE HALF
|
|
265 |
<34> /xBE <U00BE> VULGAR FRACTION THREE QUARTERS
|
|
266 |
<?I> /xBF <U00BF> INVERTED QUESTION MARK
|
|
267 |
<A!!> /xC0 <U00C0> LATIN CAPITAL LETTER A WITH GRAVE
|
|
268 |
<A'> /xC1 <U00C1> LATIN CAPITAL LETTER A WITH ACUTE
|
|
269 |
<A/>> /xC2 <U00C2> LATIN CAPITAL LETTER A WITH CIRCUMFLEX
|
|
270 |
<A?> /xC3 <U00C3> LATIN CAPITAL LETTER A WITH TILDE
|
|
271 |
<A:> /xC4 <U00C4> LATIN CAPITAL LETTER A WITH DIAERESIS
|
|
272 |
<AA> /xC5 <U00C5> LATIN CAPITAL LETTER A WITH RING ABOVE
|
|
273 |
<AE> /xC6 <U00C6> LATIN CAPITAL LETTER AE
|
|
274 |
<C,> /xC7 <U00C7> LATIN CAPITAL LETTER C WITH CEDILLA
|
|
275 |
<E!!> /xC8 <U00C8> LATIN CAPITAL LETTER E WITH GRAVE
|
|
276 |
<E'> /xC9 <U00C9> LATIN CAPITAL LETTER E WITH ACUTE
|
|
277 |
<E/>> /xCA <U00CA> LATIN CAPITAL LETTER E WITH CIRCUMFLEX
|
|
278 |
<E:> /xCB <U00CB> LATIN CAPITAL LETTER E WITH DIAERESIS
|
|
279 |
<I!!> /xCC <U00CC> LATIN CAPITAL LETTER I WITH GRAVE
|
|
280 |
<I'> /xCD <U00CD> LATIN CAPITAL LETTER I WITH ACUTE
|
|
281 |
<I/>> /xCE <U00CE> LATIN CAPITAL LETTER I WITH CIRCUMFLEX
|
|
282 |
<I:> /xCF <U00CF> LATIN CAPITAL LETTER I WITH DIAERESIS
|
|
283 |
<D-> /xD0 <U00D0> LATIN CAPITAL LETTER ETH (Icelandic)
|
|
284 |
<N?> /xD1 <U00D1> LATIN CAPITAL LETTER N WITH TILDE
|
|
285 |
<O!!> /xD2 <U00D2> LATIN CAPITAL LETTER O WITH GRAVE
|
|
286 |
<O'> /xD3 <U00D3> LATIN CAPITAL LETTER O WITH ACUTE
|
|
287 |
<O/>> /xD4 <U00D4> LATIN CAPITAL LETTER O WITH CIRCUMFLEX
|
|
288 |
<O?> /xD5 <U00D5> LATIN CAPITAL LETTER O WITH TILDE
|
|
289 |
<O:> /xD6 <U00D6> LATIN CAPITAL LETTER O WITH DIAERESIS
|
|
290 |
<*X> /xD7 <U00D7> MULTIPLICATION SIGN
|
|
291 |
<O//> /xD8 <U00D8> LATIN CAPITAL LETTER O WITH STROKE
|
|
292 |
<U!!> /xD9 <U00D9> LATIN CAPITAL LETTER U WITH GRAVE
|
|
293 |
<U'> /xDA <U00DA> LATIN CAPITAL LETTER U WITH ACUTE
|
|
294 |
<U/>> /xDB <U00DB> LATIN CAPITAL LETTER U WITH CIRCUMFLEX
|
|
295 |
<U:> /xDC <U00DC> LATIN CAPITAL LETTER U WITH DIAERESIS
|
|
296 |
<Y'> /xDD <U00DD> LATIN CAPITAL LETTER Y WITH ACUTE
|
|
297 |
<TH> /xDE <U00DE> LATIN CAPITAL LETTER THORN (Icelandic)
|
|
298 |
<ss> /xDF <U00DF> LATIN SMALL LETTER SHARP S (German)
|
|
299 |
<a!!> /xE0 <U00E0> LATIN SMALL LETTER A WITH GRAVE
|
|
300 |
<a'> /xE1 <U00E1> LATIN SMALL LETTER A WITH ACUTE
|
|
301 |
<a/>> /xE2 <U00E2> LATIN SMALL LETTER A WITH CIRCUMFLEX
|
|
302 |
<a?> /xE3 <U00E3> LATIN SMALL LETTER A WITH TILDE
|
|
303 |
<a:> /xE4 <U00E4> LATIN SMALL LETTER A WITH DIAERESIS
|
|
304 |
<aa> /xE5 <U00E5> LATIN SMALL LETTER A WITH RING ABOVE
|
|
305 |
<ae> /xE6 <U00E6> LATIN SMALL LETTER AE
|
|
306 |
<c,> /xE7 <U00E7> LATIN SMALL LETTER C WITH CEDILLA
|
|
307 |
<e!!> /xE8 <U00E8> LATIN SMALL LETTER E WITH GRAVE
|
|
308 |
<e'> /xE9 <U00E9> LATIN SMALL LETTER E WITH ACUTE
|
|
309 |
<e/>> /xEA <U00EA> LATIN SMALL LETTER E WITH CIRCUMFLEX
|
|
310 |
<e:> /xEB <U00EB> LATIN SMALL LETTER E WITH DIAERESIS
|
|
311 |
<i!!> /xEC <U00EC> LATIN SMALL LETTER I WITH GRAVE
|
|
312 |
<i'> /xED <U00ED> LATIN SMALL LETTER I WITH ACUTE
|
|
313 |
<i/>> /xEE <U00EE> LATIN SMALL LETTER I WITH CIRCUMFLEX
|
|
314 |
<i:> /xEF <U00EF> LATIN SMALL LETTER I WITH DIAERESIS
|
|
315 |
<d-> /xF0 <U00F0> LATIN SMALL LETTER ETH (Icelandic)
|
|
316 |
<n?> /xF1 <U00F1> LATIN SMALL LETTER N WITH TILDE
|
|
317 |
<o!!> /xF2 <U00F2> LATIN SMALL LETTER O WITH GRAVE
|
|
318 |
<o'> /xF3 <U00F3> LATIN SMALL LETTER O WITH ACUTE
|
|
319 |
<o/>> /xF4 <U00F4> LATIN SMALL LETTER O WITH CIRCUMFLEX
|
|
320 |
<o?> /xF5 <U00F5> LATIN SMALL LETTER O WITH TILDE
|
|
321 |
<o:> /xF6 <U00F6> LATIN SMALL LETTER O WITH DIAERESIS
|
|
322 |
<-:> /xF7 <U00F7> DIVISION SIGN
|
|
323 |
<o//> /xF8 <U00F8> LATIN SMALL LETTER O WITH STROKE
|
|
324 |
<u!!> /xF9 <U00F9> LATIN SMALL LETTER U WITH GRAVE
|
|
325 |
<u'> /xFA <U00FA> LATIN SMALL LETTER U WITH ACUTE
|
|
326 |
<u/>> /xFB <U00FB> LATIN SMALL LETTER U WITH CIRCUMFLEX
|
|
327 |
<u:> /xFC <U00FC> LATIN SMALL LETTER U WITH DIAERESIS
|
|
328 |
<y'> /xFD <U00FD> LATIN SMALL LETTER Y WITH ACUTE
|
|
329 |
<th> /xFE <U00FE> LATIN SMALL LETTER THORN (Icelandic)
|
|
330 |
<y:> /xFF <U00FF> LATIN SMALL LETTER Y WITH DIAERESIS
|
|
331 |
END CHARMAP
|
|
332 |
|
|
333 |
"
|
|
334 |
! !
|
|
335 |
|
|
336 |
!MS_CP1252 class methodsFor:'queries'!
|
|
337 |
|
|
338 |
maxCode
|
22588
|
339 |
^ 255
|
22586
|
340 |
!
|
|
341 |
|
|
342 |
minCode
|
|
343 |
^ 0
|
|
344 |
! !
|
|
345 |
|
|
346 |
!MS_CP1252 methodsFor:'encoding & decoding'!
|
|
347 |
|
|
348 |
decode:codeArg
|
|
349 |
|code "{ Class: SmallInteger }" t|
|
|
350 |
|
|
351 |
code := codeArg.
|
|
352 |
code <= 16r7F ifTrue:[ ^ code ].
|
|
353 |
code >= 16rA0 ifTrue:[
|
|
354 |
code > 16rFF ifTrue:[
|
|
355 |
^ 16rFF.
|
|
356 |
].
|
|
357 |
^ codeArg.
|
|
358 |
].
|
|
359 |
|
|
360 |
"similar to 8859-1 with different chars in the 8x..9x area"
|
|
361 |
"we map CP1252 chars to unicode chars"
|
|
362 |
|
|
363 |
t := #(
|
|
364 |
"16r0080" 16r20AC " EURO character "
|
|
365 |
"16r0081" 16r0000 " invalid "
|
|
366 |
"16r0082" 16r201A " SINGLE LOW-9 QUOTATION MARK "
|
|
367 |
"16r0083" 16r0192 " LATIN SMALL LETTER F WITH HOOK "
|
|
368 |
"16r0084" 16r201E " DOUBLE LOW-9 QUOTATION MARK "
|
|
369 |
"16r0085" 16r2026 " HORIZONTAL ELLIPSIS "
|
|
370 |
"16r0086" 16r2020 " DAGGER "
|
|
371 |
"16r0087" 16r2021 " DOUBLE DAGGER "
|
|
372 |
"16r0088" 16r02C6 " MODIFIER LETTER CIRCUMFLEX ACCENT "
|
|
373 |
"16r0089" 16r2030 " PER MILLE SIGN "
|
|
374 |
"16r008A" 16r0160 " LATIN CAPITAL LETTER S WITH CARON "
|
|
375 |
"16r008B" 16r2039 " SINGLE LEFT-POINTING ANGLE QUOTATION MARK "
|
|
376 |
"16r008C" 16r0152 " LATIN CAPITAL LIGATURE OE "
|
|
377 |
"16r008D" 16r0000 " invalid "
|
|
378 |
"16r008E" 16r017D " LATIN CAPITAL Z WITH INVERSE CARON"
|
|
379 |
"16r008F" 16r0000 " invalid "
|
|
380 |
"16r0090" 16r0000 " invalid "
|
|
381 |
"16r0091" 16r2018 " LEFT SINGLE QUOTATION MARK "
|
|
382 |
"16r0092" 16r2019 " RIGHT SINGLE QUOTATION MARK "
|
|
383 |
"16r0093" 16r201C " LEFT DOUBLE QUOTATION MARK "
|
|
384 |
"16r0094" 16r201D " RIGHT DOUBLE QUOTATION MARK "
|
|
385 |
"16r0095" 16r2022 " BULLET "
|
|
386 |
"16r0096" 16r2013 " EN DASH "
|
|
387 |
"16r0097" 16r2014 " EM DASH "
|
|
388 |
"16r0098" 16r02DC " SMALL TILDE "
|
|
389 |
"16r0099" 16r2122 " TRADE MARK SIGN "
|
|
390 |
"16r009A" 16r0161 " LATIN SMALL LETTER S WITH CARON "
|
|
391 |
"16r009B" 16r203A " SINGLE RIGHT-POINTING ANGLE QUOTATION MARK "
|
|
392 |
"16r009C" 16r0153 " LATIN SMALL LIGATURE OE "
|
|
393 |
"16r009D" 16r0000 " invalid "
|
|
394 |
"16r009E" 16r017E " LATIN SMALL LETTER Z WITH INVERSE CARON "
|
|
395 |
"16r009F" 16r0178 " LATIN CAPITAL LETTER Y WITH DIAERESIS "
|
|
396 |
) at:(code - 16r7F).
|
|
397 |
t == 0 ifFalse:[^ t].
|
|
398 |
^ self decodingError.
|
|
399 |
|
|
400 |
"Modified (format): / 12-07-2012 / 14:06:56 / cg"
|
|
401 |
!
|
|
402 |
|
|
403 |
decodeString:anEncodedStringOrByteCollection
|
|
404 |
"given a string in my encoding, return a unicode-string for it"
|
|
405 |
|
23334
|
406 |
|outStream myCode code size "{ Class:SmallInteger }"|
|
22586
|
407 |
|
|
408 |
size := anEncodedStringOrByteCollection size.
|
23334
|
409 |
outStream := CharacterWriteStream new:size.
|
22586
|
410 |
|
|
411 |
1 to:size do:[:idx |
|
|
412 |
code := (anEncodedStringOrByteCollection at:idx) codePoint.
|
|
413 |
myCode := self decode:code.
|
23334
|
414 |
outStream nextPut:(Character codePoint:myCode).
|
22586
|
415 |
].
|
23334
|
416 |
^ outStream contents
|
22586
|
417 |
|
|
418 |
"
|
|
419 |
CharacterEncoderImplementations::MS_CP1252 decodeString:'hello'
|
|
420 |
"
|
|
421 |
|
|
422 |
"Created: / 16-01-2018 / 19:54:02 / stefan"
|
|
423 |
"Modified (format): / 17-01-2018 / 16:30:59 / stefan"
|
23334
|
424 |
"Modified: / 14-09-2018 / 14:24:18 / Claus Gittinger"
|
22586
|
425 |
!
|
|
426 |
|
|
427 |
encode:unicodeArg
|
|
428 |
|unicode "{ Class: SmallInteger }" t
|
|
429 |
replacementForInvalid|
|
|
430 |
|
|
431 |
"we map unicode chars to CP1252 where a mapping exists.
|
|
432 |
If no mapping exists, we encode it as 0xFF"
|
|
433 |
|
|
434 |
replacementForInvalid := 16r7F.
|
|
435 |
|
|
436 |
unicode := unicodeArg.
|
|
437 |
unicode > 16r2122 ifTrue:[
|
|
438 |
^ replacementForInvalid.
|
|
439 |
].
|
|
440 |
unicode <= 16rFF ifTrue:[
|
|
441 |
^ unicode
|
|
442 |
].
|
|
443 |
unicode <= 16r2DC ifTrue:[
|
|
444 |
unicode <= 16r192 ifTrue:[
|
|
445 |
unicode <= 16r178 ifTrue:[
|
|
446 |
unicode <= 16r161 ifTrue:[
|
|
447 |
t := #[
|
|
448 |
"16r0152" 16r8C " LATIN CAPITAL LIGATURE OE "
|
|
449 |
"16r0153" 16r9C " LATIN SMALL LIGATURE OE "
|
|
450 |
"16r0154" 16r00 " keep unicode "
|
|
451 |
"16r0155" 16r00 " keep unicode "
|
|
452 |
"16r0156" 16r00 " keep unicode "
|
|
453 |
"16r0157" 16r00 " keep unicode "
|
|
454 |
"16r0158" 16r00 " keep unicode "
|
|
455 |
"16r0159" 16r00 " keep unicode "
|
|
456 |
"16r015A" 16r00 " keep unicode "
|
|
457 |
"16r015B" 16r00 " keep unicode "
|
|
458 |
"16r015C" 16r00 " keep unicode "
|
|
459 |
"16r015D" 16r00 " keep unicode "
|
|
460 |
"16r015E" 16r00 " keep unicode "
|
|
461 |
"16r015F" 16r00 " keep unicode "
|
|
462 |
"16r0160" 16r8A " LATIN CAPITAL LETTER S WITH CARON "
|
|
463 |
"16r0161" 16r9A " LATIN SMALL LETTER S WITH CARON "
|
|
464 |
] at:(unicode - 16r151).
|
|
465 |
t == 0 ifFalse:[^ t].
|
|
466 |
^ unicode
|
|
467 |
].
|
|
468 |
unicode <= 16r177 ifTrue:[
|
|
469 |
^ replacementForInvalid
|
|
470 |
].
|
|
471 |
^ "16r0178" 16r009F " LATIN CAPITAL LETTER Y WITH DIAERESIS "
|
|
472 |
].
|
|
473 |
unicode <= 16r191 ifTrue:[
|
|
474 |
^ replacementForInvalid
|
|
475 |
].
|
|
476 |
^ "16r0192" 16r0083 " LATIN SMALL LETTER F WITH HOOK "
|
|
477 |
].
|
|
478 |
unicode <= 16r2C5 ifTrue:[
|
|
479 |
^ replacementForInvalid
|
|
480 |
].
|
|
481 |
unicode == 16r2C6 ifTrue:[
|
|
482 |
^ "16r02C6" 16r0088 " MODIFIER LETTER CIRCUMFLEX ACCENT "
|
|
483 |
].
|
|
484 |
unicode <= 16r2DB ifTrue:[
|
|
485 |
^ replacementForInvalid
|
|
486 |
].
|
|
487 |
^ "16r02DC" 16r0098 " SMALL TILDE "
|
|
488 |
].
|
|
489 |
unicode <= 16r2012 ifTrue:[
|
|
490 |
^ replacementForInvalid
|
|
491 |
].
|
|
492 |
unicode <= 16r203A ifTrue:[
|
|
493 |
t := #(
|
|
494 |
"16r2013" 16r96" EN DASH "
|
|
495 |
"16r2014" 16r97" EM DASH "
|
|
496 |
"16r2015" 16r00 " keep unicode "
|
|
497 |
"16r2016" 16r00 " keep unicode "
|
|
498 |
"16r2017" 16r00 " keep unicode "
|
|
499 |
"16r2018" 16r91 " LEFT SINGLE QUOTATION MARK "
|
|
500 |
"16r2019" 16r92 " RIGHT SINGLE QUOTATION MARK "
|
|
501 |
"16r201A" 16r82 " SINGLE LOW-9 QUOTATION MARK "
|
|
502 |
"16r201B" 16r00 " keep unicode "
|
|
503 |
"16r201C" 16r93 " LEFT DOUBLE QUOTATION MARK "
|
|
504 |
"16r201D" 16r94 " RIGHT DOUBLE QUOTATION MARK "
|
|
505 |
"16r201E" 16r84 " DOUBLE LOW-9 QUOTATION MARK "
|
|
506 |
"16r201F" 16r00 " keep unicode "
|
|
507 |
"16r2020" 16r86 " DAGGER "
|
|
508 |
"16r2021" 16r87 " DOUBLE DAGGER "
|
|
509 |
"16r2022" 16r95 " BULLET "
|
|
510 |
"16r2023" 16r00 " keep unicode "
|
|
511 |
"16r2024" 16r00 " keep unicode "
|
|
512 |
"16r2025" 16r00 " keep unicode "
|
|
513 |
"16r2026" 16r85 " HORIZONTAL ELLIPSIS "
|
|
514 |
"16r2027" 16r00 " keep unicode "
|
|
515 |
"16r2028" 16r00 " keep unicode "
|
|
516 |
"16r2029" 16r00 " keep unicode "
|
|
517 |
"16r202A" 16r00 " keep unicode "
|
|
518 |
"16r202B" 16r00 " keep unicode "
|
|
519 |
"16r202C" 16r00 " keep unicode "
|
|
520 |
"16r202D" 16r00 " keep unicode "
|
|
521 |
"16r202E" 16r00 " keep unicode "
|
|
522 |
"16r202F" 16r00 " keep unicode "
|
|
523 |
"16r2030" 16r89 " PER MILLE SIGN "
|
|
524 |
"16r2031" 16r00 " keep unicode "
|
|
525 |
"16r2032" 16r00 " keep unicode "
|
|
526 |
"16r2033" 16r00 " keep unicode "
|
|
527 |
"16r2034" 16r00 " keep unicode "
|
|
528 |
"16r2035" 16r00 " keep unicode "
|
|
529 |
"16r2036" 16r00 " keep unicode "
|
|
530 |
"16r2037" 16r00 " keep unicode "
|
|
531 |
"16r2038" 16r00 " keep unicode "
|
|
532 |
"16r2039" 16r8B " SINGLE LEFT-POINTING ANGLE QUOTATION MARK "
|
|
533 |
"16r203A" 16r9B " SINGLE RIGHT-POINTING ANGLE QUOTATION MARK "
|
|
534 |
) at:(unicode - 16r2012).
|
|
535 |
t == 0 ifFalse:[^ t].
|
|
536 |
^ replacementForInvalid
|
|
537 |
].
|
|
538 |
unicode = 16r20AC ifTrue:[
|
|
539 |
^ 16r0080 " EURO character "
|
|
540 |
].
|
|
541 |
unicode <= 16r2121 ifTrue:[
|
|
542 |
^ replacementForInvalid
|
|
543 |
].
|
|
544 |
^ "16r2122" 16r0099 " TRADE MARK SIGN "
|
|
545 |
!
|
|
546 |
|
|
547 |
encodeString:aStringOrUnicodeString
|
|
548 |
"redefined to speedup simple 8 bit strings"
|
|
549 |
|
|
550 |
|newString myCode bits size "{ Class:SmallInteger }"|
|
|
551 |
|
|
552 |
"/ all between 0 and 7F ?
|
|
553 |
(aStringOrUnicodeString containsNon7BitAscii) ifFalse:[
|
|
554 |
^ aStringOrUnicodeString asSingleByteString.
|
|
555 |
].
|
|
556 |
|
|
557 |
size := aStringOrUnicodeString size.
|
|
558 |
newString := String new:size.
|
|
559 |
bits := newString bitsPerCharacter.
|
|
560 |
|
|
561 |
1 to:size do:[:idx |
|
|
562 |
myCode := self encode:((aStringOrUnicodeString at:idx) codePoint).
|
|
563 |
newString at:idx put:(Character codePoint:myCode).
|
|
564 |
].
|
|
565 |
^ newString
|
|
566 |
! !
|
|
567 |
|
|
568 |
!MS_CP1252 class methodsFor:'documentation'!
|
|
569 |
|
|
570 |
version
|
|
571 |
^ '$Header$'
|
|
572 |
!
|
|
573 |
|
|
574 |
version_CVS
|
|
575 |
^ '$Header$'
|
|
576 |
! !
|
|
577 |
|