summaryrefslogtreecommitdiff
path: root/old-lib/resource/romance/QuestionRomance.gf
diff options
context:
space:
mode:
authoraarne <aarne@chalmers.se>2009-06-22 15:39:08 +0000
committeraarne <aarne@chalmers.se>2009-06-22 15:39:08 +0000
commite89fdae2fa1626348d8025824a7469252fa85e42 (patch)
treec7d46bbd0494043b4bd6f917a25a7687517d0547 /old-lib/resource/romance/QuestionRomance.gf
parent3049b59b35b25381a7c6787444165c200d66e08b (diff)
next-lib renamed to lib, lib to old-lib
Diffstat (limited to 'old-lib/resource/romance/QuestionRomance.gf')
-rw-r--r--old-lib/resource/romance/QuestionRomance.gf113
1 files changed, 113 insertions, 0 deletions
diff --git a/old-lib/resource/romance/QuestionRomance.gf b/old-lib/resource/romance/QuestionRomance.gf
new file mode 100644
index 000000000..6d2fa8669
--- /dev/null
+++ b/old-lib/resource/romance/QuestionRomance.gf
@@ -0,0 +1,113 @@
+incomplete concrete QuestionRomance of Question =
+ CatRomance ** open CommonRomance, ResRomance, Prelude in {
+
+ flags optimize=all_subs ;
+
+ lin
+
+ QuestCl cl = {
+ s = \\t,a,p =>
+ let cls = cl.s ! DDir ! t ! a ! p ---- DInv?
+ in table {
+ QDir => cls ! Indic ;
+ QIndir => subjIf ++ cls ! Indic
+ }
+ } ;
+
+ QuestVP qp vp = {
+ s = \\t,a,b,_ =>
+ let
+ cl = mkClause (qp.s ! Nom) False (agrP3 qp.a.g qp.a.n) vp
+ in
+ cl.s ! DDir ! t ! a ! b ! Indic
+ } ;
+
+ QuestSlash ip slash = {
+ s = \\t,a,p =>
+ let
+ cls : Direct -> Str =
+ \d -> slash.s ! ip.a ! d ! t ! a ! p ! Indic ;
+ who = slash.c2.s ++ ip.s ! slash.c2.c
+ in table {
+ QDir => who ++ cls DInv ;
+ QIndir => who ++ cls DDir
+ }
+ } ;
+
+ QuestIAdv iadv cl = {
+ s = \\t,a,p,q =>
+ let
+ ord = case q of {
+ QDir => DInv ;
+ QIndir => DDir
+ } ;
+ cls = cl.s ! ord ! t ! a ! p ! Indic ;
+ why = iadv.s
+ in why ++ cls
+ } ;
+
+ QuestIComp icomp np = {
+ s = \\t,a,p,_ =>
+ let
+ vp = predV copula ;
+ cls = (mkClause (np.s ! Aton Nom) np.hasClit np.a vp).s !
+ DInv ! t ! a ! p ! Indic ;
+ why = icomp.s ! {g = np.a.g ; n = np.a.n}
+ in why ++ cls
+ } ;
+
+ PrepIP p ip = {
+ s = p.s ++ ip.s ! p.c
+ } ;
+
+ AdvIP ip adv = {
+ s = \\c => ip.s ! c ++ adv.s ;
+ a = ip.a
+ } ;
+
+ IdetCN idet cn =
+ let
+ g = cn.g ;
+ n = idet.n ;
+ a = aagr g n
+ in {
+ s = \\c => idet.s ! g ! c ++ cn.s ! n ;
+ a = a
+ } ;
+
+ IdetIP idet =
+ let
+ g = Masc ; ---- Fem in Extra
+ n = idet.n ;
+ a = aagr g n
+ in {
+ s = \\c => idet.s ! g ! c ;
+ a = a
+ } ;
+
+ IdetQuant idet num =
+ let
+ n = num.n ;
+ in {
+ s = \\g,c => idet.s ! n ! g ! c ++ num.s ! g ;
+ n = n
+ } ;
+
+
+ CompIAdv a = {s = \\_ => a.s} ;
+
+ CompIP p = {s = \\_ => p.s ! Nom} ;
+
+}
+
+{- ---b
+ IDetCN idet num ord cn =
+ let
+ g = cn.g ;
+ n = idet.n ;
+ a = aagr g n
+ in {
+ s = \\c => idet.s ! g ! c ++ num.s ! g ++ ord.s ! a ++ cn.s ! n ;
+ a = a
+ } ;
+-}