• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 
18 package org.apache.harmony.niochar.charset.additional;
19 
20 import java.nio.ByteBuffer;
21 import java.nio.CharBuffer;
22 import java.nio.charset.Charset;
23 import java.nio.charset.CharsetDecoder;
24 import java.nio.charset.CharsetEncoder;
25 import java.nio.charset.CoderResult;
26 
27 /* TODO: support direct byte buffers
28 import org.apache.harmony.nio.AddressUtil;
29 import org.apache.harmony.niochar.CharsetProviderImpl;
30 */
31 
32 public class IBM437 extends Charset {
33 
IBM437(String csName, String[] aliases)34         public IBM437(String csName, String[] aliases) {
35             super(csName, aliases);
36         }
37 
contains(Charset cs)38         public boolean contains(Charset cs) {
39             return cs.name().equalsIgnoreCase("IBM367") || cs.name().equalsIgnoreCase("IBM437") || cs.name().equalsIgnoreCase("US-ASCII") ;
40         }
41 
newDecoder()42         public CharsetDecoder newDecoder() {
43             return new Decoder(this);
44         }
45 
newEncoder()46         public CharsetEncoder newEncoder() {
47             return new Encoder(this);
48         }
49 
50 	private static final class Decoder extends CharsetDecoder{
Decoder(Charset cs)51 		private Decoder(Charset cs){
52 			super(cs, 1, 1);
53 
54 		}
55 
nDecode(char[] array, int arrPosition, int remaining, long outAddr, int absolutePos)56 		private native int nDecode(char[] array, int arrPosition, int remaining, long outAddr, int absolutePos);
57 
58 
decodeLoop(ByteBuffer bb, CharBuffer cb)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{
Encoder(Charset cs)150 		private Encoder(Charset cs){
151 			super(cs, 1, 1);
152 		}
153 
nEncode(long outAddr, int absolutePos, char[] array, int arrPosition, int[] res)154 		private native void nEncode(long outAddr, int absolutePos, char[] array, int arrPosition, int[] res);
155 
encodeLoop(CharBuffer cb, ByteBuffer bb)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