6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Sun designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Sun in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 22 * CA 95054 USA or visit www.sun.com if you need additional information or 23 * have any questions. 24 */ 25 26 /* 27 */ 28 29 package sun.nio.cs.ext; 30 31 import java.nio.charset.Charset; 32 import java.nio.charset.CharsetDecoder; 33 import java.nio.charset.CharsetEncoder; 34 import java.nio.charset.CharacterCodingException; 35 import sun.nio.cs.HistoricallyNamedCharset; 36 37 public class IBM943C extends Charset implements HistoricallyNamedCharset 38 { 39 40 public IBM943C() { 41 super("x-IBM943C", ExtendedCharsets.aliasesFor("x-IBM943C")); 42 } 43 44 public String historicalName() { 45 return "Cp943C"; 46 } 47 48 public boolean contains(Charset cs) { 49 return ((cs.name().equals("US-ASCII")) 50 || (cs instanceof IBM943C)); 51 } 52 53 public CharsetDecoder newDecoder() { 54 return new Decoder(this); 55 } 56 57 public CharsetEncoder newEncoder() { 58 return new Encoder(this); 59 } 60 61 private static class Decoder extends IBM943.Decoder { 62 protected static final String singleByteToChar; 63 64 static { 65 String indexs = ""; 66 for (char c = '\0'; c < '\u0080'; ++c) indexs += c; 67 singleByteToChar = indexs + 68 IBM943.Decoder.singleByteToChar.substring(indexs.length()); 69 } 70 71 public Decoder(Charset cs) { 72 super(cs, singleByteToChar); 73 } 74 } 75 76 private static class Encoder extends IBM943.Encoder { 77 78 protected static final short index1[]; 79 protected static final String index2a; 80 protected static final int shift = 6; 81 82 static { 83 String indexs = ""; 84 for (char c = '\0'; c < '\u0080'; ++c) indexs += c; 85 index2a = IBM943.Encoder.index2a + indexs; 86 87 int o = IBM943.Encoder.index2a.length() + 15000; 88 index1 = new short[IBM943.Encoder.index1.length]; 89 System.arraycopy(IBM943.Encoder.index1, 90 0, 91 index1, 92 0, 93 IBM943.Encoder.index1.length); 94 95 for (int i = 0; i * (1<<shift) < 128; ++i) { 96 index1[i] = (short)(o + i * (1<<shift)); 97 } 98 } 99 100 public Encoder(Charset cs) { 101 super(cs, index1, index2a); 102 } 103 } 104 } | 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Sun designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Sun in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 22 * CA 95054 USA or visit www.sun.com if you need additional information or 23 * have any questions. 24 */ 25 26 package sun.nio.cs.ext; 27 28 import java.nio.charset.Charset; 29 import java.nio.charset.CharsetDecoder; 30 import java.nio.charset.CharsetEncoder; 31 import java.util.Arrays; 32 import sun.nio.cs.HistoricallyNamedCharset; 33 34 public class IBM943C extends Charset implements HistoricallyNamedCharset 35 { 36 37 public IBM943C() { 38 super("x-IBM943C", ExtendedCharsets.aliasesFor("x-IBM943C")); 39 } 40 41 public String historicalName() { 42 return "Cp943C"; 43 } 44 45 public boolean contains(Charset cs) { 46 return ((cs.name().equals("US-ASCII")) 47 || (cs instanceof IBM943C)); 48 } 49 50 public CharsetDecoder newDecoder() { 51 return new DoubleByte.Decoder(this, 52 IBM943.b2c, 53 b2cSB, 54 0x40, 55 0xfc); 56 } 57 58 public CharsetEncoder newEncoder() { 59 return new DoubleByte.Encoder(this, c2b, c2bIndex); 60 } 61 62 final static char[] b2cSB; 63 final static char[] c2b; 64 final static char[] c2bIndex; 65 66 static { 67 IBM943.initb2c(); 68 b2cSB = new char[0x100]; 69 for (int i = 0; i < 0x80; i++) { 70 b2cSB[i] = (char)i; 71 } 72 for (int i = 0x80; i < 0x100; i++) { 73 b2cSB[i] = IBM943.b2cSB[i]; 74 } 75 76 IBM943.initc2b(); 77 c2b = Arrays.copyOf(IBM943.c2b, IBM943.c2b.length); 78 c2bIndex = Arrays.copyOf(IBM943.c2bIndex, IBM943.c2bIndex.length); 79 for (char c = '\0'; c < '\u0080'; ++c) { 80 int index = c2bIndex[c >> 8]; 81 c2b[index + (c & 0xff)] = c; 82 } 83 } 84 } |