summaryrefslogtreecommitdiff
path: root/next-lib/src/german/QuestionGer.gf
diff options
context:
space:
mode:
authoraarne <aarne@cs.chalmers.se>2008-09-22 12:24:28 +0000
committeraarne <aarne@cs.chalmers.se>2008-09-22 12:24:28 +0000
commit766852a64c9816f073100ff720cf7bafab39c043 (patch)
tree8aedd62fb0d8b24d84f2640087b2e958c1ced043 /next-lib/src/german/QuestionGer.gf
parent69b96e87ee361b1f95b8de566ef98c3789c53705 (diff)
adapted German to 1.5
Diffstat (limited to 'next-lib/src/german/QuestionGer.gf')
-rw-r--r--next-lib/src/german/QuestionGer.gf101
1 files changed, 101 insertions, 0 deletions
diff --git a/next-lib/src/german/QuestionGer.gf b/next-lib/src/german/QuestionGer.gf
new file mode 100644
index 000000000..d94742c5f
--- /dev/null
+++ b/next-lib/src/german/QuestionGer.gf
@@ -0,0 +1,101 @@
+concrete QuestionGer of Question = CatGer ** open ResGer in {
+
+ flags optimize=all_subs ;
+
+ lin
+
+ QuestCl cl = {
+ s = \\m,t,a,p =>
+ let cls = cl.s ! m ! t ! a ! p
+ in table {
+ QDir => cls ! Inv ;
+ QIndir => "ob" ++ cls ! Sub
+ }
+ } ;
+
+ QuestVP qp vp = {
+ s = \\m,t,a,b,q =>
+ let
+ cl = (mkClause (qp.s ! Nom) (agrP3 qp.n) vp).s ! m ! t ! a ! b
+ in
+ case q of {
+ QIndir => cl ! Sub ;
+ _ => cl ! Main
+ }
+ } ;
+
+ QuestSlash ip slash = {
+ s = \\m,t,a,p =>
+ let
+ cls = slash.s ! m ! t ! a ! p ;
+ who = appPrep slash.c2 ip.s
+ in table {
+ QDir => who ++ cls ! Inv ;
+ QIndir => who ++ cls ! Sub
+ }
+ } ;
+
+ QuestIAdv iadv cl = {
+ s = \\m,t,a,p =>
+ let
+ cls = cl.s ! m ! t ! a ! p ;
+ why = iadv.s
+ in table {
+ QDir => why ++ cls ! Inv ;
+ QIndir => why ++ cls ! Sub
+ }
+ } ;
+
+ QuestIComp icomp np = {
+ s = \\m,t,a,p =>
+ let
+ vp = predV sein_V ;
+ cls = (mkClause (np.s ! Nom) np.a vp).s ! m ! t ! a ! p ;
+ why = icomp.s ! np.a
+ in table {
+ QDir => why ++ cls ! Inv ;
+ QIndir => why ++ cls ! Sub
+ }
+ } ;
+
+ PrepIP p ip = {
+ s = appPrep p ip.s
+ } ;
+
+ AdvIP ip adv = {
+ s = \\c => ip.s ! c ++ adv.s ;
+ n = ip.n
+ } ;
+
+ IdetCN idet cn =
+ let
+ g = cn.g ;
+ n = idet.n
+ in {
+ s = \\c => idet.s ! g ! c ++ cn.s ! Weak ! n ! c ;
+ n = n
+ } ;
+
+ IdetIP idet =
+ let
+ g = Neutr ; ----
+ n = idet.n
+ in {
+ s = idet.s ! g ;
+ n = n
+ } ;
+
+ IdetQuant idet num =
+ let
+ n = num.n
+ in {
+ s = \\g,c => idet.s ! n ! g ! c ++ num.s!g!c ;
+ n = n
+ } ;
+
+ CompIAdv a = {s = \\_ => a.s} ;
+
+ CompIP ip = {s = \\_ => ip.s ! Nom} ;
+
+}
+