1/*
2 *  Licensed to the Apache Software Foundation (ASF) under one or more
3 *  contributor license agreements.  See the NOTICE file distributed with
4 *  this work for additional information regarding copyright ownership.
5 *  The ASF licenses this file to You under the Apache License, Version 2.0
6 *  (the "License"); you may not use this file except in compliance with
7 *  the License.  You may obtain a copy of the License at
8 *
9 *     http://www.apache.org/licenses/LICENSE-2.0
10 *
11 *  Unless required by applicable law or agreed to in writing, software
12 *  distributed under the License is distributed on an "AS IS" BASIS,
13 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 *  See the License for the specific language governing permissions and
15 *  limitations under the License.
16 */
17
18package org.apache.harmony.niochar.charset.additional;
19
20import java.nio.ByteBuffer;
21import java.nio.CharBuffer;
22import java.nio.charset.Charset;
23import java.nio.charset.CharsetDecoder;
24import java.nio.charset.CharsetEncoder;
25import java.nio.charset.CoderResult;
26
27/* TODO: support direct byte buffers
28import org.apache.harmony.nio.AddressUtil;
29import org.apache.harmony.niochar.CharsetProviderImpl;
30*/
31
32public class IBM437 extends Charset {
33
34        public IBM437(String csName, String[] aliases) {
35            super(csName, aliases);
36        }
37
38        public boolean contains(Charset cs) {
39            return cs.name().equalsIgnoreCase("IBM367") || cs.name().equalsIgnoreCase("IBM437") || cs.name().equalsIgnoreCase("US-ASCII") ;
40        }
41
42        public CharsetDecoder newDecoder() {
43            return new Decoder(this);
44        }
45
46        public CharsetEncoder newEncoder() {
47            return new Encoder(this);
48        }
49
50	private static final class Decoder extends CharsetDecoder{
51		private Decoder(Charset cs){
52			super(cs, 1, 1);
53
54		}
55
56		private native int nDecode(char[] array, int arrPosition, int remaining, long outAddr, int absolutePos);
57
58
59		protected CoderResult decodeLoop(ByteBuffer bb, CharBuffer cb){
60                        int cbRemaining = cb.remaining();
61/* TODO: support direct byte buffers
62		        if(CharsetProviderImpl.hasLoadedNatives() && bb.isDirect() && bb.hasRemaining() && cb.hasArray()){
63		            int toProceed = bb.remaining();
64		            int cbPos = cb.position();
65		            int bbPos = bb.position();
66		            boolean throwOverflow = false;
67		            if( cbRemaining < toProceed ) {
68		                toProceed = cbRemaining;
69                                throwOverflow = true;
70                            }
71                            int res = nDecode(cb.array(), cb.arrayOffset()+cbPos, toProceed, AddressUtil.getDirectBufferAddress(bb), bbPos);
72                            bb.position(bbPos+res);
73                            cb.position(cbPos+res);
74                            if(throwOverflow) return CoderResult.OVERFLOW;
75                        }else{
76*/
77                            if(bb.hasArray() && cb.hasArray()) {
78                                int rem = bb.remaining();
79                                rem = cbRemaining >= rem ? rem : cbRemaining;
80                                byte[] bArr = bb.array();
81                                char[] cArr = cb.array();
82                                int bStart = bb.position();
83                                int cStart = cb.position();
84                                int i;
85                                for(i=bStart; i<bStart+rem; i++) {
86                                    char in = (char)(bArr[i] & 0xFF);
87                                    if(in >= 26){
88                                        int index = (int)in - 26;
89                                        cArr[cStart++] = (char)arr[index];
90                                    }else {
91                                        cArr[cStart++] = (char)(in & 0xFF);
92                                    }
93                                }
94                                bb.position(i);
95                                cb.position(cStart);
96                                if(rem == cbRemaining && bb.hasRemaining()) return CoderResult.OVERFLOW;
97                            } else {
98                                while(bb.hasRemaining()){
99                                    if( cbRemaining == 0 ) return CoderResult.OVERFLOW;
100                                    char in = (char)(bb.get() & 0xFF);
101                                    if(in >= 26){
102                                        int index = (int)in - 26;
103                                        cb.put(arr[index]);
104                                    }else {
105                                        cb.put((char)(in & 0xFF));
106                                    }
107                                cbRemaining--;
108                                }
109/*
110                            }
111*/
112			}
113                        return CoderResult.UNDERFLOW;
114		}
115
116		final static char[] arr = {
117                0x001C,0x001B,0x007F,0x001D,0x001E,0x001F,
118                0x0020,0x0021,0x0022,0x0023,0x0024,0x0025,0x0026,0x0027,
119                0x0028,0x0029,0x002A,0x002B,0x002C,0x002D,0x002E,0x002F,
120                0x0030,0x0031,0x0032,0x0033,0x0034,0x0035,0x0036,0x0037,
121                0x0038,0x0039,0x003A,0x003B,0x003C,0x003D,0x003E,0x003F,
122                0x0040,0x0041,0x0042,0x0043,0x0044,0x0045,0x0046,0x0047,
123                0x0048,0x0049,0x004A,0x004B,0x004C,0x004D,0x004E,0x004F,
124                0x0050,0x0051,0x0052,0x0053,0x0054,0x0055,0x0056,0x0057,
125                0x0058,0x0059,0x005A,0x005B,0x005C,0x005D,0x005E,0x005F,
126                0x0060,0x0061,0x0062,0x0063,0x0064,0x0065,0x0066,0x0067,
127                0x0068,0x0069,0x006A,0x006B,0x006C,0x006D,0x006E,0x006F,
128                0x0070,0x0071,0x0072,0x0073,0x0074,0x0075,0x0076,0x0077,
129                0x0078,0x0079,0x007A,0x007B,0x007C,0x007D,0x007E,0x001A,
130                0x00C7,0x00FC,0x00E9,0x00E2,0x00E4,0x00E0,0x00E5,0x00E7,
131                0x00EA,0x00EB,0x00E8,0x00EF,0x00EE,0x00EC,0x00C4,0x00C5,
132                0x00C9,0x00E6,0x00C6,0x00F4,0x00F6,0x00F2,0x00FB,0x00F9,
133                0x00FF,0x00D6,0x00DC,0x00A2,0x00A3,0x00A5,0x20A7,0x0192,
134                0x00E1,0x00ED,0x00F3,0x00FA,0x00F1,0x00D1,0x00AA,0x00BA,
135                0x00BF,0x2310,0x00AC,0x00BD,0x00BC,0x00A1,0x00AB,0x00BB,
136                0x2591,0x2592,0x2593,0x2502,0x2524,0x2561,0x2562,0x2556,
137                0x2555,0x2563,0x2551,0x2557,0x255D,0x255C,0x255B,0x2510,
138                0x2514,0x2534,0x252C,0x251C,0x2500,0x253C,0x255E,0x255F,
139                0x255A,0x2554,0x2569,0x2566,0x2560,0x2550,0x256C,0x2567,
140                0x2568,0x2564,0x2565,0x2559,0x2558,0x2552,0x2553,0x256B,
141                0x256A,0x2518,0x250C,0x2588,0x2584,0x258C,0x2590,0x2580,
142                0x03B1,0x00DF,0x0393,0x03C0,0x03A3,0x03C3,0x03BC,0x03C4,
143                0x03A6,0x0398,0x03A9,0x03B4,0x221E,0x03C6,0x03B5,0x2229,
144                0x2261,0x00B1,0x2265,0x2264,0x2320,0x2321,0x00F7,0x2248,
145                0x00B0,0x2219,0x00B7,0x221A,0x207F,0x00B2,0x25A0,0x00A0
146		};
147        }
148
149	private static final class Encoder extends CharsetEncoder{
150		private Encoder(Charset cs){
151			super(cs, 1, 1);
152		}
153
154		private native void nEncode(long outAddr, int absolutePos, char[] array, int arrPosition, int[] res);
155
156		protected CoderResult encodeLoop(CharBuffer cb, ByteBuffer bb){
157                        int bbRemaining = bb.remaining();
158/* TODO: support direct byte buffers
159                        if(CharsetProviderImpl.hasLoadedNatives() && bb.isDirect() && cb.hasRemaining() && cb.hasArray()){
160		            int toProceed = cb.remaining();
161		            int cbPos = cb.position();
162		            int bbPos = bb.position();
163		            boolean throwOverflow = false;
164		            if( bbRemaining < toProceed ) {
165		                toProceed = bbRemaining;
166                                throwOverflow = true;
167                            }
168                            int[] res = {toProceed, 0};
169                            nEncode(AddressUtil.getDirectBufferAddress(bb), bbPos, cb.array(), cb.arrayOffset()+cbPos, res);
170                            if( res[0] <= 0 ) {
171                                bb.position(bbPos-res[0]);
172                                cb.position(cbPos-res[0]);
173                                if(res[1]!=0) {
174                                    if(res[1] < 0)
175                                        return CoderResult.malformedForLength(-res[1]);
176                                    else
177                                        return CoderResult.unmappableForLength(res[1]);
178                                }
179                            }else{
180                                bb.position(bbPos+res[0]);
181                                cb.position(cbPos+res[0]);
182                                if(throwOverflow) return CoderResult.OVERFLOW;
183                            }
184                        }else{
185*/
186                            if(bb.hasArray() && cb.hasArray()) {
187                                byte[] byteArr = bb.array();
188                                char[] charArr = cb.array();
189                                int rem = cb.remaining();
190                                int byteArrStart = bb.position();
191                                rem = bbRemaining <= rem ? bbRemaining : rem;
192                                int x;
193                                for(x = cb.position(); x < cb.position()+rem; x++) {
194                                    char c = charArr[x];
195                                    if(c > (char)0x25A0){
196                                        if (c >= 0xD800 && c <= 0xDFFF) {
197                                            if(x+1 < cb.limit()) {
198                                                char c1 = charArr[x+1];
199                                                if(c1 >= 0xD800 && c1 <= 0xDFFF) {
200                                                    cb.position(x); bb.position(byteArrStart);
201                                                    return CoderResult.unmappableForLength(2);
202                                                }
203                                            } else {
204                                                cb.position(x); bb.position(byteArrStart);
205                                                return CoderResult.UNDERFLOW;
206                                            }
207                                            cb.position(x); bb.position(byteArrStart);
208                                            return CoderResult.malformedForLength(1);
209                                        }
210                                        cb.position(x); bb.position(byteArrStart);
211                                        return CoderResult.unmappableForLength(1);
212                                    }else{
213                                        if(c < 0x1A) {
214                                            byteArr[byteArrStart++] = (byte)c;
215                                        } else {
216                                            int index = (int)c >> 8;
217                                            index = encodeIndex[index];
218                                            if(index < 0) {
219                                                cb.position(x); bb.position(byteArrStart);
220                                                return CoderResult.unmappableForLength(1);
221                                            }
222                                            index <<= 8;
223                                            index += (int)c & 0xFF;
224                                            if((byte)arr[index] != 0){
225                                                byteArr[byteArrStart++] = (byte)arr[index];
226                                            }else{
227                                                cb.position(x); bb.position(byteArrStart);
228                                                return CoderResult.unmappableForLength(1);
229                                            }
230                                        }
231                                    }
232                                }
233                                cb.position(x);
234                                bb.position(byteArrStart);
235                                if(rem == bbRemaining && cb.hasRemaining()) {
236                                    return CoderResult.OVERFLOW;
237                                }
238                            } else {
239                                while(cb.hasRemaining()){
240                                    if( bbRemaining == 0 ) return CoderResult.OVERFLOW;
241                                    char c = cb.get();
242                                    if(c > (char)0x25A0){
243                                        if (c >= 0xD800 && c <= 0xDFFF) {
244                                            if(cb.hasRemaining()) {
245                                                char c1 = cb.get();
246                                                if(c1 >= 0xD800 && c1 <= 0xDFFF) {
247                                                    cb.position(cb.position()-2);
248                                                    return CoderResult.unmappableForLength(2);
249                                                } else {
250                                                    cb.position(cb.position()-1);
251                                                }
252                                            } else {
253                                                cb.position(cb.position()-1);
254                                                return CoderResult.UNDERFLOW;
255                                            }
256                                            cb.position(cb.position()-1);
257                                            return CoderResult.malformedForLength(1);
258                                        }
259                                        cb.position(cb.position()-1);
260                                        return CoderResult.unmappableForLength(1);
261                                    }else{
262                                        if(c < 0x1A) {
263                                            bb.put((byte)c);
264                                        } else {
265                                            int index = (int)c >> 8;
266                                            index = encodeIndex[index];
267                                            if(index < 0) {
268                                                cb.position(cb.position()-1);
269                                                return CoderResult.unmappableForLength(1);
270                                            }
271                                            index <<= 8;
272                                            index += (int)c & 0xFF;
273                                            if((byte)arr[index] != 0){
274                                                bb.put((byte)arr[index]);
275                                            }else{
276                                                cb.position(cb.position()-1);
277                                                return CoderResult.unmappableForLength(1);
278                                            }
279                                        }
280                                        bbRemaining--;
281                                    }
282                                }
283/* TODO: support direct byte buffers
284			    }
285*/
286			}
287			return CoderResult.UNDERFLOW;
288		}
289
290                final static char arr[] = {
291
292                0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,
293                0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x7F,0x1B,0x1A,0x1D,0x1E,0x1F,
294                0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,0x28,0x29,0x2A,0x2B,0x2C,0x2D,0x2E,0x2F,
295                0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39,0x3A,0x3B,0x3C,0x3D,0x3E,0x3F,
296                0x40,0x41,0x42,0x43,0x44,0x45,0x46,0x47,0x48,0x49,0x4A,0x4B,0x4C,0x4D,0x4E,0x4F,
297                0x50,0x51,0x52,0x53,0x54,0x55,0x56,0x57,0x58,0x59,0x5A,0x5B,0x5C,0x5D,0x5E,0x5F,
298                0x60,0x61,0x62,0x63,0x64,0x65,0x66,0x67,0x68,0x69,0x6A,0x6B,0x6C,0x6D,0x6E,0x6F,
299                0x70,0x71,0x72,0x73,0x74,0x75,0x76,0x77,0x78,0x79,0x7A,0x7B,0x7C,0x7D,0x7E,0x1C,
300                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
301                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
302                0xFF,0xAD,0x9B,0x9C,0x00,0x9D,0x00,0x00,0x00,0x00,0xA6,0xAE,0xAA,0x00,0x00,0x00,
303                0xF8,0xF1,0xFD,0x00,0x00,0x00,0x00,0xFA,0x00,0x00,0xA7,0xAF,0xAC,0xAB,0x00,0xA8,
304                0x00,0x00,0x00,0x00,0x8E,0x8F,0x92,0x80,0x00,0x90,0x00,0x00,0x00,0x00,0x00,0x00,
305                0x00,0xA5,0x00,0x00,0x00,0x00,0x99,0x00,0x00,0x00,0x00,0x00,0x9A,0x00,0x00,0xE1,
306                0x85,0xA0,0x83,0x00,0x84,0x86,0x91,0x87,0x8A,0x82,0x88,0x89,0x8D,0xA1,0x8C,0x8B,
307                0x00,0xA4,0x95,0xA2,0x93,0x00,0x94,0xF6,0x00,0x97,0xA3,0x96,0x81,0x00,0x00,0x98,
308
309                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
310                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
311                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
312                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
313                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
314                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
315                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
316                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
317                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
318                0x00,0x00,0x9F,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
319                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
320                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
321                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
322                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
323                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
324                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
325
326                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
327                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
328                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
329                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
330                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
331                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
332                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
333                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
334                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
335                0x00,0x00,0x00,0xE2,0x00,0x00,0x00,0x00,0xE9,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
336                0x00,0x00,0x00,0xE4,0x00,0x00,0xE8,0x00,0x00,0xEA,0x00,0x00,0x00,0x00,0x00,0x00,
337                0x00,0xE0,0x00,0x00,0xEB,0xEE,0x00,0x00,0x00,0x00,0x00,0x00,0xE6,0x00,0x00,0x00,
338                0xE3,0x00,0x00,0xE5,0xE7,0x00,0xED,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
339                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
340                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
341                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
342
343                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
344                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
345                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
346                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
347                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
348                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
349                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
350                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xFC,
351                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
352                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
353                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x9E,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
354                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
355                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
356                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
357                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
358                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
359
360                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
361                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xF9,0xFB,0x00,0x00,0x00,0xEC,0x00,
362                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xEF,0x00,0x00,0x00,0x00,0x00,0x00,
363                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
364                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xF7,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
365                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
366                0x00,0xF0,0x00,0x00,0xF3,0xF2,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
367                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
368                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
369                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
370                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
371                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
372                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
373                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
374                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
375                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
376
377                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
378                0xA9,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
379                0xF4,0xF5,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
380                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
381                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
382                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
383                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
384                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
385                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
386                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
387                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
388                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
389                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
390                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
391                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
392                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
393
394                0xC4,0x00,0xB3,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xDA,0x00,0x00,0x00,
395                0xBF,0x00,0x00,0x00,0xC0,0x00,0x00,0x00,0xD9,0x00,0x00,0x00,0xC3,0x00,0x00,0x00,
396                0x00,0x00,0x00,0x00,0xB4,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xC2,0x00,0x00,0x00,
397                0x00,0x00,0x00,0x00,0xC1,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xC5,0x00,0x00,0x00,
398                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
399                0xCD,0xBA,0xD5,0xD6,0xC9,0xB8,0xB7,0xBB,0xD4,0xD3,0xC8,0xBE,0xBD,0xBC,0xC6,0xC7,
400                0xCC,0xB5,0xB6,0xB9,0xD1,0xD2,0xCB,0xCF,0xD0,0xCA,0xD8,0xD7,0xCE,0x00,0x00,0x00,
401                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
402                0xDF,0x00,0x00,0x00,0xDC,0x00,0x00,0x00,0xDB,0x00,0x00,0x00,0xDD,0x00,0x00,0x00,
403                0xDE,0xB0,0xB1,0xB2,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
404                0xFE,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
405                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
406                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
407                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
408                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
409                0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
410                };
411
412                final static int[] encodeIndex = {
413                 0,1,-1,2,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
414                 3,-1,4,5,-1,6,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
415                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
416                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
417                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
418                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
419                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
420                 -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1
421                };
422	}
423}
424