summaryrefslogtreecommitdiff
path: root/examples/foods/FoodsPes.gf
blob: c2e631e81e7597c80b6a9a54b4734ef3dd9521fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
concrete FoodsPes of Foods = {

      flags optimize=noexpand ; coding=utf8 ;
	  
      lincat
        Comment = {s : Str} ;
		Quality = {s : Add => Str; prep : Str} ;
        Kind = {s : Add => Number => Str ; prep : Str};
        Item = {s : Str ; n : Number};
      lin
        Pred item quality = {s = item.s ++ quality.s ! Indep ++ copula ! item.n} ;
        This = det Sg "این" ;
        That = det Sg "آن" ;
        These = det Pl "این" ;
        Those = det Pl "آن" ;
        
        Mod quality kind = {s = \\a,n =>  kind.s ! Attr ! n ++ kind.prep ++ quality.s ! a ;                                  
                            prep = quality.prep             
                            };
        Wine = regN "شراب" ; 
        Cheese = regN "پنیر" ;
        Fish = regN "ماهى" ;
        Pizza = regN "پیتزا" ;
        Very a = {s = \\at => "خیلی" ++ a.s ! at ; prep = a.prep} ;
        Fresh = adj "تازه" ;
        Warm = adj "گرم" ;
        Italian = adj "ایتالیایی" ;
        Expensive = adj "گران" ;
        Delicious = adj "لذىذ" ;
        Boring = adj "ملال آور" ;  -- it must be written as ملال آور. 
     
     param
        Number = Sg | Pl ;
		Add = Indep | Attr ;
     oper
        det : Number -> Str -> {s: Add => Number => Str ; prep : Str} -> {s : Str ; n: Number} =
           \n,det,noun -> {s = det ++ noun.s ! Indep ! n ; n = n };
           
        noun : (x1,_,_,x4 : Str) -> {s : Add => Number => Str ; prep : Str} = \pytzA, pytzAy, pytzAhA,pr -> 
         {s = \\a,n => case <a,n> of
		        {<Indep,Sg> => pytzA ; <Indep,Pl> => pytzAhA ;
  				 <Attr,Sg>  =>pytzA ; <Attr,Pl>  => pytzAhA + "ى" };
		 prep = pr
		 };		 
         
        regN : Str -> {s: Add => Number => Str ; prep : Str} = \mrd -> 
		case mrd of 
		{ _ + ("ا"|"ه"|"ى"|"و"|"") => noun mrd (mrd+"ى") (mrd + "ها") "";
		  _                        => noun mrd mrd (mrd + "ها") "e"
		};
        
        adj : Str -> {s : Add => Str; prep : Str} = \tAzh -> 
		case tAzh of 
		{ _ + ("ا"|"ه"|"ى"|"و"|"") => mkAdj tAzh (tAzh ++ "ى") "" ;
		  _                        => mkAdj tAzh tAzh "ه"
        };
		
		mkAdj : Str -> Str -> Str -> {s : Add => Str; prep : Str} = \tAzh, tAzhy, pr  ->
		{s = table {Indep => tAzh;
		            Attr => tAzhy};
		 prep = pr 			
		};
        copula : Number => Str = table {Sg => "است"; Pl => "هستند"};
      
}