// Tests conversion of 8-byte decomposed Hangul from EUC-KR (and variants) // to Unicode, including invalid input load('CharsetConversionTests.js'); load('hangulTestStrings.js'); const aliases = [ "euc-kr", "EUC-KR", "iso-ir-149", "ks_c_5601-1989", "ksc_5601", "ksc5601", "korean", "csksc56011987", "windows-949", "ks_c_5601-1987", "cseuckr"]; function to8byteHangul(byte3, byte5, byte7) { return String.fromCharCode(0xa4, 0xd4, 0xa4, byte3, 0xa4, byte5, 0xa4, byte7); } function run_test() { var converter = CreateScriptableConverter(); for (var i = 0; i < aliases.length; ++i) { var row = 0; for (var byte3 = 0xa0; byte3 < 0xc0; ++byte3) { for (var byte5 = 0xbe; byte5 < 0xd5; ++byte5) { var inString = " row " + byte3.toString(16) + "_" + byte5.toString(16) + "_: "; for (var byte7 = 0xa0; byte7 < 0xc0; ++byte7) { inString += to8byteHangul(byte3, byte5, byte7) + " "; } inString += to8byteHangul(byte3, byte5, 0xd4) + " "; checkDecode(converter, aliases[i], inString, expectedStrings[row++]); } } do_check_eq(row, expectedStrings.length); } }