Files
gf-core/lib/src/chinese/NumeralChi.gf
hallgren 72459b5158 lib/src/*/Numeral*.gf: fix inconsistent inheritance form Cat
While the abstract Numeral inherits only Cat[Numeral,Digits], some of the
concrete NumeralNNN of Numeral inherited everything from CatNNN.

Normally the compiler outputs a warning message when a concrete syntax 
contains superflous lincats, but apparently not when they get included
through inheritance...

This does not seem to cause problems in the Haskell run-time system, but the 
C run-time system fails to load PGFs with superflous lincats.

This problems shows up when creating application grammars that inherit Numeral.
The Phrasebook is an example of such a grammar.
2015-08-26 11:53:16 +00:00

164 lines
4.7 KiB
Plaintext

concrete NumeralChi of Numeral = CatChi [Numeral,Digits] ** open ResChi, Prelude in {
flags coding = utf8 ;
param Qform = bai | bai0 | shiwan | shiwan0 ;
param Bform = shi | shi0 | wan | wan0 ;
param Zero = zero | nozero ;
oper ling : Zero * Zero => Str =
table {<zero,z> => "零" ;
<z,zero> => "零" ;
<nozero,nozero> => []} ;
oper Wan : Zero => Str =
table {zero => "万" ;
nozero => []} ;
oper mkD : Str -> Str -> Str = \x,_ -> word x ; -- hiding the "formal" version
lincat Digit = {s,p : Str} ; -- s/p: without/with classifier (er/liang)
lincat Sub10 = {s,p,t : Str} ; -- t: with "shi wan"
lincat Sub100 = {end0,beg0 : Zero ; s,p : Bform => Str} ; -- end0: ends with zeros, e.g. 20 ; beg0: begins with zeros, e.g. 02
lincat Sub1000 = {end0,beg0 : Zero ; s,p : Qform => Str} ; -- end0: ends with zeros, e.g. 210 ; beg0: begins with zeros, e.g. 021
lincat Sub1000000 = {s,p : Str} ;
lin num x0 = x0 ;
-- 一二三四五六七八九十一百千
--
lin n2 =
{s = mkD "二" "贰" ; p = "两"} ;
lin n3 =
{s,p = mkD "三" "叁"} ;
lin n4 =
{s,p = mkD "四" "肆"} ;
lin n5 =
{s,p = mkD "五" "伍"} ;
lin n6 =
{s,p = mkD "六" "陆"} ;
lin n7 =
{s,p = mkD "七" "柒"} ;
lin n8 =
{s,p = mkD "八" "捌"} ;
lin n9 =
{s,p = mkD "九" "玖"} ;
lin pot01 =
{s,p = mkD "一" "壹" ; t = []} ; -- t used in "(*yi) shi wan"
lin pot0 d =
{s,t = d.s ; p = d.p} ;
lin pot110 =
{beg0 = nozero ; end0 = zero ;
s,p = table {
shi => mkD "十" "拾" ;
shi0 => mkD "一十" "壹拾" ;
wan => mkD "一万" "壹万" ;
wan0 => mkD "一万" "壹万"
}} ;
lin pot111 =
{beg0 = nozero ; end0 = nozero ;
s,p = table {
shi => mkD "十一" "拾壹" ;
shi0 => mkD "一十一" "壹拾壹" ;
wan => mkD "一万一千" "壹万壹千" ; -- 11.16 by chenpeng wan => mkD "十一万" "拾壹万" ;
wan0 => mkD "一万一千" "壹万壹千"
}} ; -- 11.16 by chenpeng wan0 => mkD "十一万" "拾壹万"}} ;
lin pot1to19 d =
{beg0 = nozero ; end0 = nozero ;
s,p = table {
shi => mkD "十" "壹拾" ++ d.s ;
shi0 => mkD "一十" "壹拾" ++ d.s ;
wan => mkD "一万" "壹万" ++ d.s ++ mkD "千" "仟" ;
wan0 => mkD "一万" "壹万" ++ d.s ++ mkD "千" "仟"
}} ;
lin pot0as1 n =
{beg0 = zero ; end0 = nozero ;
s = table {
shi => n.s ;
shi0 => n.s ;
wan => n.p ++ mkD "千" "仟" ;
wan0 => n.p ++ mkD "千" "仟"
} ;
p = table {
shi => n.p ;
shi0 => n.s ;
wan => n.p ++ mkD "千" "仟" ;
wan0 => n.p ++ mkD "千" "仟"
}
} ;
lin pot1 d =
{beg0 = nozero ; end0 = zero ; -- inh = nozero ;
s,p = table {
shi => d.s ++ mkD "十" "拾" ;
shi0 => d.s ++ mkD "十" "拾" ;
wan0 => (d.p | d.s) ++ "万" ;
wan => (d.p | d.s) ++ "万"
}} ;
lin pot1plus d e =
{beg0 = nozero ; end0 = nozero ; -- inh = nozero ;
s,p = table {
shi => d.s ++ mkD "十" "拾" ++ e.s ;
shi0 => d.s ++ mkD "十" "拾" ++ e.s ;
wan => (d.p | d.s) ++ "万" ++ e.s ++ mkD "千" "仟" ;
wan0 => (d.p | d.s) ++ "万" ++ e.s ++ mkD "千" "仟"
}} ;
lin pot1as2 n =
{beg0 = zero ; end0 = n.end0 ; -- inh = zero ;
s = table {
bai => n.s ! shi ;
bai0 => n.s ! shi0 ;
shiwan => n.s ! wan ;
shiwan0 => n.s ! wan0
} ;
p = table {
bai => n.p ! shi ;
bai0 => n.s ! shi0 ;
shiwan => n.s ! wan ;
shiwan0 => n.s ! wan0
}} ;
lin pot2 d =
{beg0 = nozero ; end0 = zero ; -- inh = zero ;
s,p = table {
bai => (d.p | d.s) ++ mkD "百" "佰" ;
bai0 => (d.p | d.s) ++ mkD "百" "佰" ;
shiwan0 => d.t ++ mkD "十万" "拾万" ;
shiwan => d.t ++ mkD "十万" "拾万"
}} ;
lin pot2plus d e =
{beg0 = nozero ; end0 = e.end0 ; -- inh = nozero ;
s,p = table {
bai => (d.p | d.s) ++ mkD "百" "佰" ++ (ling ! <nozero,e.beg0>) ++ e.s ! shi0 ; --why omit "百"? i add it /chenpeng
bai0 => (d.p | d.s) ++ mkD "百" "佰" ++ (ling ! <nozero,e.beg0>) ++ e.s ! shi0 ; --why omit "百"? i add it /chenpeng
shiwan => d.t ++ mkD "十" "拾" ++ (Wan ! (e.end0)) ++ e.s ! wan ; --why omit "十"? i add it /chenpeng
shiwan0 => d.t ++ mkD "十" "拾" ++ (Wan ! (e.end0)) ++ e.s ! wan0
}} ;--why omit "十"? i add it /chenpeng
lin pot2as3 n =
{s = n.s ! bai ; p = n.p ! bai} ;
lin pot3 n =
{s,p = n.s ! shiwan} ;
lin pot3plus n m =
{s,p = (n.s ! shiwan0) ++ (ling ! <n.end0,m.beg0>) ++ m.s ! bai0} ;
-- numerals as sequences of digits
lincat
Dig = SS ;
lin
IDig d = d ;
IIDig d i = ss (d.s ++ i.s) ;
D_0 = ss "0" ;
D_1 = ss "1" ;
D_2 = ss "2" ;
D_3 = ss "3" ;
D_4 = ss "4" ;
D_5 = ss "5" ;
D_6 = ss "6" ;
D_7 = ss "7" ;
D_8 = ss "8" ;
D_9 = ss "9" ;
}