/*
* Copyright (c) 2006, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
package sun.nio.cs.ext;
import java.nio.ByteBuffer;
import java.nio.charset.Charset;
import java.nio.charset.CharsetDecoder;
import java.nio.charset.CharsetEncoder;
import java.nio.charset.CoderResult;
// EBCDIC DBCS-only Korean
public class IBM834
extends Charset
{
public IBM834() {
super("x-IBM834", ExtendedCharsets.aliasesFor("x-IBM834"));
}
public boolean contains(Charset cs) {
return (cs instanceof IBM834);
}
public CharsetDecoder newDecoder() {
return new Decoder(this);
}
public CharsetEncoder newEncoder() {
return new Encoder(this);
}
protected static class Decoder extends DBCS_ONLY_IBM_EBCDIC_Decoder {
public Decoder(Charset cs) {
super(cs);
super.mask1 = 0xFFF0;
super.mask2 = 0x000F;
super.shift = 4;
super.index1 = IBM933.getDecoderIndex1();
super.index2 = IBM933.getDecoderIndex2();
}
}
protected static class Encoder extends IBM933.Encoder {
public Encoder(Charset cs) {
super(cs, new byte[] {(byte)0xfe, (byte)0xfe}, false);
}
protected CoderResult implFlush(ByteBuffer out) {
implReset();
return CoderResult.UNDERFLOW;
}
protected byte[] encodeHangul(char ch) {
byte[] bytes = super.encodeHangul(ch);
if (bytes.length == 0) {
// Cp834 has 6 additional non-roundtrip char->bytes
// mappings, see#6379808
if (ch == '\u00b7') {
return new byte[] {(byte)0x41, (byte)0x43 };
} else if (ch == '\u00ad') {
return new byte[] {(byte)0x41, (byte)0x48 };
} else if (ch == '\u2015') {
return new byte[] {(byte)0x41, (byte)0x49 };
} else if (ch == '\u223c') {
return new byte[] {(byte)0x42, (byte)0xa1 };
} else if (ch == '\uff5e') {
return new byte[] {(byte)0x49, (byte)0x54 };
} else if (ch == '\u2299') {
return new byte[] {(byte)0x49, (byte)0x6f };
}
} else if (bytes[0] == 0) {
return EMPTYBA;
}
return bytes;
}
public boolean canEncode(char ch) {
return encodeHangul(ch).length != 0;
}
public boolean isLegalReplacement(byte[] repl) {
if (repl.length == 2 &&
repl[0] == (byte)0xfe && repl[1] == (byte)0xfe)
return true;
return super.isLegalReplacement(repl);
}
}
}