NAME
Lingua::KO::Hangul::Util - utility functions for Hangul Syllables
SYNOPSIS
use Lingua::KO::Hangul::Util;
decomposeHangul(0xAC00);
# (0x1100,0x1161) or "\x{1100}\x{1161}"
composeHangul("\x{1100}\x{1161}");
# "\x{AC00}"
getHangulName(0xAC00);
# "HANGUL SYLLABLE GA"
parseHangulName("HANGUL SYLLABLE GA");
# 0xAC00
DESCRIPTION
A Hangul Syllable consists of Hangul Jamo.
Hangul Jamo are classified into three classes:
CHOSEONG (the initial sound) as a leading consonant (L),
JUNGSEONG (the medial sound) as a vowel (V),
JONGSEONG (the final sound) as a trailing consonant (T).
Any Hangul Syllable is a composition of
i) CHOSEONG + JUNGSEONG (L + V)
or
ii) CHOSEONG + JUNGSEONG + JONGSEONG (L + V + T).
Names of Hangul Syllables have a format of "HANGUL SYLLABLE %s"
.
Composition and Decomposition
$string_decomposed = decomposeHangul($code_point)
@codepoints = decomposeHangul($code_point)
-
If the specified code point is of a Hangul Syllable, returns a list of code points (in a list context) or a UTF-8 string (in a scalar context) of its decomposition.
decomposeHangul(0xAC00) # U+AC00 is HANGUL SYLLABLE GA. returns "\x{1100}\x{1161}" or (0x1100, 0x1161); decomposeHangul(0xAE00) # U+AE00 is HANGUL SYLLABLE GEUL. returns "\x{1100}\x{1173}\x{11AF}" or (0x1100, 0x1173, 0x11AF);
Otherwise, returns false (empty string or empty list).
decomposeHangul(0x0041) # outside Hangul Syllables returns empty string or empty list.
$string_composed = composeHangul($src_string)
@code_points_composed = composeHangul($src_string)
-
Any sequence of an initial Jamo
L
and a medial JamoV
is composed to a syllableLV
; then any sequence of a syllableLV
and a final JamoT
is composed to a syllableLVT
.Any characters other than Hangul Jamo and Hangul Syllables are unaffected.
composeHangul("Hangul \x{1100}\x{1161}\x{1100}\x{1173}\x{11AF}.") returns "Hangul \x{AC00}\x{AE00}." or (0x48,0x61,0x6E,0x67,0x75,0x6C,0x20,0xAC00,0xAE00,0x2E);
$code_point_composite = getHangulComposite($code_point_here, $code_point_next)
-
Return the codepoint of the composite if both two code points,
$code_point_here
and$code_point_next
, are in Hangul, and composable.Otherwise, returns
undef
.
Hangul Syllable Name
$name = getHangulName($code_point)
-
If the specified code point is of a Hangul Syllable, returns its name; otherwise returns undef.
getHangulName(0xAC00) returns "HANGUL SYLLABLE GA"; getHangulName(0x0041) returns undef.
$codepoint = parseHangulName($name)
-
If the specified name is of a Hangul Syllable, returns its code point; otherwise returns undef.
parseHangulName("HANGUL SYLLABLE GEUL") returns 0xAE00; parseHangulName("LATIN SMALL LETTER A") returns undef; parseHangulName("HANGUL SYLLABLE PERL") returns undef; # Regrettably, HANGUL SYLLABLE PERL does not exist :-)
EXPORT
By default,
decomposeHangul
composeHangul
getHangulName
parseHangulName
getHangulComposite
AUTHOR
SADAHIRO Tomoyuki
bqw10602@nifty.com
http://homepage1.nifty.com/nomenclator/perl/
Copyright(C) 2001-2002, SADAHIRO Tomoyuki. Japan. All rights reserved.
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.