; THDL Phonetics rules for WylieWord.

; File format: there are two sections, for rules and exceptions.
;
; There is one rule per line.  Typically a rule has two parts,
; separated by a space.  The first part is a sequence of letters
; that, if it appears in a Wylie transliteration, is to be replaced
; by the second part in the phonetic transcription.  The second
; part can be missing, in which case the first part is simply 
; deleted from transcriptions when found.  
;
; A semicolon precedes a comment.  Blank lines are OK.
;
; The rules are applied in the order they appear in this file.
; Each rule is applied as many times as possible, but we never
; go back to a previous rule.  (This simple rewrite-rule grammar is
; not sufficient to implement all phonetic schemes, at least not
; compactly.  For example, it would be difficult to capture the
; effects of preinitial consonants on tone (as in the scheme used
; in Joe Wilson's book, for instance).)  Also note that not even the
; whole of the present scheme is implemented using these rules.  For
; example, the deletion of prefix and superscript consonants, 
; and of wa-zur, are done in program code, not using the rules here.

; This makes e come out � only when the last letter in a "word" (*not*
; syllable).  Our grammar engine is not nearly powerful enough to do
; this in a clean way.
<?Enable THDL final � kludge?>

; Another thing that is handled kludgily.
<?Enable nasalization before a-chung?>

; Miscellaneous prefix transformations
g.      ; delete this (representing g prefix, used before root y only)
dby y   ; must come before db->w, for dbyang
dbr r   ; must come before db->w, for dbral
db w    ; must come before by->j

; Removal of confusing 'h's
th t
ph p
tsh ts

; c and ch are both transcribed ch.  To get this we need a kludge
; (involving x), because the rule c -> ch would apply recursively.
ch c
c x
x ch

; Bad behavior from Y
py ch
phy ch
by j
my ny

; Retroflexes
kr tr
khr tr
gr dr
pr tr
phr tr
br dr

; Other bad behavior from R
mr m
sr s

; Uniquely random case
zl d

; Umlaut of a, o, u followed by d, n, l, s, and 'i
; Note: this must be done before suffix-stripping.
; Before actually doing the umlaut, we "hide" the n in ng, so that ng doesn't
;   induce umlaut.  This is gross; if we had a real grammar engine it wouldn't
;   be necessary.
ng x
ad e
an en
al el
as e
a'i e
od �
on �n
ol �l
os �
o'i �
ud �
un �n
ul �l
us �
u'i �
; restore ng
x ng

; Stripping of 'i from e'i 
; (It is stripped from a, o, u by umlaut rules, and from i by vowel-doubling rule.)
e'i e

; Stripping of suffix d,  s, and ' from i and e
; Note: this has already been done by the umlaut rules for some cases, 
;       which don't need to be repeated here.
id i
ed e
is i
es e
a' a
e' e
i' i
o' o
u' u

; Remove doubled vowels (e.g. pa'ang -> pang, not paang)
aa a
ee e
ii i
oo o
uu u

; Devoicing of suffix g, b
ag ak
eg ek
ig ik
og ok
ug uk
ab ap
eb ep
ib ip
ob op
ub up

<?Exceptions?>

; There is one exception per line.  Each exception consists of
; the transliteration (which may be several syllables separated
; by spaces), followed by a space, a greater-than, a space, and the
; pronunciation (which may also contain spaces).  A semicolon 
; precedes a comment.  Blank lines are OK.

; Exceptions to nasalization rule:
skyabs 'gro > kyamdro
rten 'brel > tendrel
lam 'bras > lamdr�

; Other exceptions:
sprul sku > tulku
rta mgrin > tamdrin
a mdo > amdo
chab mdo > chamdo
dpal ldan > penden
'bri ru > biru
sbra nag zhol > banakzh�l
rdo rje > dorj�
o rgyan > orgyen
lha rje > lharj�
rgyal rtse > gyants