mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-10 19:52:50 -06:00
A major update to the Latvian resource grammar
The case of the topic part of a clause (~subject) can now depend on the verb, allowing for less frequent agreement.
E.g. "man[Dat] garšo pica[Nom]" ("I like pizza").
The default case for the topic/subject remains the nominative case.
This commit is contained in:
@@ -1,46 +1,54 @@
|
||||
--# -path=.:../abstract:../common:../prelude
|
||||
|
||||
concrete CatLav of Cat = CommonX - [CAdv, Voc] ** open
|
||||
ResLav,
|
||||
Prelude
|
||||
in {
|
||||
concrete CatLav of Cat = CommonX - [CAdv, Voc] **
|
||||
open
|
||||
Prelude,
|
||||
ResLav
|
||||
in {
|
||||
|
||||
flags
|
||||
coding = utf8 ;
|
||||
optimize = all_subs ;
|
||||
|
||||
lincat
|
||||
-- Tensed/Untensed
|
||||
S = { s : Str } ;
|
||||
QS = { s : Str } ;
|
||||
RS = { s : Agr => Str } ; -- Eng: c : Case -- c for it clefts
|
||||
SSlash = { s : Str ; p : Prep } ;
|
||||
|
||||
-- Tensed / Untensed
|
||||
|
||||
S, QS = { s : Str } ;
|
||||
RS = { s : Agr => Str } ;
|
||||
SSlash = { s : Str ; p : ResLav.Prep } ;
|
||||
|
||||
-- Sentence
|
||||
|
||||
Cl = { s : VerbMood => Polarity => Str } ;
|
||||
ClSlash = { s : VerbMood => Polarity => Str ; p : Prep } ;
|
||||
ClSlash = { s : VerbMood => Polarity => Str ; p : ResLav.Prep } ;
|
||||
Imp = { s : Polarity => Number => Str } ;
|
||||
|
||||
-- Question
|
||||
|
||||
QCl = { s : VerbMood => Polarity => Str } ;
|
||||
IP = { s : Case => Str ; n: Number } ;
|
||||
--IComp = { s : Str ; a : ResLav.Agr } ;
|
||||
IDet = { s : Gender => Str ; n : Number } ;
|
||||
IQuant = { s : Gender => Number => Str } ;
|
||||
-- TODO: IComp = { s : Str ; a : ResLav.Agr } ;
|
||||
|
||||
-- Relative
|
||||
|
||||
RCl = { s : VerbMood => Polarity => Agr => Str } ;
|
||||
RP = { s : Gender => Case => Str } ;
|
||||
|
||||
-- Verb
|
||||
|
||||
VP = ResLav.VP ;
|
||||
VPSlash = ResLav.VP ** { p : Prep } ;
|
||||
VPSlash = ResLav.VP ** { p : ResLav.Prep } ;
|
||||
Comp = { s : ResLav.Agr => Str } ;
|
||||
|
||||
-- Adjective
|
||||
|
||||
AP = { s : Definite => Gender => Number => Case => Str } ;
|
||||
|
||||
-- Noun
|
||||
|
||||
CN = { s : Definite => Number => Case => Str ; g : Gender } ;
|
||||
NP = { s : Case => Str ; a : ResLav.Agr } ;
|
||||
Pron = { s : Case => Str ; a : ResLav.Agr ; possessive : Gender => Number => Case => Str } ;
|
||||
@@ -52,33 +60,33 @@ lincat
|
||||
Quant = { s : Gender => Number => Case => Str ; d : Definite } ;
|
||||
|
||||
-- Numeral
|
||||
|
||||
Numeral = { s : CardOrd => Gender => Case => Str ; n : Number } ;
|
||||
Digits = { s : CardOrd => Str ; n : Number } ;
|
||||
|
||||
-- Structural
|
||||
|
||||
Conj = { s1, s2 : Str ; n : Number } ;
|
||||
Subj = { s : Str } ;
|
||||
Prep = { s : Str ; c : Number => Case } ;
|
||||
-- e.g. 'ar' + Sg-Acc or Pl-Dat; preposition may be empty ([]) for case-based valences
|
||||
-- TODO: pozīcija (pre/post) nav noteikta
|
||||
Prep = ResLav.Prep ;
|
||||
|
||||
-- Open lexical classes (lexicon)
|
||||
|
||||
-- Open lexical classes, e.g. Lexicon
|
||||
N = { s : Number => Case => Str ; g : Gender } ;
|
||||
N2 = { s : Number => Case => Str ; g : Gender } ** { p : Prep ; isPre : Bool } ;
|
||||
-- case/preposition used; if isPre, then located before the noun
|
||||
N3 = { s : Number => Case => Str ; g : Gender } ** { p1, p2 : Prep ; isPre1, isPre2 : Bool } ;
|
||||
N2 = { s : Number => Case => Str ; g : Gender } ** { p : ResLav.Prep ; isPre : Bool } ; -- If isPre then located before the noun
|
||||
N3 = { s : Number => Case => Str ; g : Gender } ** { p1, p2 : ResLav.Prep ; isPre1, isPre2 : Bool } ;
|
||||
PN = { s : Case => Str ; g : Gender ; n : Number } ;
|
||||
|
||||
A = { s : AForm => Str } ;
|
||||
A2 = A ** { p : Prep } ;
|
||||
A2 = A ** { p : ResLav.Prep } ;
|
||||
|
||||
V, VQ, VA, VV = Verb ;
|
||||
VS = Verb ** { subj : Subj } ;
|
||||
V2, V2A, V2Q, V2V = Verb ** { p : Prep } ;
|
||||
V2S = Verb ** { p : Prep ; subj : Subj } ;
|
||||
V3 = Verb ** { p1, p2 : Prep } ;
|
||||
-- TODO: pieņemam ka viena valence; būtu jānorāda semantika - integrēt ar FrameNet
|
||||
V, VA = Verb ;
|
||||
VV, VQ = Verb ** { topic : Case } ;
|
||||
VS = Verb ** { subj : Subj ; topic : Case } ;
|
||||
V2 = Verb ** { p : ResLav.Prep ; topic : Case } ;
|
||||
V2A, V2Q, V2V = Verb ** { p : ResLav.Prep } ;
|
||||
V2S = Verb ** { p : ResLav.Prep ; subj : Subj } ;
|
||||
V3 = Verb ** { p1, p2 : ResLav.Prep ; topic : Case } ;
|
||||
|
||||
CAdv = { s, p : Str ; d : Degree } ;
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user