1# © 2016 and later: Unicode, Inc. and others. 2# License & terms of use: http://www.unicode.org/copyright.html 3# Generated using tools/cldr/cldr-to-icu/build-icu-data.xml 4# 5# File: Latin_ConjoiningJamo.txt 6# Generated from CLDR 7# 8 9# Follows the Ministry of Culture and Tourism romanization: see http://www.korea.net/korea/kor_loca.asp?code=A020303 10# http://www.unicode.org/cldr/transliteration_guidelines.html#Korean 11#- N.B. DO NOT put any filters, NFD, etc. here -- those are aliased in 12#- the INDEX file. This transliterator is, by itself, not 13#- instantiated. It is used as a part of Latin-Jamo, Latin-Hangul, or 14#- inverses thereof. 15# Transliteration from Latin characters to Korean script is done in 16# two steps: Latin to Jamo, then Jamo to Hangul. The Jamo-Hangul 17# transliteration is done algorithmically following Unicode 3.0 18# section 3.11. This file implements the Latin to Jamo 19# transliteration using rules. 20# Jamo occupy the block 1100-11FF. Within this block there are three 21# groups of characters: initial consonants or choseong (I), medial 22# vowels or jungseong (M), and trailing consonants or jongseong (F). 23# Standard Korean syllables are of the form I+M+F*. 24# Section 3.11 describes the use of 'filler' jamo to convert 25# nonstandard syllables to standard form: the choseong filler 115F and 26# the junseong filler 1160. In this transliterator, we will not use 27# 115F or 1160. 28# We will, however, insert two 'null' jamo to make foreign words 29# conform to Korean syllable structure. These are the null initial 30# consonant 110B (IEUNG) and the null vowel 1173 (EU). In Latin text, 31# we will use the separator in order to disambiguate strings, 32# e.g. "kan-ggan" (initial GG) vs. "kanggan" (final NG + initial G). 33# We will not use all of the characters in the jamo block. We will 34# only use the 19 initials, 21 medials, and 27 finals possessing a 35# jamo short name as defined in section 4.4 of the Unicode book. 36# Rules of thumb. These guidelines provide the basic framework 37# for the rules. They are phrased in terms of Latin-Jamo transliteration. 38# The Jamo-Latin rules derive from these, since the Jamo-Latin rules are 39# just context-free transliteration of jamo to corresponding short names, 40# with the addition of separators to maintain round-trip integrity 41# in the context of the Latin-Jamo rules. 42# A sequence of vowels: 43# - Take the longest sequence you can. If there are too many, or you don't 44# have a starting consonant, introduce a 110B necessary. 45# A sequence of consonants. 46# - First join the double consonants: G + G -→ GG 47# - In the remaining list, 48# -- If there is no preceding vowel, take the first consonant, and insert EU 49# after it. Continue with the rest of the consonants. 50# -- If there is one consonant, attach to the following vowel 51# -- If there are two consonants and a following vowel, attach one to the 52# preceding vowel, and one to the following vowel. 53# -- If there are more than two consonants, join the first two together if you 54# can: L + G =→ LG 55# -- If you still end up with more than 2 consonants, insert EU after the 56# first one, and continue with the rest of the consonants. 57#---------------------------------------------------------------------- 58# Variables 59# Some latin consonants or consonant pairs only occur as initials, and 60# some only as finals, but some occur as both. This makes some jamo 61# consonants ambiguous when transliterated into latin. 62# Initial only: IEUNG BB DD JJ R 63# Final only: BS GS L LB LG LH LM LP LS LT NG NH NJ 64# Initial and Final: B C D G GG H J K M N P S SS T 65$Gi = ᄀ; 66$KKi = ᄁ; 67$Ni = ᄂ; 68$Di = ᄃ; 69$TTi = ᄄ; 70$Li = ᄅ; 71$Mi = ᄆ; 72$Bi = ᄇ; 73$PPi = ᄈ; 74$Si = ᄉ; 75$SSi = ᄊ; 76$IEUNG = ᄋ; # null initial, inserted during Latin-Jamo 77$Ji = ᄌ; 78$JJi = ᄍ; 79$CHi = ᄎ; 80$Ki = ᄏ; 81$Ti = ᄐ; 82$Pi = ᄑ; 83$Hi = ᄒ; 84$A = ᅡ; 85$AE = ᅢ; 86$YA = ᅣ; 87$YAE = ᅤ; 88$EO = ᅥ; 89$E = ᅦ; 90$YEO = ᅧ; 91$YE = ᅨ; 92$O = ᅩ; 93$WA = ᅪ; 94$WAE = ᅫ; 95$OE = ᅬ; 96$YO = ᅭ; 97$U = ᅮ; 98$WO = ᅯ; 99$WE = ᅰ; 100$WI = ᅱ; 101$YU = ᅲ; 102$EU = ᅳ; # null medial, inserted during Latin-Jamo 103$UI = ᅴ; 104$I = ᅵ; 105$Gf = ᆨ; 106$GGf = ᆩ; 107$GS = ᆪ; 108$Nf = ᆫ; 109$NJ = ᆬ; 110$NH = ᆭ; 111$Df = ᆮ; 112$L = ᆯ; 113$LG = ᆰ; 114$LM = ᆱ; 115$LB = ᆲ; 116$LS = ᆳ; 117$LT = ᆴ; 118$LP = ᆵ; 119$LH = ᆶ; 120$Mf = ᆷ; 121$Bf = ᆸ; 122$BS = ᆹ; 123$Sf = ᆺ; 124$SSf = ᆻ; 125$NG = ᆼ; 126$Jf = ᆽ; 127$Cf = ᆾ; 128$Kf = ᆿ; 129$Tf = ᇀ; 130$Pf = ᇁ; 131$Hf = ᇂ; 132$jamoInitial = [ᄀ-ᄒ]; 133$jamoMedial = [ᅡ-ᅵ]; 134$latinInitial = [bcdghjklmnprst]; 135# Any character in the latin transliteration of a medial 136$latinMedial = [aeiouwy]; 137# The last character of the latin transliteration of a medial 138$latinMedialEnd = [aeiou]; 139# Disambiguation separator 140$sep = \-; 141#---------------------------------------------------------------------- 142# Jamo-Latin 143# 144# Jamo to latin is relatively simple, since it is the latin that is 145# ambiguous. Most rules are straightforward, and we encode them below 146# as simple add-on back rule, e.g.: 147# $jamoMedial {bs} → $BS; 148# becomes 149# $jamoMedial {bs} ↔ $BS; 150# 151# Furthermore, we don't care about the ordering for Jamo-Latin because 152# we are going from single characters, so we can very easily piggyback 153# on the Latin-Jamo. 154# 155# The main issue with Jamo-Latin is when to insert separators. 156# Separators are inserted to obtain correct round trip behavior. For 157# example, the sequence Ki A Gf Gi E, if transliterated to "kagge", 158# would then round trip to Ki A GGi E. To prevent this, we insert a 159# separator: "kag-ge". IMPORTANT: The need for separators depends 160# very specifically on the behavior of the Latin-Jamo rules. A change 161# in the Latin-Jamo behavior can completely change the way the 162# separator insertion must be done. 163# First try to preserve actual separators in the jamo text by doubling 164# them. This fixes problems like: 165# (Di)(A)(Ji)(U)(NG)-(IEUNG)(YEO)(Nf)(Gi)(YEO)(L) =→ dajung-yeongyeol 166# =→ (Di)(A)(Ji)(U)(NG)(IEUNG)(YEO)(Nf)(Gi)(YEO)(L). This is optional 167# -- if we don't care about losing separators in the jamo, we can delete 168# this rule. 169$sep $sep ↔ $sep; 170# Triple consonants. For three consonants "axxx" we insert a 171# separator between the first and second "x" if XXf, Xf, and Xi all 172# exist, and we have A Xf XXi. This prevents the reverse 173# transliteration to A XXf Xi. 174$sep ← $latinMedialEnd s {} $SSi; 175# For vowels the rule is similar. If there is a vowel "ae" such that 176# "a" by itself and "e" by itself are vowels, then we want to map A E 177# to "a-e" so as not to round trip to AE. However, in the text Ki EO 178# IEUNG E we don't need to map to "keo-e". "keoe" suffices. For 179# vowels of the form "aei", both "ae" + "i" and "a" + "ei" must be 180# tested. NOTE: These rules used to have a left context of 181# $latinInitial instead of [^$latinMedial]. The problem with this is 182# sequences where an initial IEUNG is transliterated away: 183# (IEUNG)(A)(IEUNG)(EO) =→ aeo =→ (IEUNG)(AE)(IEUNG)(O) 184# Also problems in cases like gayeo, which needs to be gaye-o 185# The hard case is a chain, like aeoeu. Normally interpreted as ae oe u. So for a-eoeu, we have to insert $sep 186# But, we don't insert between the o and the e. 187# 188# a ae 189# e eo eu 190# i 191# o oe 192# u 193# ui 194# wa wae we wi 195# yae ya yeo ye yo yu 196# These are simple, since they can't chain. Note that we don't handle extreme cases like [ga][eo][e][o] 197$sep ← a {} [$E $EO $EU]; 198$sep ← [^aow] e {} [$O $OE]; 199$sep ← [^aowy] e {} [$U $UI]; 200$sep ← [^ey] o {} [$E $EO $EU]; 201$sep ← [^y] u {} [$I]; 202# Similar to the above, but with an intervening $IEUNG. 203$sep ← [^$latinMedial] [y] e {} $IEUNG [$O $OE]; 204$sep ← [^$latinMedial] e {} $IEUNG [$O $OE $U]; 205$sep ← [^$latinMedial] [o a] {} $IEUNG [$E $EO $EU]; 206$sep ← [^$latinMedial] [w y] a {} $IEUNG [$E $EO $EU]; 207# Single finals followed by IEUNG. The jamo sequence A Xf IEUNG E, 208# where Xi also exists, must be transliterated as "ax-e" to prevent 209# the round trip conversion to A Xi E. 210$sep ← $latinMedialEnd b {} $IEUNG $jamoMedial; 211$sep ← $latinMedialEnd d {} $IEUNG $jamoMedial; 212$sep ← $latinMedialEnd g {} $IEUNG $jamoMedial; 213$sep ← $latinMedialEnd h {} $IEUNG $jamoMedial; 214$sep ← $latinMedialEnd j {} $IEUNG $jamoMedial; 215$sep ← $latinMedialEnd k {} $IEUNG $jamoMedial; 216$sep ← $latinMedialEnd m {} $IEUNG $jamoMedial; 217$sep ← $latinMedialEnd n {} $IEUNG $jamoMedial; 218$sep ← $latinMedialEnd p {} $IEUNG $jamoMedial; 219$sep ← $latinMedialEnd s {} $IEUNG $jamoMedial; 220$sep ← $latinMedialEnd t {} $IEUNG $jamoMedial; 221$sep ← $latinMedialEnd l {} $IEUNG $jamoMedial; 222# Double finals followed by IEUNG. Similar to the single finals 223# followed by IEUNG. Any latin consonant pair X Y, between medials, 224# that we would split by Latin-Jamo, we must handle when it occurs as 225# part of A XYf IEUNG E, to prevent round trip conversion to A Xf Yi E 226$sep ← $latinMedialEnd b s {} $IEUNG $jamoMedial; 227$sep ← $latinMedialEnd k k {} $IEUNG $jamoMedial; 228$sep ← $latinMedialEnd g s {} $IEUNG $jamoMedial; 229$sep ← $latinMedialEnd l b {} $IEUNG $jamoMedial; 230$sep ← $latinMedialEnd l g {} $IEUNG $jamoMedial; 231$sep ← $latinMedialEnd l h {} $IEUNG $jamoMedial; 232$sep ← $latinMedialEnd l m {} $IEUNG $jamoMedial; 233$sep ← $latinMedialEnd l p {} $IEUNG $jamoMedial; 234$sep ← $latinMedialEnd l s {} $IEUNG $jamoMedial; 235$sep ← $latinMedialEnd l t {} $IEUNG $jamoMedial; 236$sep ← $latinMedialEnd n g {} $IEUNG $jamoMedial; 237$sep ← $latinMedialEnd n h {} $IEUNG $jamoMedial; 238$sep ← $latinMedialEnd n j {} $IEUNG $jamoMedial; 239$sep ← $latinMedialEnd s s {} $IEUNG $jamoMedial; 240$sep ← $latinMedialEnd ch {} $IEUNG $jamoMedial; 241# Split doubles. Text of the form A Xi Xf E, where XXi also occurs, 242# we transliterate as "ax-xe" to prevent round trip transliteration as 243# A XXi E. 244$sep ← $latinMedialEnd j {} $Ji $jamoMedial; 245$sep ← $latinMedialEnd k {} $Ki $jamoMedial; 246$sep ← $latinMedialEnd s {} $Si $jamoMedial; 247# XYY. This corresponds to the XYY rule in Latin-Jamo. By default 248# Latin-Jamo maps "xyy" to Xf YYi, to keep YY together. As a result, 249# "xyy" forms that correspond to XYf Yi must be transliterated as 250# "xy-y". 251$sep ← $latinMedialEnd b s {} [$Si $SSi]; 252$sep ← $latinMedialEnd g s {} [$Si $SSi]; 253$sep ← $latinMedialEnd l b {} [$Bi]; 254$sep ← $latinMedialEnd l g {} [$Gi]; 255$sep ← $latinMedialEnd l s {} [$Si $SSi]; 256$sep ← $latinMedialEnd n g {} [$Gi]; 257$sep ← $latinMedialEnd n j {} [$Ji $JJi]; 258# $sep ← $latinMedialEnd l {} [$PPi]; 259# $sep ← $latinMedialEnd l {} [$TTi]; 260$sep ← $latinMedialEnd l p {} [$Pi]; 261$sep ← $latinMedialEnd l t {} [$Ti]; 262$sep ← $latinMedialEnd k {} [$KKi $Ki]; 263$sep ← $latinMedialEnd p {} $Pi; 264$sep ← $latinMedialEnd t {} $Ti; 265$sep ← $latinMedialEnd c {} [$Hi]; 266# Deletion of IEUNG is handled below. 267#---------------------------------------------------------------------- 268# Latin-Jamo 269# [Basic, context-free Jamo-Latin rules are embedded here too. See 270# above.] 271# Split digraphs: Text of the form 'axye', where 'xy' is a final 272# digraph, 'x' is a final (by itself), 'y' is an initial, and 'a' and 273# 'e' are medials, we want to transliterate this as A Xf Yi E rather 274# than A XYf IEUNG E. We do NOT include text of the form "axxe", 275# since that is handled differently below. These rules are generated 276# programmatically from the jamo data. 277$jamoMedial {b s} $latinMedial → $Bf $Si; 278$jamoMedial {g s} $latinMedial → $Gf $Si; 279$jamoMedial {l b} $latinMedial → $L $Bi; 280$jamoMedial {l g} $latinMedial → $L $Gi; 281$jamoMedial {l h} $latinMedial → $L $Hi; 282$jamoMedial {l m} $latinMedial → $L $Mi; 283$jamoMedial {l p} $latinMedial → $L $Pi; 284$jamoMedial {l s} $latinMedial → $L $Si; 285$jamoMedial {l t} $latinMedial → $L $Ti; 286$jamoMedial {n g} $latinMedial → $Nf $Gi; 287$jamoMedial {n h} $latinMedial → $Nf $Hi; 288$jamoMedial {n j} $latinMedial → $Nf $Ji; 289# Single consonants are initials: Text of the form 'axe', where 'x' 290# can be an initial or a final, and 'a' and 'e' are medials, we want 291# to transliterate as A Xi E rather than A Xf IEUNG E. 292$jamoMedial {b} $latinMedial → $Bi; 293$jamoMedial {ch} $latinMedial → $CHi; 294$jamoMedial {d} $latinMedial → $Di; 295$jamoMedial {g} $latinMedial → $Gi; 296$jamoMedial {h} $latinMedial → $Hi; 297$jamoMedial {j} $latinMedial → $Ji; 298$jamoMedial {k} $latinMedial → $Ki; 299$jamoMedial {m} $latinMedial → $Mi; 300$jamoMedial {n} $latinMedial → $Ni; 301$jamoMedial {p} $latinMedial → $Pi; 302$jamoMedial {s} $latinMedial → $Si; 303$jamoMedial {t} $latinMedial → $Ti; 304$jamoMedial {l} $latinMedial → $Li; 305# Doubled initials. The sequence "axxe", where XX exists as an initial 306# (XXi), and also Xi and Xf exist (true of all digraphs XX), we want 307# to transliterate as A XXi E, rather than split to A Xf Xi E. 308$jamoMedial {p p} $latinMedial → $PPi; 309$jamoMedial {t t} $latinMedial → $TTi; 310$jamoMedial {j j} $latinMedial → $JJi; 311$jamoMedial {k k} $latinMedial → $KKi; 312$jamoMedial {s s} $latinMedial → $SSi; 313# XYY. Because doubled consonants bind more strongly than XY 314# consonants, we must handle the sequence "axyy" specially. Here XYf 315# and YYi must exist. In these cases, we map to Xf YYi rather than 316# XYf. 317# However, there are two special cases. 318$jamoMedial {lp} p p → $LP; 319$jamoMedial {lt} t t → $LT; 320# End special cases 321$jamoMedial {b} s s → $Bf; 322$jamoMedial {g} s s → $Gf; 323$jamoMedial {l} b b → $L; 324$jamoMedial {l} g g → $L; 325$jamoMedial {l} s s → $L; 326$jamoMedial {l} t t → $L; 327$jamoMedial {l} p p → $L; 328$jamoMedial {n} g g → $Nf; 329$jamoMedial {n} j j → $Nf; 330# Finals: Attach consonant with preceding medial to preceding medial. 331# Do this BEFORE mapping consonants to initials. Longer keys must 332# precede shorter keys that they start with, e.g., the rule for 'bs' 333# must precede 'b'. 334# [BASIC Jamo-Latin FINALS handled here. Order irrelevant within this 335# block for Jamo-Latin.] 336$jamoMedial {bs} ↔ $BS; 337$jamoMedial {b} ↔ $Bf; 338$jamoMedial {ch} ↔ $Cf; 339$jamoMedial {c} → $Cf; 340$jamoMedial {d} ↔ $Df; 341$jamoMedial {kk} ↔ $GGf; 342$jamoMedial {gs} ↔ $GS; 343$jamoMedial {g} ↔ $Gf; 344$jamoMedial {h} ↔ $Hf; 345$jamoMedial {j} ↔ $Jf; 346$jamoMedial {k} ↔ $Kf; 347$jamoMedial {lb} ↔ $LB; $jamoMedial {lg} ↔ $LG; 348$jamoMedial {lh} ↔ $LH; 349$jamoMedial {lm} ↔ $LM; 350$jamoMedial {lp} ↔ $LP; 351$jamoMedial {ls} ↔ $LS; 352$jamoMedial {lt} ↔ $LT; 353$jamoMedial {l} ↔ $L; 354$jamoMedial {m} ↔ $Mf; 355$jamoMedial {ng} ↔ $NG; 356$jamoMedial {nh} ↔ $NH; 357$jamoMedial {nj} ↔ $NJ; 358$jamoMedial {n} ↔ $Nf; 359$jamoMedial {p} ↔ $Pf; 360$jamoMedial {ss} ↔ $SSf; 361$jamoMedial {s} ↔ $Sf; 362$jamoMedial {t} ↔ $Tf; 363# Initials: Attach single consonant to following medial. Do this 364# AFTER mapping finals. Longer keys must precede shorter keys that 365# they start with, e.g., the rule for 'gg' must precede 'g'. 366# [BASIC Jamo-Latin INITIALS handled here. Order irrelevant within 367# this block for Jamo-Latin.] 368{kk} $latinMedial ↔ $KKi; 369{g} $latinMedial ↔ $Gi; 370{n} $latinMedial ↔ $Ni; 371{tt} $latinMedial ↔ $TTi; 372{d} $latinMedial ↔ $Di; 373{l} $latinMedial ↔ $Li; 374{m} $latinMedial ↔ $Mi; 375{pp} $latinMedial ↔ $PPi; 376{b} $latinMedial ↔ $Bi; 377{ss} $latinMedial ↔ $SSi; 378{s} $latinMedial ↔ $Si; 379{jj} $latinMedial ↔ $JJi; 380{j} $latinMedial ↔ $Ji; 381{ch} $latinMedial ↔ $CHi; 382{c} $latinMedial → $CHi; 383{k} $latinMedial ↔ $Ki; 384{t} $latinMedial ↔ $Ti; 385{p} $latinMedial ↔ $Pi; 386{h} $latinMedial ↔ $Hi; 387# 'r' in final position. Because of the equivalency of the 'l' and 388# 'r' jamo (the glyphs are the same), we try to provide the same 389# equivalency in Latin-Jamo. The 'l' to 'r' conversion is handled 390# below. If we see an 'r' in an apparent final position, treat it 391# like 'l'. For example, "karka" =→ Ki A R EU Ki A without this rule. 392# Instead, we want Ki A L Ki A. 393# Initial + Final: If we match the next rule, we have initial then 394# final consonant with no intervening medial. We insert the null 395# vowel BEFORE it to create a well-formed syllable. (In the next rule 396# we insert a null vowel AFTER an anomalous initial.) 397# Initial + X: This block matches an initial consonant not followed by 398# a medial. We insert the null vowel after it. We handle double 399# initials explicitly here; for single initial consonants we insert EU 400# (as Latin) after them and let standard rules do the rest. 401# BREAKS ROUND TRIP INTEGRITY 402kk → $KKi $EU; 403tt → $TTi $EU; 404pp → $PPi $EU; 405ss → $SSi $EU; 406jj → $JJi $EU; 407ch → $CHi $EU; 408([lbdghjkmnpst]) → | $1 eu; 409# X + Final: Finally we have to deal with a consonant that can only be 410# interpreted as a final (not an initial) and which is preceded 411# neither by an initial nor a medial. It is the start of the 412# syllable, but cannot be. Most of these will already be handled by 413# the above rules. 'bs' splits into Bi EU Sf. Similar for 'gs' 'ng' 414# 'nh' 'nj'. The only problem is 'l' and digraphs starting with 'l'. 415# For this isolated case, we could add a null initial and medial, 416# which would give "la" =→ IEUNG EU L IEUNG A, for example. A more 417# economical solution is to transliterate isolated "l" (that is, 418# initial "l") to "r". (Other similar conversions of consonants that 419# occur neither as initials nor as finals are handled below.) 420l → | r; 421# Medials. If a medial is preceded by an initial, then we proceed 422# normally. As usual, longer keys must precede shorter ones. 423# [BASIC Jamo-Latin MEDIALS handled here. Order irrelevant within 424# this block for Jamo-Latin.] 425# 426# a e i o u 427# ae 428# eo eu 429# oe 430# ui 431# wa we wi 432# wae 433# yae ya yeo ye yo yu 434$jamoInitial {ae} ↔ $AE; 435$jamoInitial {a} ↔ $A; 436$jamoInitial {eo} ↔ $EO; 437$jamoInitial {eu} ↔ $EU; 438$jamoInitial {e} ↔ $E; 439$jamoInitial {i} ↔ $I; 440$jamoInitial {oe} ↔ $OE; 441$jamoInitial {o} ↔ $O; 442$jamoInitial {ui} ↔ $UI; 443$jamoInitial {u} ↔ $U; 444$jamoInitial {wae} ↔ $WAE; 445$jamoInitial {wa} ↔ $WA; 446$jamoInitial {wo} ↔ $WO; 447$jamoInitial {we} ↔ $WE; 448$jamoInitial {wi} ↔ $WI; 449$jamoInitial {yae} ↔ $YAE; 450$jamoInitial {ya} ↔ $YA; 451$jamoInitial {yeo} ↔ $YEO; 452$jamoInitial {ye} ↔ $YE; 453$jamoInitial {yo} ↔ $YO; 454$jamoInitial {yu} ↔ $YU; 455# We may see an anomalous isolated 'w' or 'y'. In that case, we 456# interpret it as 'wi' and 'yu', respectively. 457# BREAKS ROUND TRIP INTEGRITY 458$jamoInitial {w} → | wi; 459$jamoInitial {y} → | yu; 460# Otherwise, insert a null consonant IEUNG before the medial (which is 461# still an untransliterated latin vowel). 462($latinMedial) → $IEUNG | $1; 463# Convert non-jamo latin consonants to equivalents. These occur as 464# neither initials nor finals in jamo. 'l' occurs as a final, but not 465# an initial; it is handled above. The following letters (left hand 466# side) will never be output by Jamo-Latin. 467f → | p; 468q → | k; 469v → | b; 470x → | ks; 471z → | s; 472r → | l; 473c → | k; 474# Delete separators (Latin-Jamo). 475$sep → ; 476# Delete null consonants (Jamo-Latin). Do NOT delete null EU vowels, 477# since these may also occur in text. 478← $IEUNG; 479#- N.B. DO NOT put any filters, NFD, etc. here -- those are aliased in 480#- the INDEX file. This transliterator is, by itself, not 481#- instantiated. It is used as a part of Latin-Jamo, Latin-Hangul, or 482#- inverses thereof. 483# eof 484 485