summaryrefslogtreecommitdiff
path: root/examples/letter/letter.Eng.gf
diff options
context:
space:
mode:
authoraarne <unknown>2004-01-29 12:03:23 +0000
committeraarne <unknown>2004-01-29 12:03:23 +0000
commitfdddeca0d08ba68b564b14359ef9b4a697cdb636 (patch)
tree711b817c905f33b5e196582183c3d4bc7d757b40 /examples/letter/letter.Eng.gf
parent4c31deb83940be8e6ff3775013aec5da593c4d7a (diff)
Improving unicode menus, e.g. in Letter.
Diffstat (limited to 'examples/letter/letter.Eng.gf')
-rw-r--r--examples/letter/letter.Eng.gf151
1 files changed, 151 insertions, 0 deletions
diff --git a/examples/letter/letter.Eng.gf b/examples/letter/letter.Eng.gf
new file mode 100644
index 000000000..195caf8c7
--- /dev/null
+++ b/examples/letter/letter.Eng.gf
@@ -0,0 +1,151 @@
+--1 An English Concrete Syntax for Business and Love Letters
+--
+-- This file defines the English syntax of the grammar set
+-- whose abstract syntax is $letter.Abs.gf$.
+
+include letter.Abs.gf ;
+
+flags lexer=textlit ; unlexer=textlit ;
+
+param Sex = masc | fem ;
+param Num = sg | pl ;
+param Kas = nom | acc ;
+param DepNum = depnum | cnum Num ;
+
+lintype SS = {s : Str} ;
+lintype SSDep = {s : Num => Sex => Str} ; -- needs Num and Sex
+lintype SSSrc = {s : Str ; n : Num ; x : Sex} ; -- gives Num and Sex
+lintype SSSrc2 = {s : Num => Sex => Str ; n : DepNum ; x : Sex} ; -- gives and needs
+lintype SSDep2 = {s : DepNum => Sex => Num => Sex => Str} ; -- needs Auth's & Recp's
+lintype SSSrcNum = {s : Str ; n : Num} ; -- gives Num only
+
+
+oper
+ ss : Str -> SS = \s -> {s = s} ;
+ constNX : Str -> Num -> Sex -> SSSrc2 = \str,num,sex ->
+ {s = table {_ => table {_ => str}} ; n = cnum num ; x = sex} ;
+
+ dep2num : DepNum -> Num -> Num = \dn,n -> case dn of {
+ depnum => n ;
+ cnum cn => cn
+ } ;
+
+lincat
+Letter = SS ;
+Recipient = SSSrc ;
+Author = SSSrc2 ;
+Message = SSDep2 ;
+Heading = SSSrc ;
+Ending = SSSrc2 ;
+Mode = SSDep2 ;
+Sentence = SSDep2 ;
+NounPhrase = SSSrcNum ;
+Position = SSDep ;
+
+lin
+MkLetter head mess end =
+ ss (head.s ++ "," ++ "<p>" ++
+ mess.s ! end.n ! end.x ! head.n ! head.x ++ "." ++ "<p>" ++
+ end.s ! head.n ! head.x) ;
+
+DearRec rec = {s = "Dear" ++ rec.s ; n = rec.n ; x = rec.x} ;
+PlainRec rec = rec ;
+HelloRec rec = {s = "Hello" ++ rec.s ; n = rec.n ; x = rec.x} ;
+JustHello rec = {s = "Hello" ; n = rec.n ; x = rec.x} ;
+
+ModeSent mode sent =
+ {s =
+ table {dna => table {xa => table {nr => table {xr =>
+ mode.s ! dna ! xa ! nr ! xr ++ sent.s ! dna ! xa ! nr ! xr}}}}
+ } ;
+PlainSent sent = sent ;
+
+FormalEnding auth =
+ {s = table {n => table {x =>
+ ["Sincerely yours <p>"] ++ auth.s ! n ! x}} ; n = auth.n ; x = auth.x} ;
+InformalEnding auth =
+ {s = table {n => table {x =>
+ ["With best regards <p>"] ++ auth.s ! n ! x}} ; n = auth.n ; x = auth.x} ;
+
+ColleaguesHe = {s = kollega ! pl ; n = pl ; x = masc} ;
+ColleaguesShe = {s = kollega ! pl ; n = pl ; x = fem} ;
+ColleagueHe = {s = kollega ! sg ; n = sg ; x = masc} ;
+ColleagueShe = {s = kollega ! sg ; n = sg ; x = fem} ;
+DarlingHe = {s = "darling" ; n = sg ; x = masc} ;
+DarlingShe = {s = "darling" ; n = sg ; x = fem} ;
+NameHe s = {s = s.s ; n = sg ; x = masc} ;
+NameShe s = {s = s.s ; n = sg ; x = fem} ;
+
+
+Honour = {s =
+ table {dna => table {xa => table {nr => table {xr =>
+ let {na = dep2num dna nr} in
+ ego ! na ! nom ++ ["have the honour to inform you that"]}}}}
+ } ;
+
+Regret = {s =
+ table {dna => table {xa => table {nr => table {xr =>
+ let {na = dep2num dna nr} in
+ ego ! na ! nom ++ am ! na ++ ["sorry to inform you that"]}}}}
+ } ;
+
+
+President = constNX ["the President"] sg masc ;
+Mother = constNX "Mom" sg fem ;
+Spouse = {s = table {
+ sg => table {fem => ["your husband"] ; masc => ["your wife"]} ;
+ pl => table {fem => ["your husbands"] ; masc => ["your wives"]}
+ } ; n = depnum ; x = masc} ; -- sex does not matter here
+Dean = constNX ["the Dean"] sg masc ;
+Name s = constNX s.s sg masc ; ---
+
+BePromoted pos = {s =
+ table {na => table {xa => table {nr => table {xr =>
+ ["you have been promoted to"] ++
+ pos.s ! nr ! xr}}}}
+ } ;
+GoBankrupt np = {s =
+ table {na => table {xa => table {nr => table {xr =>
+ np.s ++ have ! np.n ++ ["gone bankrupt"]}}}}
+ } ;
+ILoveYou = {s =
+ table {na => table {xa => table {nr => table {xr =>
+ ego ! dep2num na nr ! nom ++ ["love you"]}}}}
+ } ;
+
+Company = {s = ["our company"] ; n = sg} ;
+Competitor = {s = ["our worst competitor"] ; n = sg} ;
+OurCustomers = {s = ["our customers"] ; n = pl} ;
+
+Senior = {s =
+ table {
+ sg => table {x => ["a senior fellow"]} ;
+ pl => table {x => ["senior fellows"]}
+ }} ;
+ProjectManager = {s =
+ table {
+ sg => table {_ => ["a project manager"]} ;
+ pl => table {_ => ["project managers"]}
+ }} ;
+
+oper
+
+kollega :
+ Num => Str =
+ table {sg => "colleague" ; pl => "colleagues"} ;
+
+am :
+ Num => Str =
+ table {sg => "am" ; pl => "are"} ;
+
+have :
+ Num => Str =
+ table {sg => "has" ; pl => "have"} ;
+
+ego :
+ Num => Kas => Str =
+ table {
+ sg => table {nom => "I" ; acc => "me"} ;
+ pl => table {nom => "we" ; acc => "us"}
+ } ;
+