Source code for gramps.plugins.rel.rel_sl

# -*- coding: utf-8 -*-
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2003-2005  Donald N. Allingham
# Copyright (C) 2008       Brian G. Matherly
# Copyright (C) 2009-2010  Andrew I Baznikin
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#

# Written by Bernard Banko, inspired from rel_ru.py by Alex Roitman.
"""
Slovenian-specific definitions of relationships
"""
from __future__ import unicode_literals
#-------------------------------------------------------------------------
#
# GRAMPS modules
#
#-------------------------------------------------------------------------

from gramps.gen.lib import Person
import gramps.gen.relationship

#-------------------------------------------------------------------------

_ancestors = [ "", "starš", "stari starš", "prastari starš" ]
_fathers = [ "", "oče", "ded", "praded", "prapraded" ]
_mothers = [ "", "mati", "babica", "prababica", "praprababica" ]
_descendants = [
  "", "otrok", "vnuk(inja)", "pravnuk(inja)", "prapravnuk(inja)" ]
_sons = [ "", "sin", "vnuk", "pravnuk", "prapravnuk" ]
_daughters = [ "", "hči", "vnukinja", "pravnukinja", "prapravnukinja" ]
_maleCousins = [ "", "brat", "bratranec", "mali bratranec" ]
_femaleCousins = [ "", "sestra", "sestrična", "mala sestrična" ]
_someCousins = [ "", "brat ali sestra", "bratranec ali sestrična",
  "mali bratranec ali mala sestrična" ]
_aunts = [ "", "teta", "stara teta", "prateta", "praprateta" ]
_uncles = [ "", "stric", "stari stric", "prastric", "praprastric" ]  
_nieces = [ "", "nečakinja", "pranečakinja", "prapranečakinja" ]
_nephews = [ "", "nečak", "pranečak", "prapranečak" ]

#plural
_children = [ "", "otroci", "vnuki", "pravnuki", "prapravnuki" ]
_parents = [ "", "starši", "stari starši", "prastarši", "praprastarši" ]
_siblings = [ "", "sorojenci", "strici", "stari strici", "prastrici",
  "praprastrici" ]
_neph_niec = [ "", "nečaki", "pranečaki", "prapranečaki" ]

