<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE supplementalData SYSTEM "../../common/dtd/ldmlSupplemental.dtd">
<!-- Copyright © 1991-2015 Unicode, Inc.
CLDR data files are interpreted according to the LDML specification (http://unicode.org/reports/tr35/)
For terms of use, see http://www.unicode.org/copyright.html -->
<supplementalData>
	<version number="$Revision: 12347 $" />
	<transforms>
		<transform source="my" target="my_FONIPA" direction="forward" alias="my-fonipa-t-my">
			<tRule><![CDATA[

# Pronunciation rules for Burmese.
#
# The following rules are lexical and heuristic: lexical in the sense
# that they generate phoneme strings which may further undergo
# post-lexical phonological processes, in particular voicing, to
# result in actual surface forms; heuristic in the sense that they try
# to resolve ambiguities, especially around reduced vowels, in a
# systematic way that may be incorrect in many situations. Vowel
# reduction depends on many factors, such as morphemic structure,
# which are not available here.

#
# Definitions
#

# Dependent vowel signs
$vs_AA = \u102B;
$vs_aa = \u102C;
$vs_i = \u102D;
$vs_ii = \u102E;
$vs_u = \u102F;
$vs_uu = \u1030;
$vs_e = \u1031;
$vs_ai = \u1032;

# Various signs
$anusvara = \u1036;
$visarga = \u1038;
$virama = \u1039;
$asat = \u103A;

# Dependent (medial) consonant signs
$med_y = \u103B;
$med_r = \u103C;
$med_w = \u103D;
$med_h = \u103E;

# Independent letters and letter-like punctuation symbols
$independent = [\u1000-\u102A \u103F \u104C-\u104F \u1050-\u1055];

$creaky = \u0330;
$high = \u0301;
$low = \u0300;
$coda = [$creaky $high $low ɴ ʔ ə];  # TODO: remove if unused

#
# Preprocessing
#

::NFC;

# Replace U+102B TALL AA with U+102C AA. Their pronunciation is identical.
$vs_AA → $vs_aa;

# Unstack kinzi (င် plus U+1039 VIRAMA) into plain င်.
# Hmm, what would happen if the syllable ending in kinzi had non-low tone?
င် $virama → င်;

# Unstack everything else, i.e. replace U+1039 VIRAMA with U+103A ASAT.
$virama → $asat;

# Unstack U+103F GREAT SA.
ဿ → သ်သ;

# Insert a syllable boundary marker /./ before every independent letter.
::Null;
[^.$] { } $independent ([\u1037\u103B-\u103E])* [^\u103A] → \.;

# Insert default inherent vowel: /a̰/ at the end, /ə/ everywhere else.
::Null;
([\u1000-\u1021\u103F] [\u103B-\u103E]*) } [$] → $1 a $creaky;
([\u1000-\u1021\u103F] [\u103B-\u103E]*) } \.  → $1 ə;

# Allow for additional coda consonants.
#
# This only covers a few of the cases in which full coda consonants
# can appear in loanwords. The general situation is somewhat rare and
# is more easily dealt with in a formalism that can impose structural
# constraints on syllables more easily.
::Null;
$asat ($visarga)? [\u1000-\u102A] { $asat → ;

# Deal with ၎င်း early.
၎င်း → lə\.ɡa $high ʊ̯ɴ;

#
# Rhymes
#

::Null;

က် → ɛʔ;

ဂ် → ɛʔ;  # in မဂ္ဂဇင်း ~ မဂ်ဂဇင်း /mɛʔ.ɡə.zɪ́ɴ/

င့် → ɪ $creaky ɴ;
င်း → ɪ $high ɴ;
င် → ɪ $low ɴ;

စ် → ɪʔ;  # maybe sometimes /eɪ̯ʔ/

ဉ့် → ɪ $creaky ɴ;
ဉ်း → ɪ $high ɴ;
ဉ် → ɪ $low ɴ;

ည့် → ɛ $creaky;
ည်း → ɛ $high;
ည် → ɛ $low;

ဏ့် → a $creaky ɴ;
ဏ်း → a $high ɴ;
ဏ် → a $low ɴ;

တ် → aʔ;

န့် → a $creaky ɴ;
န်း → a $high ɴ;
န် → a $low ɴ;

ပ် → aʔ;

မ့် → a $creaky ɴ;
မ်း → a $high ɴ;
မ် → a $low ɴ;

ယ့် → ɛ $creaky;
ယ်း → ɛ $high;
ယ် → ɛ $low;

သ် → aʔ;

$vs_aa ဉ့် → ɪ $creaky ɴ;
$vs_aa ဉ်း → ɪ $high ɴ;
$vs_aa ဉ် → ɪ $low ɴ;
$vs_aa တ် → aʔ;
$vs_aa ဏ့် → a $creaky ɴ;
$vs_aa ဏ်း → a $high ɴ;
$vs_aa ဏ် → a $low ɴ;
$vs_aa န့် → a $creaky ɴ;
$vs_aa န်း → a $high ɴ;
$vs_aa န် → a $low ɴ;
$vs_aa ပ် → aʔ;  # in ကလာပ်စည်း /kə.laʔ.sɛ́/ (club cell)
$vs_aa ယ့် → ɛ $creaky;
$vs_aa ယ်း → ɛ $high;
$vs_aa ယ် → ɛ $low;
$vs_aa ့ → a $creaky;  # redundant creaky tone
$vs_aa း → a $high;
$vs_aa → a $low;

$vs_i က် → eɪ̯ʔ;
$vs_i စ် → eɪ̯ʔ;
$vs_i တ် → eɪ̯ʔ;
$vs_i န့် → e $creaky ɪ̯ɴ;
$vs_i န်း → e $high ɪ̯ɴ;
$vs_i န် → e $low ɪ̯ɴ;
$vs_i ပ် → eɪ̯ʔ;
$vs_i မ့် → e $creaky ɪ̯ɴ;
$vs_i မ်း → e $high ɪ̯ɴ;
$vs_i မ် → e $low ɪ̯ɴ;
$vs_i $vs_u က် → aɪ̯ʔ;
$vs_i $vs_u င့် → a $creaky ɪ̯ɴ;
$vs_i $vs_u င်း → a $high ɪ̯ɴ;
$vs_i $vs_u င် → a $low ɪ̯ɴ;
$vs_i $vs_u ဏ့် → a $creaky ɪ̯ɴ;
$vs_i $vs_u ဏ်း → a $high ɪ̯ɴ;
$vs_i $vs_u ဏ် → a $low ɪ̯ɴ;
$vs_i $vs_u ယ့် → o $creaky;
$vs_i $vs_u ယ်း → o $high;
$vs_i $vs_u ယ် → o $low;  # in ကိုယ် /kò/
$vs_i $vs_u ့ → o $creaky;
$vs_i $vs_u း → o $high;
$vs_i $vs_u → o $low;
$vs_i $anusvara ့ → e $creaky ɪ̯ɴ;
$vs_i $anusvara း → e $high ɪ̯ɴ;
$vs_i $anusvara → e $low ɪ̯ɴ;
$vs_i → i $creaky;

$vs_ii ့ → i $creaky;  # this does not usually occur
$vs_ii း → i $high;
$vs_ii → i $low;

$vs_u က် → oʊ̯ʔ;
$vs_u ဂ် → oʊ̯ʔ;
$vs_u ဏ့် → o $creaky ʊ̯ɴ;
$vs_u ဏ်း → o $high ʊ̯ɴ;
$vs_u ဏ် → o $low ʊ̯ɴ;
$vs_u တ် → oʊ̯ʔ;
$vs_u န့် → o $creaky ʊ̯ɴ;
$vs_u န်း → o $high ʊ̯ɴ;
$vs_u န် → o $low ʊ̯ɴ;
$vs_u ပ် → oʊ̯ʔ;
$vs_u မ့် → o $creaky ʊ̯ɴ;
$vs_u မ်း → o $high ʊ̯ɴ;
$vs_u မ် → o $low ʊ̯ɴ;
$vs_u $anusvara ့ → o $creaky ʊ̯ɴ;
$vs_u $anusvara း → o $high ʊ̯ɴ;
$vs_u $anusvara → o $low ʊ̯ɴ;
$vs_u → u $creaky;

$vs_uu ့ → u $creaky;  # this does not usually occur
$vs_uu း → u $high;
$vs_uu → u $low;

$vs_e တ် → ɪʔ;
$vs_e $vs_aa က် → aʊ̯ʔ;
$vs_e $vs_aa င့် → a $creaky ʊ̯ɴ;
$vs_e $vs_aa င်း → a $high ʊ̯ɴ;
$vs_e $vs_aa င် → a $low ʊ̯ɴ;
$vs_e $vs_aa ့ → ɔ $creaky;
$vs_e $vs_aa း → ɔ $high;  # redundant high tone; this does not usually occur
$vs_e $vs_aa ် → ɔ $low;
$vs_e $vs_aa → ɔ $high;
$vs_e ့ → e $creaky;
$vs_e း → e $high;
$vs_e → e $low;

$vs_ai ့ → ɛ $creaky;
$vs_ai း → ɛ $high;  # redundant high tone; this does not usually occur
$vs_ai → ɛ $high;

$anusvara ့ → a $creaky ɴ;
$anusvara း → a $high ɴ;
$anusvara → a $low ɴ;

$med_w တ် → ʊʔ;
$med_w န့် → ʊ $creaky ɴ;
$med_w န်း → ʊ $high ɴ;
$med_w န် → ʊ $low ɴ;
$med_w ပ် → ʊʔ;
$med_w မ့် → ʊ $creaky ɴ;
$med_w မ်း → ʊ $high ɴ;
$med_w မ် → ʊ $low ɴ;

#
# Medials
#

::Null;

# Palatalization of the velar stops before MEDIAL YA and MEDIAL RA:
# velar + /j/ ==> modern palatals.

ကျ → t͡ɕ;
ချ → t͡ɕʰ;
ဂျ → d͡ʑ;
ဃျ → d͡ʑ;

ကြ → t͡ɕ;
ခြ → t͡ɕʰ;
ဂြ → d͡ʑ;
ဃြ → d͡ʑ;

# Remove redundant MEDIAL YA and MEDIAL RA after initial YA.
ယ { [$med_y $med_r] → ;

# Reorder the medials so that U+103E SIGN MEDIAL HA comes before any
# other medials.

# First, push U+103E MEDIAL HA before U+103D MEDIAL WA.
\u103D \u103E → \u103E \u103D;
::Null;
# Now MEDIAL WA comes last.

# Produce the palatal ʃ from (SA|LA)+YA+HA.
သျှ → ʃ;
လျှ → ʃ;

# Second, push U+103E MEDIAL HA before U+103C MEDIAL RA.
\u103C \u103E → \u103E \u103C;
::Null;

# Finally, push U+103E MEDIAL HA before U+103B MEDIAL YA.
\u103B \u103E → \u103E \u103B;
::Null;

# Consume MEDIAL HA and apply devoicing.

ငှ → ŋ̊;
ဉှ → ɲ̥;
ညှ → ɲ̥;
ဏှ → n̥;
နှ → n̥;
မှ → m̥;
ယှ → ʃ;
ရှ → ʃ;
လှ → l̥;
ဝှ → w̥;
ဠှ → l̥;

# Drop any remaining U+103E MEDIAL HA.
\u103E → ;

# Simplify medial cluster /jw/ to /w/, i.e. drop U+103B MEDIAL YA and
# U+103C MEDIAL RA before U+103D MEDIAL WA.  # TODO: revisit this
\u103B } \u103D → ;
\u103C } \u103D → ;

\u103B → j;
\u103C → j;
\u103D → w;

#
# Initials
#

# Velars
က → k;
ခ → kʰ;
ဂ → ɡ;
ဃ → ɡ;
င → ŋ;

# Historic palatals
စ → s;
ဆ → sʰ;
ဇ → z;
ဈ → z;
ဉ → ɲ;
ည → ɲ;

# Alveolars
ဋ → t;
ဌ → tʰ;
ဍ → d;
ဎ → d;
ဏ → n;

# Historic dentals ==> alveolars
တ → t;
ထ → tʰ;
ဒ → d;
ဓ → d;
န → n;

# Labials
ပ → p;
ဖ → pʰ;
ဗ → b;
ဘ → b;
မ → m;

# Other letters
ယ → j;
ရ → j;  # historic /r/
လ် → ;  # final, typically not pronounced in native words
လ → l;
ဝ → w;
သ → θ;  # historic /s/ ==> modern dental
ဟ → h;
ဠ → l;
အ → ʔ;

# Independent vowels

ဣ့ → ʔḭ;  # redundant creaky tone; this does not usually occur
ဣး → ʔí;  # this does not usually occur
ဣ → ʔḭ;

ဤ့ → ʔḭ;  # this does not usually occur
ဤး → ʔí;  # this does not usually occur
ဤ → ʔì;

ဥ့ → ʔṵ;  # redundant creaky tone; this does not usually occur
ဥး → ʔú;  # this does not usually occur
ဥ → ʔṵ;

ဦ့ → ʔṵ;  # this does not usually occur
ဦး → ʔú;
ဦ → ʔù;

ဧ့ → ʔḛ;  # this does not usually occur
ဧး → ʔé;
ဧ → ʔè;

ဩ့ → ʔɔ̰;  # this does not usually occur
ဩး → ʔɔ́;  # redundant high tone; this does not usually occur
ဩ → ʔɔ́;

ဪ့ → ʔɔ̰;  # this does not usually occur
ဪး → ʔɔ́;  # this does not usually occur
ဪ → ʔɔ̀;

# Various signs

၌ → n̥aɪ̯ʔ;
၍ → jwḛ;
# ၎င်း was handled earlier.
၏ → ʔḭ;

#
# Postprocessing
#

# Delete any remaining U+103A ASAT.
$asat → ;

# Delete zero-width space, non-joiner, joiner.
[\u200B-\u200D] → ;

::NFC;

			]]></tRule>
		</transform>
	</transforms>
</supplementalData>