6803681: RFE: Need new codeset converter for IBM Cp1364
Forward port the Cp1364 Reviewed-by: alanb
This commit is contained in:
parent
4293c9d423
commit
5423e4402e
@ -376,6 +376,7 @@ FILES_gen_extcs = \
|
|||||||
sun/nio/cs/ext/HKSCSMapping.java \
|
sun/nio/cs/ext/HKSCSMapping.java \
|
||||||
sun/nio/cs/ext/HKSCS2001Mapping.java \
|
sun/nio/cs/ext/HKSCS2001Mapping.java \
|
||||||
sun/nio/cs/ext/HKSCS_XPMapping.java \
|
sun/nio/cs/ext/HKSCS_XPMapping.java \
|
||||||
|
sun/nio/cs/ext/IBM1364.java \
|
||||||
sun/nio/cs/ext/IBM1381.java \
|
sun/nio/cs/ext/IBM1381.java \
|
||||||
sun/nio/cs/ext/IBM1383.java \
|
sun/nio/cs/ext/IBM1383.java \
|
||||||
sun/nio/cs/ext/IBM930.java \
|
sun/nio/cs/ext/IBM930.java \
|
||||||
|
22
jdk/make/tools/CharsetMapping/IBM1364.c2b
Normal file
22
jdk/make/tools/CharsetMapping/IBM1364.c2b
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
#
|
||||||
|
# Diff of
|
||||||
|
# b2c: cdctables.zip/Package2.zip/IBM-1364A.zip/055444B0.TPMAP110
|
||||||
|
# c2b: cdctables.zip/Package2.zip/IBM-1364A.zip/055444B0.UPMAP110
|
||||||
|
# shows there are 6 additional c->b entries in UPMAP110, they are
|
||||||
|
# listed below (in b->c form)
|
||||||
|
#
|
||||||
|
# UPMAP110 also defines
|
||||||
|
# <subchar> \xFE\xFE
|
||||||
|
# and commend out
|
||||||
|
# #<subchar1> \x3F
|
||||||
|
# with
|
||||||
|
#
|
||||||
|
# <UFFFD> \xFE\xFD # (SUB)
|
||||||
|
# <UFFFD> \xFE\xFE # (SUB)
|
||||||
|
#
|
||||||
|
4148 00AD
|
||||||
|
4143 00B7
|
||||||
|
4149 2015
|
||||||
|
42A1 223C
|
||||||
|
496F 2299
|
||||||
|
4954 FF5E
|
19774
jdk/make/tools/CharsetMapping/IBM1364.map
Normal file
19774
jdk/make/tools/CharsetMapping/IBM1364.map
Normal file
File diff suppressed because it is too large
Load Diff
@ -10,6 +10,7 @@ MS936 x-mswin-936 MS936 basic sun.nio.cs.ext true 0x81 0xfe 0x
|
|||||||
MS949 x-windows-949 MS949 basic sun.nio.cs.ext true 0x81 0xfe 0x41 0xfe
|
MS949 x-windows-949 MS949 basic sun.nio.cs.ext true 0x81 0xfe 0x41 0xfe
|
||||||
MS950 x-windows-950 MS950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe
|
MS950 x-windows-950 MS950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe
|
||||||
GBK GBK GBK basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe
|
GBK GBK GBK basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe
|
||||||
|
IBM1364 x-IBM1364 Cp1364 ebcdic sun.nio.cs.ext false 0x40 0xde 0x40 0xfe
|
||||||
IBM1381 x-IBM1381 Cp1381 basic sun.nio.cs.ext true 0x8c 0xf7 0xa1 0xfe
|
IBM1381 x-IBM1381 Cp1381 basic sun.nio.cs.ext true 0x8c 0xf7 0xa1 0xfe
|
||||||
IBM1383 x-IBM1383 Cp1383 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe
|
IBM1383 x-IBM1383 Cp1383 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe
|
||||||
IBM930 x-IBM930 Cp930 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe
|
IBM930 x-IBM930 Cp930 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe
|
||||||
|
@ -679,6 +679,14 @@ public class ExtendedCharsets
|
|||||||
"1124"
|
"1124"
|
||||||
});
|
});
|
||||||
|
|
||||||
|
charset("x-IBM1364", "IBM1364",
|
||||||
|
new String[] {
|
||||||
|
"cp1364",
|
||||||
|
"ibm1364",
|
||||||
|
"ibm-1364",
|
||||||
|
"1364"
|
||||||
|
});
|
||||||
|
|
||||||
charset("IBM273", "IBM273",
|
charset("IBM273", "IBM273",
|
||||||
new String[] {
|
new String[] {
|
||||||
"cp273", // JDK historical
|
"cp273", // JDK historical
|
||||||
|
209
jdk/test/sun/nio/cs/TestIBM1364.java
Normal file
209
jdk/test/sun/nio/cs/TestIBM1364.java
Normal file
@ -0,0 +1,209 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* @test
|
||||||
|
@bug 6803681
|
||||||
|
@summary Test IBM1364
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.nio.*;
|
||||||
|
import java.nio.charset.*;
|
||||||
|
|
||||||
|
public class TestIBM1364 {
|
||||||
|
private static String c2bNRStr = "\u00AD\u00B7\u2015\u223C\u2299\uFF5E";
|
||||||
|
private static byte[] c2bNRBytes = new byte[] {
|
||||||
|
(byte)0x0e,
|
||||||
|
(byte)0x41, (byte)0x48,
|
||||||
|
(byte)0x41, (byte)0x43,
|
||||||
|
(byte)0x41, (byte)0x49,
|
||||||
|
(byte)0x42, (byte)0xa1,
|
||||||
|
(byte)0x49, (byte)0x6f,
|
||||||
|
(byte)0x49, (byte)0x54,
|
||||||
|
(byte)0x0f };
|
||||||
|
|
||||||
|
// end at SO
|
||||||
|
private static String mixedStr = "\u008d\u008e\u0020\u3000\u3001\u71ba\u3164\u0088\ue757";
|
||||||
|
private static byte[] mixedBytes = new byte[] {
|
||||||
|
(byte)0x09,
|
||||||
|
(byte)0x0a,
|
||||||
|
(byte)0x40,
|
||||||
|
(byte)0x0e,
|
||||||
|
(byte)0x40, (byte)0x40,
|
||||||
|
(byte)0x41, (byte)0x41,
|
||||||
|
(byte)0x6c, (byte)0x45,
|
||||||
|
(byte)0x84, (byte)0x41,
|
||||||
|
(byte)0x0f,
|
||||||
|
(byte)0x28,
|
||||||
|
(byte)0x0e,
|
||||||
|
(byte)0xdd, (byte)0xfd,
|
||||||
|
(byte)0x0f };
|
||||||
|
|
||||||
|
// end at SI
|
||||||
|
private static String mixedStr2 = "\u008d\u008e\u0020\u3000\u3001\u71ba\u3164\u0088";
|
||||||
|
private static byte[] mixedBytes2 = new byte[] {
|
||||||
|
(byte)0x09,
|
||||||
|
(byte)0x0a,
|
||||||
|
(byte)0x40,
|
||||||
|
(byte)0x0e,
|
||||||
|
(byte)0x40, (byte)0x40,
|
||||||
|
(byte)0x41, (byte)0x41,
|
||||||
|
(byte)0x6c, (byte)0x45,
|
||||||
|
(byte)0x84, (byte)0x41,
|
||||||
|
(byte)0x0f,
|
||||||
|
(byte)0x28 };
|
||||||
|
|
||||||
|
private static byte[][] malformedBytes = {
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x039, (byte)0x40,
|
||||||
|
(byte)0x0f
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x039, (byte)0x42,
|
||||||
|
(byte)0x0f
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x040, (byte)0x41,
|
||||||
|
(byte)0x0f
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x040, (byte)0xee,
|
||||||
|
(byte)0x0f
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x0ef, (byte)0x30,
|
||||||
|
(byte)0x0f
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x0ff, (byte)0x41,
|
||||||
|
(byte)0x0f
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static byte[][] unmappedBytes = {
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x06c, (byte)0x46,
|
||||||
|
(byte)0x0f,
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x078, (byte)0x46,
|
||||||
|
(byte)0x0f,
|
||||||
|
},
|
||||||
|
{ (byte)0x0e,
|
||||||
|
(byte)0x083, (byte)0xfe,
|
||||||
|
(byte)0x0f,
|
||||||
|
},
|
||||||
|
{ (byte)0xfa },
|
||||||
|
{ (byte)0xfe },
|
||||||
|
};
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
if (!(Arrays.equals(mixedStr.getBytes("cp1364"), mixedBytes)) ||
|
||||||
|
!mixedStr.equals(new String(mixedBytes, "cp1364")))
|
||||||
|
throw new RuntimeException("cp1364 failed on mixed!");
|
||||||
|
|
||||||
|
if (!(Arrays.equals(mixedStr2.getBytes("cp1364"), mixedBytes2)) ||
|
||||||
|
!mixedStr2.equals(new String(mixedBytes2, "cp1364")))
|
||||||
|
throw new RuntimeException("cp1364 failed on mixed!");
|
||||||
|
|
||||||
|
if (!(Arrays.equals(c2bNRStr.getBytes("cp1364"), c2bNRBytes)) ||
|
||||||
|
c2bNRStr.equals(new String(c2bNRBytes, "cp1364")))
|
||||||
|
throw new RuntimeException("cp1364 failed on c2bNR!");
|
||||||
|
|
||||||
|
ByteBuffer bb = ByteBuffer.allocateDirect(mixedBytes.length);
|
||||||
|
bb.put(mixedBytes).flip();
|
||||||
|
CharBuffer cb = Charset.forName("ibm1364").decode(bb);
|
||||||
|
if (!mixedStr.equals(new String(cb.toString())))
|
||||||
|
throw new RuntimeException("cp1364 failed on direct decod()!");
|
||||||
|
|
||||||
|
bb = ByteBuffer.allocateDirect(mixedBytes2.length);
|
||||||
|
bb.put(mixedBytes2).flip();
|
||||||
|
cb = Charset.forName("ibm1364").decode(bb);
|
||||||
|
if (!mixedStr2.equals(new String(cb.toString())))
|
||||||
|
throw new RuntimeException("cp1364 failed on direct decod()!");
|
||||||
|
|
||||||
|
cb = ByteBuffer.allocateDirect(mixedStr.length() * 2).asCharBuffer();
|
||||||
|
cb.put(mixedStr.toCharArray()).flip();
|
||||||
|
bb = Charset.forName("x-ibm1364").encode(cb);
|
||||||
|
if (!(Arrays.equals(Arrays.copyOf(bb.array(), bb.limit()), mixedBytes)))
|
||||||
|
throw new RuntimeException("cp1364 failed on direct encode()!");
|
||||||
|
|
||||||
|
cb = ByteBuffer.allocateDirect(mixedStr2.length() * 2).asCharBuffer();
|
||||||
|
cb.put(mixedStr2.toCharArray()).flip();
|
||||||
|
bb = Charset.forName("x-ibm1364").encode(cb);
|
||||||
|
if (!(Arrays.equals(Arrays.copyOf(bb.array(), bb.limit()), mixedBytes2)))
|
||||||
|
throw new RuntimeException("cp1364 failed on direct encode()!");
|
||||||
|
|
||||||
|
// malformed
|
||||||
|
cb = CharBuffer.allocate(1024);
|
||||||
|
CharBuffer cbd = ByteBuffer.allocateDirect(1024).asCharBuffer();
|
||||||
|
CharsetDecoder dec = Charset.forName("x-ibm1364").newDecoder();
|
||||||
|
for (byte[] ba:malformedBytes) {
|
||||||
|
cb.clear();
|
||||||
|
dec.reset();
|
||||||
|
if (!dec.reset().decode(ByteBuffer.wrap(ba), cb, true).isMalformed() ||
|
||||||
|
!dec.reset().decode(ByteBuffer.wrap(ba), cbd, true).isMalformed())
|
||||||
|
throw new RuntimeException("cp1364 failed on decode()/malformed!");
|
||||||
|
}
|
||||||
|
|
||||||
|
//unmappable
|
||||||
|
for (byte[] ba:unmappedBytes) {
|
||||||
|
cb.clear();
|
||||||
|
dec.reset();
|
||||||
|
if (!dec.reset().decode(ByteBuffer.wrap(ba), cb, true).isUnmappable() ||
|
||||||
|
!dec.reset().decode(ByteBuffer.wrap(ba), cbd, true).isUnmappable())
|
||||||
|
throw new RuntimeException("cp1364 failed on decode()/unmappable!");
|
||||||
|
}
|
||||||
|
|
||||||
|
//overflow
|
||||||
|
cb.limit(mixedStr.length() - 1);
|
||||||
|
cbd.limit(mixedStr.length() - 1);
|
||||||
|
if (!dec.reset().decode(ByteBuffer.wrap(mixedBytes), cb, true).isOverflow() ||
|
||||||
|
!dec.reset().decode(ByteBuffer.wrap(mixedBytes), cbd, true).isOverflow())
|
||||||
|
throw new RuntimeException("cp1364 failed on decode()/overflow!");
|
||||||
|
|
||||||
|
CharsetEncoder enc = Charset.forName("x-ibm1364").newEncoder();
|
||||||
|
// last "0x0f" is from flush()
|
||||||
|
bb = ByteBuffer.allocate(mixedBytes.length - 2);
|
||||||
|
ByteBuffer bbd = ByteBuffer.allocateDirect(mixedBytes.length - 2);
|
||||||
|
if (!enc.reset()
|
||||||
|
.encode(CharBuffer.wrap(mixedStr.toCharArray()), bb, true)
|
||||||
|
.isOverflow() ||
|
||||||
|
!enc.reset()
|
||||||
|
.encode(CharBuffer.wrap(mixedStr.toCharArray()), bbd, true)
|
||||||
|
.isOverflow())
|
||||||
|
throw new RuntimeException("cp1364 failed on encode()/overflow!");
|
||||||
|
|
||||||
|
// flush() overflow
|
||||||
|
bb = ByteBuffer.allocate(mixedBytes.length - 1);
|
||||||
|
bbd = ByteBuffer.allocateDirect(mixedBytes.length - 1);
|
||||||
|
|
||||||
|
enc.reset().encode(CharBuffer.wrap(mixedStr.toCharArray()), bb, true);
|
||||||
|
enc.reset().encode(CharBuffer.wrap(mixedStr.toCharArray()), bbd, true);
|
||||||
|
|
||||||
|
if (!enc.flush(bb).isOverflow() ||
|
||||||
|
!enc.flush(bbd).isOverflow())
|
||||||
|
throw new RuntimeException("cp1364 failed on encode()/flush()/overflow!");
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user