#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
[docs]class RelationshipCalculator(gramps.gen.relationship.RelationshipCalculator): """ RelationshipCalculator Class """ def __init__(self): gramps.gen.relationship.RelationshipCalculator.__init__(self)
[docs] def getAncestor(self, level): if level > len(_ancestors)-1: return "%s-krat-pra-prednik" % (level-2) else: return _ancestors[level]
[docs] def getFather(self, level): if level > len(_fathers)-1: return "%s-krat-pra-ded" % (level-2) else: return _fathers[level]
[docs] def getMother(self, level): if level > len(_mothers)-1: return "%s-krat-pra-babica" % (level-2) else: return _mothers[level]
[docs] def getSon(self, level): if level > len(_sons)-1: return "%s-krat-pra-vnuk" % (level-2) else: return _sons[level]
[docs] def getDaughter(self, level): if level > len(_daughters)-1: return "%s-krat-pra-vnukinja" % (level-2) else: return _daughters[level]
[docs] def getDescendant(self, level): if level > len(_descendants)-1: return "%s-krat-pra-vnuk(inja)" % (level-2) else: return _descendants[level]
[docs] def getMaleCousin(self, level): if level > len(_maleCousins)-1: return "bratranec v %s. kolenu" % (level*2) else: return _maleCousins[level]
[docs] def getFemaleCousin(self, level): if level > len(_femaleCousins)-1: return "sestrična v %s. kolenu" % (level*2) else: return _femaleCousins[level]
[docs] def getSomeCousin(self, level): if level > len(_someCousins)-1: return "bratranec ali sestrična v %s. kolenu" % (level*2) else: return _someCousins[level]
[docs] def getSuffix(self, distance, level): # distance-level = 2Gb <=> Gb=1 if distance-level == 2 or distance < 6: return "" else: return " v %s. kolenu" % (distance)
[docs] def getAunt(self, distance, level): if distance == 5 and level == 1: return "mala teta" elif level > len(_aunts)-1: return "%s-krat-pra-teta%s" % (level-2, self.getSuffix(distance, level)) else: return "%s%s" % (_aunts[level], self.getSuffix(distance, level))
[docs] def getUncle(self, distance, level): if distance == 5 and level == 1: return "mali stric" elif level > len(_uncles)-1: return "%s-krat-pra-stric%s" % (level-2, self.getSuffix(distance, level)) else: return "%s%s" % (_uncles[level], self.getSuffix(distance, level))
[docs] def getNiece(self, distance, level): if distance == 5 and level == 1: return "mala nečakinja" elif level > len(_nieces)-1: return "%s-krat-pra-nečakinja%s" % (level-1, self.getSuffix(distance, level)) else: return "%s%s" % (_nieces[level], self.getSuffix(distance, level))
[docs] def getNephew(self, distance, level): if distance == 5 and level == 1: return "mali nečak" elif level > len(_nephews)-1: return "%s-krat-pra-nečak%s" % (level-1, self.getSuffix(distance, level)) else: return "%s%s" % (_nephews[level], self.getSuffix(distance, level))
[docs] def get_single_relationship_string( self, Ga, Gb, gender_a, gender_b, reltocommon_a, reltocommon_b, only_birth=True, in_law_a=False, in_law_b=False): """ Provide a string that describes the relationsip between a person, and another person. E.g. "grandparent" or "child". To be used as: 'person b is the grandparent of a', this will be in translation string: 'person b is the %(relation)s of a' Note that languages with gender should add 'the' inside the translation, so eg in french: 'person b est %(relation)s de a' where relation will be here: le grandparent Ga and Gb can be used to mathematically calculate the relationship. .. seealso:: http://en.wikipedia.org/wiki/Cousin#Mathematical_definitions Some languages need to know the specific path to the common ancestor. Those languages should use reltocommon_a and reltocommon_b which is a string like 'mfmf'. The possible string codes are: ======================= =========================================== Code Description ======================= =========================================== REL_MOTHER # going up to mother REL_FATHER # going up to father REL_MOTHER_NOTBIRTH # going up to mother, not birth relation REL_FATHER_NOTBIRTH # going up to father, not birth relation REL_FAM_BIRTH # going up to family (mother and father) REL_FAM_NONBIRTH # going up to family, not birth relation REL_FAM_BIRTH_MOTH_ONLY # going up to fam, only birth rel to mother REL_FAM_BIRTH_FATH_ONLY # going up to fam, only birth rel to father ======================= =========================================== Prefix codes are stripped, so REL_FAM_INLAW_PREFIX is not present. If the relation starts with the inlaw of the person a, then 'in_law_a' is True, if it starts with the inlaw of person b, then 'in_law_b' is True. Also REL_SIBLING (# going sideways to sibling (no parents)) is not passed to this routine. The collapse_relations changes this to a family relation. Hence, calling routines should always strip REL_SIBLING and REL_FAM_INLAW_PREFIX before calling get_single_relationship_string() Note that only_birth=False, means that in the reltocommon one of the NOTBIRTH specifiers is present. The REL_FAM identifiers mean that the relation is not via a common ancestor, but via a common family (note that that is not possible for direct descendants or direct ancestors!). If the relation to one of the parents in that common family is by birth, then 'only_birth' is not set to False. The only_birth() method is normally used for this. :param Ga: The number of generations between the main person and the common ancestor. :type Ga: int :param Gb: The number of generations between the other person and the common ancestor. :type Gb: int :param gender_a: gender of person a :type gender_a: int gender :param gender_b: gender of person b :type gender_b: int gender :param reltocommon_a: relation path to common ancestor or common Family for person a. Note that length = Ga :type reltocommon_a: str :param reltocommon_b: relation path to common ancestor or common Family for person b. Note that length = Gb :type reltocommon_b: str :param in_law_a: True if path to common ancestors is via the partner of person a :type in_law_a: bool :param in_law_b: True if path to common ancestors is via the partner of person b :type in_law_b: bool :param only_birth: True if relation between a and b is by birth only False otherwise :type only_birth: bool :returns: A string describing the relationship between the two people :rtype: str .. note:: 1. the self.REL_SIBLING should not be passed to this routine, so we should not check on it. All other self. 2. for better determination of siblings, use if Ga=1=Gb get_sibling_relationship_string """ if Gb == 0: if Ga == 0: rel_str = "ista oseba" elif gender_b == Person.MALE: rel_str = (self.getFather(Ga)) elif gender_b == Person.FEMALE: rel_str = (self.getMother(Ga)) else: rel_str = (self.getAncestor(Ga)) elif Ga == 0: if gender_b == Person.MALE: rel_str = (self.getSon(Gb)) elif gender_b == Person.FEMALE: rel_str = (self.getDaughter(Gb)) else: rel_str = (self.getDescendant(Gb)) elif Ga == Gb: if gender_b == Person.MALE: rel_str = (self.getMaleCousin(Gb)) elif gender_b == Person.FEMALE: rel_str = (self.getFemaleCousin(Gb)) else: rel_str = (self.getSomeCousin(Gb)) elif Ga > Gb: if gender_b == Person.FEMALE: rel_str = (self.getAunt(Ga+Gb, Ga-Gb)) else: rel_str = (self.getUncle(Ga+Gb, Ga-Gb)) # we'll use male for unknown sex else: #Ga < Gb if gender_b == Person.FEMALE: rel_str = (self.getNiece(Ga+Gb, Gb-Ga)) else: rel_str = (self.getNephew(Ga+Gb, Gb-Ga)) # we'll use male for unknown sex return rel_str
[docs] def get_sibling_relationship_string(self, sib_type, gender_a, gender_b, in_law_a=False, in_law_b=False): """ Determine the string giving the relation between two siblings of type sib_type. Eg: b is the brother of a Here 'brother' is the string we need to determine This method gives more details about siblings than get_single_relationship_string can do. .. warning:: DON'T TRANSLATE THIS PROCEDURE IF LOGIC IS EQUAL IN YOUR LANGUAGE, AND SAME METHODS EXIST (get_uncle, get_aunt, get_sibling) """ gender = gender_b #we don't need gender_a inlaw = in_law_a or in_law_b if sib_type == self.HALF_SIB_MOTHER or sib_type == self.HALF_SIB_FATHER: prefix = "pol" else: prefix = "" if sib_type < self.STEP_SIB: # ie. NORM_SIB or one of HALF_SIBs if not inlaw: if gender == Person.MALE: rel_str = "%sbrat" % (prefix) elif gender == Person.FEMALE: rel_str = "%ssestra" % (prefix) else: rel_str = "%sbrat ali %ssestra" % (prefix, prefix) else: if gender == Person.MALE: rel_str = "%ssvak" % (prefix) elif gender == Person.FEMALE: rel_str = "%ssvakinja" % (prefix) else: rel_str = "%ssvak ali %ssvakinja" % (prefix, prefix) else: rel_str = "" return rel_str
[docs] def get_plural_relationship_string( self, Ga, Gb, reltocommon_a='', reltocommon_b='', only_birth=True, in_law_a=False, in_law_b=False): distance = Ga+Gb rel_str = "sorodniki v %s. kolenu" % (distance) if Ga == 0: # These are descendants if Gb < len(_children): rel_str = _children[Gb] else: rel_str = "%s-krat-pra-vnuki" % (Gb-2) elif Gb == 0: # These are parents/grand parents if Ga < len(_parents): rel_str = _parents[Ga] else: rel_str = "%s-krat-pra-starši" % (Ga-2) elif Gb == 1: # These are siblings/aunts/uncles if Ga < len(_siblings): rel_str = _siblings[Ga] else: rel_str = "%s-krat-pra-strici" % (Ga-2) elif Ga == 1: # These are nieces/nephews if Gb < len(_neph_niec): rel_str = _neph_niec[Gb] else: rel_str = "%s-krat-pra-nečaki" % (Gb-1) elif Ga == Gb: # These are cousins in the same generation if Ga == 2: rel_str = "bratranci" elif Ga == 3: rel_str = "mali bratranci" else: rel_str = "bratranci v %s. kolenu" % (distance) elif Ga > Gb: # These are cousins in different generations with the second person # being in a higher generation from the common ancestor than the # first person. level = Ga - Gb if distance == 5: rel_str = "mali strici" elif level < len(_siblings)-1: # len-1 and level+1 to skip the siblings in uncles' levels rel_str = "%s v %s. kolenu" % (_siblings[level+1], distance) else: rel_str = "%s-krat-pra-strici v %s. kolenu" % (level-2, distance) else: #Gb > Ga: # These are cousins in different generations with the second person # being in a lower generation from the common ancestor than the # first person. level = Gb - Ga if distance == 5: rel_str = "mali nečaki" elif level < len(_neph_niec): rel_str = "%s v %s. kolenu" % (_neph_niec[level], distance) else: rel_str = "%s-krat-pra-nečaki v %s. kolenu" % (level-1, distance) if in_law_b == True: rel_str = "zakonci, ki jih imajo %s" % rel_str return rel_str
if __name__ == "__main__": """TRANSLATORS, copy this if statement at the bottom of your rel_xx.py module, and test your work with: python src/plugins/rel/rel_xx.py """ from gramps.gen.relationship import test RC = RelationshipCalculator() test(RC, True) # #from PluginMgr import register_relcalc # register_relcalc(RelationshipCalculatorClass,["sl","sl_SI","sl-SI","slovenian","Slovenian","slovenščina"])