forked from GitHub/gf-rgl
120 lines
3.7 KiB
Plaintext
120 lines
3.7 KiB
Plaintext
--# -path=.:../abstract:../../prelude
|
|
|
|
--1 The Top-Level Russian Resource Grammar: Combination Rules
|
|
--
|
|
-- Aarne Ranta, Janna Khegai 2003 -- 2004
|
|
--
|
|
-- This is the Russian concrete syntax of the multilingual resource
|
|
-- grammar. Most of the work is done in the file $SyntaxRus.gf$.
|
|
-- However, for the purpose of documentation, we make here explicit the
|
|
-- linearization types of each category, so that their structures and
|
|
-- dependencies can be seen.
|
|
-- Another substantial part are the linearization rules of some
|
|
-- structural words.
|
|
--
|
|
-- The users of the resource grammar should not look at this file for the
|
|
-- linearization rules, which are in fact hidden in the document version.
|
|
-- They should use $resource.Abs.gf$ to access the syntactic rules.
|
|
-- This file can be consulted in those, hopefully rare, occasions in which
|
|
-- one has to know how the syntactic categories are
|
|
-- implemented. The parameter types are defined in $TypesRus.gf$.
|
|
|
|
concrete CategoriesRus of Categories = open Prelude, SyntaxRus in {
|
|
|
|
flags
|
|
startcat=Phr ;
|
|
lexer=text ;
|
|
unlexer=text ;
|
|
|
|
lincat
|
|
N = CommNoun ;
|
|
-- = {s : SubstForm => Str ; g : Gender ; anim : Animacy } ;
|
|
CN = CommNounPhrase ;
|
|
-- = {s : Number => Case => Str; g : Gender; anim : Animacy} ;
|
|
NP = NounPhrase ;
|
|
-- = { s : PronForm => Str ; n : Number ; p : Person ;
|
|
-- g: PronGen ; anim : Animacy ; pron: Bool} ;
|
|
PN = ProperName ;
|
|
-- = {s : Case => Str ; g : Gender ; anim : Animacy} ;
|
|
A = Adjective ;
|
|
-- = {s : AdjForm => Str} ;
|
|
A2 = AdjCompl ;
|
|
-- = Adjective ** Complement ;
|
|
ADeg = AdjDegr ;
|
|
-- = {s : Degree => AdjForm => Str} ;
|
|
AP = AdjPhrase ;
|
|
-- = Adjective ** {p : IsPostfixAdj} ;
|
|
|
|
Det = Determiner ;
|
|
-- = Adjective ** {n: Number; g: PronGen; c: Case} ;
|
|
|
|
N2 = Function ;
|
|
-- = CommNounPhrase ** Complement ;
|
|
N3 = Function ** {s3 : Str; c2: Case} ;
|
|
Num = Numeral ;
|
|
-- = {s : Case => Gender => Str} ;
|
|
|
|
V = Verbum ;
|
|
-- = {s : VerbForm => Str ; asp : Aspect } ;
|
|
VG = VerbGroup ;
|
|
-- = Verbum ** { w: Voice; s2 : Bool => Str ;
|
|
-- s3 : Gender => Number => Str ; negBefore: Bool} ;
|
|
VP = VerbPhrase ;
|
|
-- = Verb ** {s2 : Str ; s3 : Gender => Number => Str ;
|
|
-- negBefore: Bool} ;
|
|
V2 = TransVerb ;
|
|
-- = Verbum ** {s2 : Str ; c: Case } ;
|
|
V3 = DitransVerb ;
|
|
-- = TransVerb ** {s4 : Str; c2: Case} ;
|
|
VS = SentenceVerb ;
|
|
-- = Verbum ;
|
|
VV = VerbVerb ;
|
|
-- = Verbum ;
|
|
|
|
|
|
AdV = Adverb ;
|
|
-- = {s : Str} ;
|
|
Prep = Preposition;
|
|
-- = {s : Str ; c: Case } ;
|
|
|
|
|
|
|
|
S = Sentence ;
|
|
-- = {s : Str} ;
|
|
Slash = SentenceSlashNounPhrase ;
|
|
-- = Sentence ** Complement ;
|
|
|
|
RP = RelPron ;
|
|
-- = {s : GenNum => Case => Animacy => Str} ;
|
|
RC = RelClause ;
|
|
-- = RelPron ;
|
|
|
|
IP = IntPron ;
|
|
-- = NounPhrase ;
|
|
Qu = Question ;
|
|
-- = {s : QuestForm => Str} ;
|
|
Imp = Imperative ;
|
|
-- = { s: Gender => Number => Str } ;
|
|
Phr = Utterance ;
|
|
-- = {s : Str} ;
|
|
|
|
Conj = Conjunction ;
|
|
-- = {s : Str ; n : Number} ;
|
|
ConjD = ConjunctionDistr ;
|
|
-- = {s1,s2 : Str ; n : Number} ;
|
|
|
|
ListS = ListSentence ;
|
|
-- = {s1,s2 : Mode => Str} ;
|
|
ListAP = ListAdjPhrase ;
|
|
-- = {s1,s2 : AdjForm => Str ; p : Bool} ;
|
|
ListNP = ListNounPhrase ;
|
|
-- = { s1,s2 : PronForm => Str ; g: Gender ; anim : Animacy ;
|
|
-- n : Number ; p : Person ; pron : Bool } ;
|
|
|
|
PP = Adverb ;
|
|
Cl = Clause ;
|
|
-- = {s : Bool => ClForm => Str} ;
|
|
|
|
}
|
|
|