mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-17 16:59:34 -06:00
280 lines
10 KiB
Plaintext
280 lines
10 KiB
Plaintext
--# -path=.:../abstract:../common
|
|
|
|
incomplete concrete DocumentationEstFunctor of Documentation = CatEst ** open
|
|
Terminology, -- the interface
|
|
ResEst,
|
|
ParadigmsEst,
|
|
(G = GrammarEst),
|
|
(S = SyntaxEst),
|
|
(L = LexiconEst),
|
|
Prelude,
|
|
HTML
|
|
in {
|
|
|
|
lincat
|
|
Inflection = {t : Str; s1,s2 : Str} ;
|
|
Definition = {s : Str} ;
|
|
Document = {s : Str} ;
|
|
Tag = {s : Str} ;
|
|
|
|
{-
|
|
-} --# notpresent
|
|
|
|
oper
|
|
heading : N -> Str = \n -> (nounHeading n).s ;
|
|
|
|
lin
|
|
InflectionN, InflectionN2, InflectionN3 = \noun -> {
|
|
t = "s" ;
|
|
s1 = heading1 (heading noun_Category) ;
|
|
s2 = inflNoun (\nf -> noun.s ! nf)
|
|
} ;
|
|
|
|
InflectionA, InflectionA2 = \adj ->
|
|
let posit : (AForm => Str) = adj.s ! Posit ;
|
|
compar : (AForm => Str) = adj.s ! Compar ;
|
|
superl : (AForm => Str) = adj.s ! Superl ;
|
|
in
|
|
{ t = "a" ;
|
|
s1 = heading1 (heading adjective_Category) ;
|
|
s2 = inflNoun (\nf -> posit ! AN nf) ++
|
|
heading2 (heading comparative_Parameter) ++
|
|
inflNoun (\nf -> compar ! AN nf) ++
|
|
heading2 (heading superlative_Parameter) ++
|
|
inflNoun (\nf -> superl ! AN nf)
|
|
} ;
|
|
|
|
InflectionAdv adv = {
|
|
t = "adv" ;
|
|
s1 = heading1 (heading adverb_Category) ;
|
|
s2 = paragraph adv.s
|
|
} ;
|
|
|
|
InflectionPrep p = {
|
|
t = "prep" ;
|
|
s1 = heading1 (heading preposition_Category) ;
|
|
s2 = paragraph ((S.mkAdv (lin Prep p) S.it_NP).s ++ ";" ++ (S.mkAdv (lin Prep p) S.we_NP).s)
|
|
} ;
|
|
|
|
InflectionV v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v)) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV2 v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.something_NP)) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV3 v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.something_NP S.something_NP)) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV2V v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.we_NP (S.mkVP (L.sleep_V)))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV2S v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.we_NP (lin S (ss "...")))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV2Q v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.we_NP (lin QS (ss "...")))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionV2A v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v S.we_NP L.beautiful_A)) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionVV v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v (S.mkVP (L.sleep_V)))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionVS v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v (lin S (ss "...")))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionVQ v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v (lin QS (ss "...")))) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
InflectionVA v = {
|
|
t = "v" ;
|
|
s1 = heading1 (heading verb_Category) ++
|
|
paragraph (verbExample (S.mkCl S.she_NP v L.beautiful_A)) ;
|
|
s2 = inflVerb v
|
|
} ;
|
|
|
|
oper
|
|
verbExample : CatEst.Cl -> Str = \cl -> (S.mkUtt cl).s ;
|
|
{-
|
|
-} --# notpresent
|
|
inflVerb : CatEst.V -> Str = \verb ->
|
|
let
|
|
--verb = sverb2verbSep verb0 ;
|
|
vfin : ResEst.VForm -> Str = \f ->
|
|
verb.s ! f ;
|
|
|
|
nounNounHeading : Parameter -> Parameter -> Str = \n1,n2 ->
|
|
(S.mkUtt (G.PossNP (S.mkCN n1) (S.mkNP n2))).s ;
|
|
in
|
|
heading3 (nounNounHeading present_Parameter indicative_Parameter) ++
|
|
frameTable (
|
|
tr (th "" ++
|
|
th (heading singular_Parameter) ++
|
|
th (heading plural_Parameter)
|
|
++ th (heading passive_Parameter) --# notpresent
|
|
) ++
|
|
tr (th "1.p" ++ td (vfin (Presn Sg P1)) ++ td (vfin (Presn Pl P1))
|
|
++ intagAttr "td" "rowspan=3" (vfin (PassPresn True)) --# notpresent
|
|
) ++
|
|
tr (th "2.p" ++ td (vfin (Presn Sg P2)) ++ td (vfin (Presn Pl P2))) ++
|
|
tr (th "3.p" ++ td (vfin (Presn Sg P3)) ++ td (vfin (Presn Pl P3))) ++
|
|
tr (th (heading negative_Parameter) ++
|
|
intagAttr "td" "colspan=2 align=center" (vfin (Imper Sg)) ++ td (vfin (PassPresn False)))
|
|
) ++
|
|
heading3 (nounNounHeading past_Parameter indicative_Parameter) ++
|
|
frameTable (
|
|
tr (th "" ++
|
|
th (heading singular_Parameter) ++
|
|
th (heading plural_Parameter)
|
|
++ th (heading passive_Parameter) --# notpresent
|
|
) ++
|
|
tr (th "1.p" ++ td (vfin (Impf Sg P1)) ++ td (vfin (Impf Pl P1))
|
|
++ intagAttr "td" "rowspan=3" (vfin (PassImpf True))) ++
|
|
tr (th "2.p" ++ td (vfin (Impf Sg P2)) ++ td (vfin (Impf Pl P2))) ++
|
|
tr (th "3.p" ++ td (vfin (Impf Sg P3)) ++ td (vfin (Impf Pl P3))) ++
|
|
tr (th (heading negative_Parameter) ++
|
|
td (vfin (PastPart Act)) ++
|
|
td (vfin (PastPart Pass)) ++
|
|
td (vfin (PassImpf False)))
|
|
) ++
|
|
heading3 (nounNounHeading present_Parameter conditional_Parameter) ++
|
|
frameTable (
|
|
tr (th "" ++
|
|
th (heading singular_Parameter) ++
|
|
th (heading plural_Parameter)
|
|
++ th (heading passive_Parameter) --# notpresent
|
|
) ++
|
|
tr (th "1.p" ++ td (vfin (Condit Sg P1)) ++ td (vfin (Condit Pl P1))
|
|
++ intagAttr "td" "rowspan=3" "TODO pass condit (nt loetaks)" --# notpresent
|
|
) ++
|
|
tr (th "2.p" ++ td (vfin (Condit Sg P2)) ++ td (vfin (Condit Pl P2))) ++
|
|
tr (th "3.p" ++ td (vfin (Condit Sg P3)) ++ td (vfin (Condit Pl P3)))
|
|
) ++
|
|
heading3 (nounNounHeading present_Parameter quotative_Parameter) ++
|
|
frameTable (
|
|
tr (th "" ++
|
|
th (heading singular_Parameter) ++
|
|
th (heading plural_Parameter)
|
|
++ th (heading passive_Parameter) --# notpresent
|
|
) ++
|
|
tr (th "isik." ++ td (vfin (Quotative Act))
|
|
++ intagAttr "td" "rowspan=3" (vfin (Quotative Act)) --# notpresent
|
|
) ++
|
|
tr (th "umbis." ++ td (vfin (Quotative Pass)) ++ td (vfin (Quotative Pass))
|
|
)) ++
|
|
heading3 (nounNounHeading present_Parameter imperative_Parameter) ++
|
|
frameTable (
|
|
tr (th "" ++
|
|
th (heading singular_Parameter) ++
|
|
th (heading plural_Parameter)
|
|
++ th (heading passive_Parameter) --# notpresent
|
|
) ++
|
|
tr (th "1.p" ++ td "" ++ td (vfin ImperP1Pl) ++
|
|
intagAttr "td" "rowspan=3" (vfin ImperPass)) ++
|
|
tr (th "2.p" ++ td (vfin (Imper Sg)) ++ td (vfin (Imper Pl))) ++
|
|
tr (th "3.p" ++ td (vfin (ImperP3)) ++ td (vfin ImperP3))
|
|
) ++
|
|
heading2 (nounPluralHeading nominal_form_ParameterType).s ++
|
|
heading3 (heading infinitive_Parameter) ++
|
|
frameTable (
|
|
tr (intagAttr "th" "rowspan=2" "da" ++
|
|
th (heading nominative_Parameter) ++ td (vfin (Inf InfDa))) ++
|
|
tr (th (heading inessive_Parameter) ++ td (vfin (Inf InfDes))) ++
|
|
|
|
tr (intagAttr "th" "rowspan=5" "ma" ++
|
|
th (heading illative_Parameter) ++ td (vfin (Inf InfMa))) ++
|
|
tr (th (heading inessive_Parameter) ++ td (vfin (Inf InfMas))) ++
|
|
tr (th (heading elative_Parameter) ++ td (vfin (Inf InfMast))) ++
|
|
tr (th (heading abessive_Parameter) ++ td (vfin (Inf InfMata))) ++
|
|
tr (th (heading translative_Parameter) ++ td (vfin (Inf InfMaks)))
|
|
|
|
) ++
|
|
heading3 (heading participle_Parameter) ++
|
|
frameTable (
|
|
tr (intagAttr "th" "rowspan=2" (heading present_Parameter) ++
|
|
th (heading active_Parameter) ++
|
|
td (vfin (PresPart Act))) ++
|
|
tr (th (heading passive_Parameter) ++
|
|
td (vfin (PresPart Pass))) ++
|
|
|
|
tr (intagAttr "th" "rowspan=2" (heading perfect_Parameter) ++
|
|
th (heading active_Parameter) ++
|
|
td (vfin (PastPart Act ))) ++
|
|
|
|
tr (th (heading passive_Parameter) ++
|
|
td (vfin (PastPart Pass )))
|
|
) ; --}
|
|
|
|
inflNoun : (NForm -> Str) -> Str = \nouns ->
|
|
frameTable (
|
|
tr (th "" ++ th (heading singular_Parameter) ++ th (heading plural_Parameter) ) ++
|
|
tr (th (heading nominative_Parameter) ++ td (nouns (NCase Sg Nom)) ++ td (nouns (NCase Pl Nom))) ++
|
|
tr (th (heading genitive_Parameter) ++ td (nouns (NCase Sg Gen)) ++ td (nouns (NCase Pl Gen))) ++
|
|
tr (th (heading partitive_Parameter) ++ td (nouns (NCase Sg Part)) ++ td (nouns (NCase Pl Part))) ++
|
|
tr (th (heading translative_Parameter) ++ td (nouns (NCase Sg Transl)) ++ td (nouns (NCase Pl Transl))) ++
|
|
tr (th (heading essive_Parameter) ++ td (nouns (NCase Sg Ess)) ++ td (nouns (NCase Pl Ess))) ++
|
|
tr (th (heading inessive_Parameter) ++ td (nouns (NCase Sg Iness)) ++ td (nouns (NCase Pl Iness))) ++
|
|
tr (th (heading elative_Parameter) ++ td (nouns (NCase Sg Elat)) ++ td (nouns (NCase Pl Elat))) ++
|
|
tr (th (heading illative_Parameter) ++ td (nouns (NCase Sg Illat)) ++ td (nouns (NCase Pl Illat))) ++
|
|
tr (th (heading adessive_Parameter) ++ td (nouns (NCase Sg Adess)) ++ td (nouns (NCase Pl Adess))) ++
|
|
tr (th (heading ablative_Parameter) ++ td (nouns (NCase Sg Ablat)) ++ td (nouns (NCase Pl Ablat))) ++
|
|
tr (th (heading allative_Parameter) ++ td (nouns (NCase Sg Allat)) ++ td (nouns (NCase Pl Allat))) ++
|
|
tr (th (heading abessive_Parameter) ++ td (nouns (NCase Sg Abess)) ++ td (nouns (NCase Pl Abess))) ++
|
|
tr (th (heading comitative_Parameter) ++ td (nouns (NCase Sg Comit)) ++ td (nouns (NCase Pl Comit))) ++
|
|
tr (th (heading instructive_Parameter) ++ td (nouns (NCase Sg Termin)) ++ td (nouns (NCase Pl Termin))
|
|
)) ;
|
|
|
|
lin
|
|
NoDefinition t = {s=t.s};
|
|
MkDefinition t d = {s="<p><b>Definitsioon:</b>"++t.s++d.s++"</p>"};
|
|
MkDefinitionEx t d e = {s="<p><b>Definitsioon:</b>"++t.s++d.s++"</p><p><b>Eeskuju:</b>"++e.s++"</p>"};
|
|
|
|
lin
|
|
MkDocument b i e = ss (i.s1 ++ paragraph b.s ++ i.s2 ++ paragraph e.s) ; -- explanation appended in a new paragraph
|
|
MkTag i = ss (i.t) ;
|
|
|
|
{- --# notpresent
|
|
-}
|
|
|
|
}
|