concrete NumeralTha of Numeral = CatTha [Numeral,Digits] ** open ResTha, StringsTha, Prelude in { flags coding = utf8 ; lincat -- Numeral = {s : Str} ; Digit = {s : DForm => Str} ; Sub10 = {s : DForm => Str} ; Sub100 = {s : NForm => Str} ; Sub1000 = {s : NForm => Str} ; Sub1000000 = {s : Str} ; lin num x = x ; pot01 = mkNum nvg_s nvg_s et_s ; n2 = mkNum soog_s yii_s soog_s ; n3 = regNum saam_s ; n4 = regNum sii_s ; n5 = regNum haa_s ; n6 = regNum hok_s ; n7 = regNum cet_s ; n8 = regNum peet_s ; n9 = regNum kaaw_s ; pot0 d = d ; pot110 = {s = sip} ; pot111 = {s = table { Unit => thbind sip_s et_s ; Thousand => thbind nvg_s mvvn_s nvg_s phan_s } } ; pot1to19 d = {s = table { Unit => thbind sip_s (d.s ! After) ; Thousand => thbind nvg_s mvvn_s (d.s ! Indep) phan_s } } ; pot0as1 d = {s = \\n => thbind (d.s ! Indep) (phan ! n)} ; pot1 d = {s = \\n => thbind (d.s ! ModTen) (sip ! n)} ; pot1plus d e = { s = \\n => thbind (d.s ! ModTen) (sip ! n) (e.s ! After) (phan ! n) } ; pot1as2 n = n ; pot2 d = {s = \\n => thbind (d.s ! Indep) (roy ! n)} ; pot2plus d e = {s = \\n => thbind (d.s ! Indep) (roy ! n) (e.s ! n)} ; pot2as3 n = {s = n.s ! Unit} ; pot3 n = {s = n.s ! Thousand} ; pot3plus n m = {s = thbind (n.s ! Thousand) (m.s ! Unit)} ; param DForm = Indep | ModTen | After ; NForm = Unit | Thousand ; oper mkNum : Str -> Str -> Str -> {s : DForm => Str} = \x,y,z -> {s = table {Indep => x ; ModTen => y ; After => z}} ; regNum : Str -> {s : DForm => Str} = \x -> mkNum x x x ; sip = table {Unit => sip_s ; Thousand => mvvn_s} ; roy = table {Unit => rooy_s ; Thousand => seen_s} ; phan = table {Unit => [] ; Thousand => phan_s} ; -- numerals as sequences of digits lincat Dig = SS ; lin IDig d = d ; IIDig d i = thbind d i ; D_0 = ss "๐" ; D_1 = ss "๑" ; D_2 = ss "๒" ; D_3 = ss "๓" ; D_4 = ss "๔" ; D_5 = ss "๕" ; D_6 = ss "๖" ; D_7 = ss "๗" ; D_8 = ss "๘" ; D_9 = ss "๙" ; }