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:
Normunds Gruzitis
2012-08-23 23:05:16 +00:00
parent d6e3d07db1
commit d217f20c60
10 changed files with 185 additions and 139 deletions

View File

@@ -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 } ;
}