summaryrefslogtreecommitdiff
path: root/examples/foods/FoodsHeb.gf
blob: b68b383be9f99263a5f5c1d693881aa48543a98c (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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

--(c) 2009 Dana Dannells
-- Licensed under LGPL

concrete FoodsHeb of Foods = open Prelude in {
  
  flags coding=utf8 ;

    lincat
      Comment = SS ;
      Quality = {s: Number => Species => Gender =>  Str} ;  
      Kind = {s : Number => Species => Str ; g : Gender ; mod : Modified} ; 
      Item = {s : Str ; g : Gender ; n : Number ; sp : Species ; mod : Modified} ; 
  
 
    lin
      Pred item quality = ss (item.s ++ quality.s ! item.n ! Indef ! item.g ) ; 
      This  = det Sg Def "הזה" "הזאת"; 
      That  = det Sg Def "ההוא" "ההיא" ; 
      These = det Pl Def "האלה" "האלה" ; 
      Those = det Pl Def "ההם" "ההן" ; 
      Mod quality kind = {
	s = \\n,sp => kind.s ! n ! sp ++ quality.s ! n ! sp ! kind.g;
	g = kind.g ;
	mod = T
	} ;     
      Wine = regNoun "יין" "יינות" Masc ; 
      Cheese = regNoun "גבינה" "גבינות" Fem ;  
      Fish = regNoun "דג" "דגים" Masc ; 
      Pizza = regNoun "פיצה" "פיצות" Fem ; 
      Very qual = {s = \\g,n,sp => "מאוד" ++  qual.s ! g ! n ! sp} ;
      Fresh = regAdj "טרי" ; 
      Warm = regAdj "חם" ;
      Italian = regAdj2 "איטלקי" ;
      Expensive = regAdj "יקר" ; 
      Delicious = regAdj "טעים" ; 
      Boring = regAdj2 "משעמם"; 

    param 
      Number = Sg | Pl ;
      Gender = Masc | Fem ;
      Species = Def | Indef ;  
      Modified = T | F ;

    oper
	Noun : Type = {s : Number => Species => Str ; g : Gender ; mod : Modified } ;
  	Adj : Type = {s : Number => Species => Gender => Str} ;

      det : Number -> Species -> Str -> Str -> Noun -> 
	{s : Str ; g :Gender ; n : Number ; sp : Species ; mod : Modified} = 
        \n,sp,m,f,cn -> {
	  s = case cn.mod of { _ => cn.s ! n ! sp ++ case cn.g of {Masc => m ; Fem  => f} };
	  g = cn.g ; 
          n = n ;
	  sp = sp ;
	  mod = cn.mod
        } ;
      
	noun : (gvina,hagvina,gvinot,hagvinot : Str) ->  Gender -> Noun =  
      		\gvina,hagvina,gvinot,hagvinot,g -> {
        	s = table {
          		Sg  => table {
             			Indef => gvina ;
             			Def =>  hagvina 
            		} ;
          		Pl => table {
             			Indef => gvinot ;
             			Def => hagvinot  
            		} 
       	  	} ;
        	g = g ;
		mod = F 
      } ;

	regNoun : Str -> Str -> Gender -> Noun = 
	        \gvina,gvinot, g -> 
		noun gvina (defH gvina) gvinot (defH gvinot) g ; 

      defH : Str -> Str = \cn ->
	case cn of {_ => "ה" + cn};	

      replaceLastLetter : Str -> Str = \c ->
	 case c of {"ף" => "פ" ; "ם" => "מ" ; "ן" => "נ" ; "ץ" => "צ" ; "ך" => "כ"; _ => c} ;
	      
      adjective : (_,_,_,_ : Str) -> Adj = 
       \tov,tova,tovim,tovot -> {
        s = table {
          Sg => table { 
			Indef => table { Masc => tov ; Fem => tova } ; 
			Def => table { Masc => defH tov ; Fem => defH tova }  
            		} ; 
          Pl => table { 
			Indef => table {Masc => tovim ; Fem  => tovot } ; 
			Def => table { Masc => defH tovim ; Fem  => defH tovot }  
            		}
	}
      } ;
    
      regAdj : Str -> Adj = \tov ->
	case tov of { to + c@? =>
	adjective tov (to + replaceLastLetter (c) + "ה" ) (to + replaceLastLetter (c) +"ים" ) (to + replaceLastLetter (c) + "ות" )};	 
     
     regAdj2 : Str -> Adj = \italki ->
 	case italki of { italk+ c@? => 
    adjective italki (italk + replaceLastLetter (c)  +"ת" )  (italk + replaceLastLetter (c)+ "ים" ) (italk + replaceLastLetter (c)  + "ות" )};

}  -- FoodsHeb