PythonTidy (PEP-8 format)
svn: r11791
This commit is contained in:
parent
248002b819
commit
ea96136bf9
@ -1,3 +1,4 @@
|
||||
#!/usr/bin/python
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
# Gramps - a GTK+/GNOME based genealogy program
|
||||
@ -9,7 +10,7 @@
|
||||
# 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,
|
||||
# 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.
|
||||
@ -21,15 +22,16 @@
|
||||
|
||||
# $Id$
|
||||
|
||||
"""
|
||||
French-specific classes for parsing and displaying dates.
|
||||
"""
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Python modules
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
"""
|
||||
French-specific classes for parsing and displaying dates.
|
||||
"""
|
||||
|
||||
import re
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
@ -37,6 +39,7 @@ import re
|
||||
# GRAMPS modules
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
from gen.lib import Date
|
||||
from _DateParser import DateParser
|
||||
from _DateDisplay import DateDisplay
|
||||
@ -47,269 +50,310 @@ from _DateHandler import register_datehandler
|
||||
# French parser
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
|
||||
class DateParserFR(DateParser):
|
||||
|
||||
month_to_int = DateParser.month_to_int
|
||||
|
||||
# Add common value
|
||||
|
||||
month_to_int[u"bluviose"] = 1
|
||||
month_to_int[u"vendose"] = 2
|
||||
month_to_int[u"7bre"] = 9
|
||||
month_to_int[u"8bre"] = 10
|
||||
month_to_int[u"9bre"] = 11
|
||||
month_to_int[u"10bre"] = 12
|
||||
month_to_int[u"xbre"] = 12
|
||||
month_to_int[u"vendose"] = 2
|
||||
month_to_int[u"7bre"] = 9
|
||||
month_to_int[u"8bre"] = 10
|
||||
month_to_int[u"9bre"] = 11
|
||||
month_to_int[u"10bre"] = 12
|
||||
month_to_int[u"xbre"] = 12
|
||||
|
||||
# Add common latin
|
||||
|
||||
month_to_int[u"januaris"] = 1
|
||||
month_to_int[u"januarii"] = 1
|
||||
month_to_int[u"januarius"] = 1
|
||||
month_to_int[u"februaris"] = 2
|
||||
month_to_int[u"februarii"] = 2
|
||||
month_to_int[u"februarius"] = 2
|
||||
month_to_int[u"martii"] = 3
|
||||
month_to_int[u"martius"] = 3
|
||||
month_to_int[u"aprilis"] = 4
|
||||
month_to_int[u"maius"] = 5
|
||||
month_to_int[u"maii"] = 5
|
||||
month_to_int[u"junius"] = 6
|
||||
month_to_int[u"junii"] = 6
|
||||
month_to_int[u"julius"] = 7
|
||||
month_to_int[u"julii"] = 7
|
||||
month_to_int[u"augustus"] = 8
|
||||
month_to_int[u"augusti"] = 8
|
||||
month_to_int[u"septembris"] = 9
|
||||
month_to_int[u"7bris"] = 9
|
||||
month_to_int[u"september"] = 9
|
||||
month_to_int[u"october"] = 10
|
||||
month_to_int[u"octobris"] = 10
|
||||
month_to_int[u"8bris"] = 10
|
||||
month_to_int[u"novembris"] = 11
|
||||
month_to_int[u"9bris"] = 11
|
||||
month_to_int[u"november"] = 11
|
||||
month_to_int[u"decembris"] = 12
|
||||
month_to_int[u"10bris"] = 12
|
||||
month_to_int[u"xbris"] = 12
|
||||
month_to_int[u"december"] = 12
|
||||
month_to_int[u"februaris"] = 2
|
||||
month_to_int[u"februarii"] = 2
|
||||
month_to_int[u"februarius"] = 2
|
||||
month_to_int[u"martii"] = 3
|
||||
month_to_int[u"martius"] = 3
|
||||
month_to_int[u"aprilis"] = 4
|
||||
month_to_int[u"maius"] = 5
|
||||
month_to_int[u"maii"] = 5
|
||||
month_to_int[u"junius"] = 6
|
||||
month_to_int[u"junii"] = 6
|
||||
month_to_int[u"julius"] = 7
|
||||
month_to_int[u"julii"] = 7
|
||||
month_to_int[u"augustus"] = 8
|
||||
month_to_int[u"augusti"] = 8
|
||||
month_to_int[u"septembris"] = 9
|
||||
month_to_int[u"7bris"] = 9
|
||||
month_to_int[u"september"] = 9
|
||||
month_to_int[u"october"] = 10
|
||||
month_to_int[u"octobris"] = 10
|
||||
month_to_int[u"8bris"] = 10
|
||||
month_to_int[u"novembris"] = 11
|
||||
month_to_int[u"9bris"] = 11
|
||||
month_to_int[u"november"] = 11
|
||||
month_to_int[u"decembris"] = 12
|
||||
month_to_int[u"10bris"] = 12
|
||||
month_to_int[u"xbris"] = 12
|
||||
month_to_int[u"december"] = 12
|
||||
|
||||
#local and historical variants
|
||||
# Add common on east france
|
||||
|
||||
month_to_int[u"janer"] = 1
|
||||
month_to_int[u"jenner"] = 1
|
||||
month_to_int[u"hartmonat"] = 1
|
||||
month_to_int[u"hartung"] = 1
|
||||
month_to_int[u"eismond"] = 1
|
||||
month_to_int[u"hornung"] = 2
|
||||
month_to_int[u"wintermonat"] = 2
|
||||
month_to_int[u"taumond"] = 2
|
||||
month_to_int[u"narrenmond"] = 2
|
||||
month_to_int[u"lenzing"] = 3
|
||||
month_to_int[u"ostermond"] = 4
|
||||
month_to_int[u"wonnemond"] = 5
|
||||
month_to_int[u"wiesenmonat"] = 5
|
||||
month_to_int[u"brachet"] = 6
|
||||
month_to_int[u"heuet"] = 7
|
||||
month_to_int[u"ernting"] = 8
|
||||
month_to_int[u"scheiding"] = 9
|
||||
month_to_int[u"gilbhard"] = 10
|
||||
month_to_int[u"nebelmonat"] = 11
|
||||
month_to_int[u"nebelung"] = 11
|
||||
month_to_int[u"julmond"] = 12
|
||||
month_to_int[u"hornung"] = 2
|
||||
month_to_int[u"wintermonat"] = 2
|
||||
month_to_int[u"taumond"] = 2
|
||||
month_to_int[u"narrenmond"] = 2
|
||||
month_to_int[u"lenzing"] = 3
|
||||
month_to_int[u"ostermond"] = 4
|
||||
month_to_int[u"wonnemond"] = 5
|
||||
month_to_int[u"wiesenmonat"] = 5
|
||||
month_to_int[u"brachet"] = 6
|
||||
month_to_int[u"heuet"] = 7
|
||||
month_to_int[u"ernting"] = 8
|
||||
month_to_int[u"scheiding"] = 9
|
||||
month_to_int[u"gilbhard"] = 10
|
||||
month_to_int[u"nebelmonat"] = 11
|
||||
month_to_int[u"nebelung"] = 11
|
||||
month_to_int[u"julmond"] = 12
|
||||
|
||||
modifier_to_int = {
|
||||
u'avant' : Date.MOD_BEFORE,
|
||||
u'av.' : Date.MOD_BEFORE,
|
||||
u'après' : Date.MOD_AFTER,
|
||||
u'ap.' : Date.MOD_AFTER,
|
||||
u'ap' : Date.MOD_AFTER,
|
||||
u'env.' : Date.MOD_ABOUT,
|
||||
u'env' : Date.MOD_ABOUT,
|
||||
u'environ': Date.MOD_ABOUT,
|
||||
u'circa' : Date.MOD_ABOUT,
|
||||
u'c.' : Date.MOD_ABOUT,
|
||||
u'ca' : Date.MOD_ABOUT,
|
||||
u'ca.' : Date.MOD_ABOUT,
|
||||
u'vers' : Date.MOD_ABOUT,
|
||||
u'~' : Date.MOD_ABOUT,
|
||||
u'avant': Date.MOD_BEFORE,
|
||||
u'av.': Date.MOD_BEFORE,
|
||||
u'après': Date.MOD_AFTER,
|
||||
u'ap.': Date.MOD_AFTER,
|
||||
u'ap': Date.MOD_AFTER,
|
||||
u'env.': Date.MOD_ABOUT,
|
||||
u'env': Date.MOD_ABOUT,
|
||||
u'environ': Date.MOD_ABOUT,
|
||||
u'circa': Date.MOD_ABOUT,
|
||||
u'c.': Date.MOD_ABOUT,
|
||||
u'ca': Date.MOD_ABOUT,
|
||||
u'ca.': Date.MOD_ABOUT,
|
||||
u'vers': Date.MOD_ABOUT,
|
||||
u'~': Date.MOD_ABOUT,
|
||||
}
|
||||
|
||||
calendar_to_int = {
|
||||
u'grégorien' : Date.CAL_GREGORIAN,
|
||||
u'g' : Date.CAL_GREGORIAN,
|
||||
u'julien' : Date.CAL_JULIAN,
|
||||
u'j' : Date.CAL_JULIAN,
|
||||
u'hébreu' : Date.CAL_HEBREW,
|
||||
u'h' : Date.CAL_HEBREW,
|
||||
u'islamique' : Date.CAL_ISLAMIC,
|
||||
u'i' : Date.CAL_ISLAMIC,
|
||||
u'révolutionnaire' : Date.CAL_FRENCH,
|
||||
u'r' : Date.CAL_FRENCH,
|
||||
u'perse' : Date.CAL_PERSIAN,
|
||||
u'p' : Date.CAL_PERSIAN,
|
||||
u'suédois' : Date.CAL_SWEDISH,
|
||||
u's' : Date.CAL_SWEDISH,
|
||||
u'grégorien': Date.CAL_GREGORIAN,
|
||||
u'g': Date.CAL_GREGORIAN,
|
||||
u'julien': Date.CAL_JULIAN,
|
||||
u'j': Date.CAL_JULIAN,
|
||||
u'hébreu': Date.CAL_HEBREW,
|
||||
u'h': Date.CAL_HEBREW,
|
||||
u'islamique': Date.CAL_ISLAMIC,
|
||||
u'i': Date.CAL_ISLAMIC,
|
||||
u'révolutionnaire': Date.CAL_FRENCH,
|
||||
u'r': Date.CAL_FRENCH,
|
||||
u'perse': Date.CAL_PERSIAN,
|
||||
u'p': Date.CAL_PERSIAN,
|
||||
u'suédois': Date.CAL_SWEDISH,
|
||||
u's': Date.CAL_SWEDISH,
|
||||
}
|
||||
|
||||
quality_to_int = {
|
||||
u'estimée' : Date.QUAL_ESTIMATED,
|
||||
u'est.' : Date.QUAL_ESTIMATED,
|
||||
u'est' : Date.QUAL_ESTIMATED,
|
||||
u'calculée' : Date.QUAL_CALCULATED,
|
||||
u'calc.' : Date.QUAL_CALCULATED,
|
||||
u'calc' : Date.QUAL_CALCULATED,
|
||||
u'comptée' : Date.QUAL_CALCULATED,
|
||||
u'compt' : Date.QUAL_CALCULATED,
|
||||
u'compt.' : Date.QUAL_CALCULATED,
|
||||
u'estimée': Date.QUAL_ESTIMATED,
|
||||
u'est.': Date.QUAL_ESTIMATED,
|
||||
u'est': Date.QUAL_ESTIMATED,
|
||||
u'calculée': Date.QUAL_CALCULATED,
|
||||
u'calc.': Date.QUAL_CALCULATED,
|
||||
u'calc': Date.QUAL_CALCULATED,
|
||||
u'comptée': Date.QUAL_CALCULATED,
|
||||
u'compt': Date.QUAL_CALCULATED,
|
||||
u'compt.': Date.QUAL_CALCULATED,
|
||||
}
|
||||
|
||||
bce = [u"avant le calendrier", u"avant notre ère",
|
||||
u"avant JC", u"avant J.C"] + DateParser.bce
|
||||
|
||||
bce = [u"avant le calendrier", u"avant notre ère", u"avant JC",
|
||||
u"avant J.C"] + DateParser.bce
|
||||
|
||||
def init_strings(self):
|
||||
DateParser.init_strings(self)
|
||||
|
||||
# This self._numeric is different from the base
|
||||
# avoid bug gregorian / french calendar conversion (+/-10 days)
|
||||
self._numeric = re.compile("((\d+)[/\. ])?\s*((\d+)[/\.])?\s*(\d+)\s*$")
|
||||
self._span = re.compile(u"(de)\s+(?P<start>.+)\s+(à)\s+(?P<stop>.+)", re.IGNORECASE)
|
||||
self._range = re.compile(u"(entre|ent\.|ent)\s+(?P<start>.+)\s+(et)\s+(?P<stop>.+)", re.IGNORECASE)
|
||||
|
||||
self._numeric = re.compile("((\d+)[/\. ])?\s*((\d+)[/\.])?\s*(\d+)\s*$")
|
||||
self._span = re.compile(u"(de)\s+(?P<start>.+)\s+(à)\s+(?P<stop>.+)",
|
||||
re.IGNORECASE)
|
||||
self._range = re.compile(u"(entre|ent\.|ent)\s+(?P<start>.+)\s+(et)\s+(?P<stop>.+)",
|
||||
re.IGNORECASE)
|
||||
|
||||
# This self._text are different from the base
|
||||
# by adding ".?" after the first date and removing "\s*$" at the end
|
||||
#gregorian and julian
|
||||
self._text2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._mon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
self._text2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._mon_str, re.IGNORECASE)
|
||||
|
||||
#hebrew
|
||||
self._jtext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._jmon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
self._jtext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._jmon_str, re.IGNORECASE)
|
||||
|
||||
#french
|
||||
self._ftext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._fmon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
self._ftext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._fmon_str, re.IGNORECASE)
|
||||
|
||||
#persian
|
||||
self._ptext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._pmon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
self._ptext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._pmon_str, re.IGNORECASE)
|
||||
|
||||
#islamic
|
||||
self._itext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._imon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
self._itext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._imon_str, re.IGNORECASE)
|
||||
|
||||
#swedish
|
||||
self._stext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' % self._smon_str,
|
||||
re.IGNORECASE)
|
||||
|
||||
|
||||
self._stext2 = re.compile('(\d+)?.?\s+?%s\s*((\d+)(/\d+)?)?' %
|
||||
self._smon_str, re.IGNORECASE)
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# French display
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
|
||||
class DateDisplayFR(DateDisplay):
|
||||
|
||||
calendar = (
|
||||
"", u" (Julien)", u" (Hébreu)",
|
||||
u" (Révolutionnaire)", u" (Perse)", u" (Islamique)",
|
||||
u" (Suédois)"
|
||||
)
|
||||
calendar = ("", u" (Julien)", u" (Hébreu)", u" (Révolutionnaire)",
|
||||
u" (Perse)", u" (Islamique)", u" (Suédois)")
|
||||
|
||||
_mod_str = ("", u"avant ", u"après ", u"vers ", "", "", "")
|
||||
|
||||
|
||||
_qual_str = ("", u"estimée ", u"calculée ", "")
|
||||
|
||||
|
||||
_bce_str = u"%s avant le calendrier"
|
||||
|
||||
formats = (
|
||||
"AAAA-MM-JJ (ISO)", "Numérique", "Mois Jour, Année",
|
||||
"MOI Jour, Année", "Jour. Mois Année", "Jour. MOI Année"
|
||||
)
|
||||
formats = ("AAAA-MM-JJ (ISO)", "Numérique", "Mois Jour, Année",
|
||||
"MOI Jour, Année", "Jour. Mois Année", "Jour. MOI Année")
|
||||
|
||||
def _display_gregorian(self, date_val):
|
||||
year = self._slash_year(date_val[2], date_val[3])
|
||||
if self.format == 0:
|
||||
return self.display_iso(date_val)
|
||||
elif self.format == 1:
|
||||
if date_val[2] < 0 or date_val[3]:
|
||||
return self.display_iso(date_val)
|
||||
if date_val[2] < 0 or date_val[3]:
|
||||
return self.display_iso(date_val)
|
||||
else:
|
||||
if date_val[0] == date_val[1] == 0:
|
||||
value = str(date_val[2])
|
||||
else:
|
||||
value = self._tformat.replace('%m', str(date_val[1]))
|
||||
value = value.replace('%d', str(date_val[0]))
|
||||
|
||||
# base_display :
|
||||
# value = value.replace('%Y', str(abs(date_val[2])))
|
||||
# value = value.replace('-', '/')
|
||||
value = value.replace('%Y', str(date_val[2]))
|
||||
|
||||
value = value.replace('%Y', str(date_val[2]))
|
||||
elif self.format == 2:
|
||||
|
||||
# Month Day, Year
|
||||
|
||||
if date_val[0] == 0:
|
||||
if date_val[1] == 0:
|
||||
value = year
|
||||
else:
|
||||
value = "%s %s" % (self._months[date_val[1]], year)
|
||||
value = "%s %s" % ((self._months)[date_val[1]], year)
|
||||
else:
|
||||
value = "%s %d, %s" % (self._months[date_val[1]], date_val[0], year)
|
||||
value = "%s %d, %s" % ((self._months)[date_val[1]],
|
||||
date_val[0], year)
|
||||
elif self.format == 3:
|
||||
|
||||
# MON Day, Year
|
||||
|
||||
if date_val[0] == 0:
|
||||
if date_val[1] == 0:
|
||||
value = year
|
||||
else:
|
||||
value = "%s %s" % (self.MONS[date_val[1]], year)
|
||||
value = "%s %s" % ((self.MONS)[date_val[1]], year)
|
||||
else:
|
||||
value = "%s %d, %s" % (self.MONS[date_val[1]], date_val[0], year)
|
||||
value = "%s %d, %s" % ((self.MONS)[date_val[1]],
|
||||
date_val[0], year)
|
||||
elif self.format == 4:
|
||||
|
||||
# Day. Month Year
|
||||
|
||||
if date_val[0] == 0:
|
||||
if date_val[1] == 0:
|
||||
value = year
|
||||
else:
|
||||
value = "%s %s" % (self._months[date_val[1]], year)
|
||||
value = "%s %s" % ((self._months)[date_val[1]], year)
|
||||
else:
|
||||
|
||||
# base_display :
|
||||
# value = "%d %s %s" % (date_val[0], self._months[date_val[1]], year)
|
||||
value = "%d. %s %s" % (date_val[0], self._months[date_val[1]], year)
|
||||
|
||||
value = "%d. %s %s" % (date_val[0], (self._months)[date_val[1]],
|
||||
year)
|
||||
else:
|
||||
|
||||
# Day. MON Year
|
||||
|
||||
if date_val[0] == 0:
|
||||
if date_val[1] == 0:
|
||||
value = year
|
||||
else:
|
||||
value = "%s %s" % (self.MONS[date_val[1]], year)
|
||||
value = "%s %s" % ((self.MONS)[date_val[1]], year)
|
||||
else:
|
||||
|
||||
# base_display :
|
||||
# value = "%d %s %s" % (date_val[0], self.MONS[date_val[1]], year)
|
||||
value = "%d. %s %s" % (date_val[0], self.MONS[date_val[1]], year)
|
||||
|
||||
value = "%d. %s %s" % (date_val[0], (self.MONS)[date_val[1]],
|
||||
year)
|
||||
if date_val[2] < 0:
|
||||
return self._bce_str % value
|
||||
else:
|
||||
return value
|
||||
|
||||
|
||||
def display(self, date):
|
||||
"""
|
||||
Return a text string representing the date.
|
||||
"""
|
||||
|
||||
mod = date.get_modifier()
|
||||
cal = date.get_calendar()
|
||||
qual = date.get_quality()
|
||||
start = date.get_start_date()
|
||||
|
||||
qual_str = self._qual_str[qual]
|
||||
|
||||
qual_str = (self._qual_str)[qual]
|
||||
|
||||
if mod == Date.MOD_TEXTONLY:
|
||||
return date.get_text()
|
||||
elif start == Date.EMPTY:
|
||||
return ""
|
||||
elif mod == Date.MOD_SPAN:
|
||||
d1 = self.display_cal[cal](start)
|
||||
d2 = self.display_cal[cal](date.get_stop_date())
|
||||
return "%s%s %s %s %s%s" % (qual_str, u'de', d1, u'à', d2, self.calendar[cal])
|
||||
d1 = (self.display_cal)[cal](start)
|
||||
d2 = (self.display_cal)[cal](date.get_stop_date())
|
||||
return "%s%s %s %s %s%s" % (qual_str, u'de', d1, u'à', d2, (self.calendar)[cal])
|
||||
elif mod == Date.MOD_RANGE:
|
||||
d1 = self.display_cal[cal](start)
|
||||
d2 = self.display_cal[cal](date.get_stop_date())
|
||||
return "%s%s %s %s %s%s" % (qual_str, u'entre', d1, u'et', d2, self.calendar[cal])
|
||||
d1 = (self.display_cal)[cal](start)
|
||||
d2 = (self.display_cal)[cal](date.get_stop_date())
|
||||
return "%s%s %s %s %s%s" % (qual_str, u'entre', d1, u'et',
|
||||
d2, (self.calendar)[cal])
|
||||
else:
|
||||
text = self.display_cal[date.get_calendar()](start)
|
||||
return "%s%s%s%s" % (qual_str, self._mod_str[mod], text, self.calendar[cal])
|
||||
|
||||
text = (self.display_cal)[date.get_calendar()](start)
|
||||
return "%s%s%s%s" % (qual_str, (self._mod_str)[mod], text, (self.calendar)[cal])
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Register classes
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
register_datehandler(
|
||||
('fr_FR', 'fr', 'french', 'French', 'fr_CA', 'fr_BE', 'fr_CH'),
|
||||
DateParserFR, DateDisplayFR)
|
||||
|
||||
register_datehandler(('fr_FR', 'fr', 'french', 'French', 'fr_CA',
|
||||
'fr_BE', 'fr_CH'), DateParserFR, DateDisplayFR)
|
||||
|
@ -1,3 +1,4 @@
|
||||
#!/usr/bin/python
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
# Gramps - a GTK+/GNOME based genealogy program
|
||||
@ -20,8 +21,6 @@
|
||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
#
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# GRAMPS modules
|
||||
@ -38,85 +37,132 @@ from gen.plug import PluginManager
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
# level est utilisé pour trouver/afficher le niveau de la génération :
|
||||
# level est utilisé pour trouver/afficher le niveau de la génération :
|
||||
# à la %sème génération
|
||||
|
||||
_level_name = [ "première", "deuxième", "troisième", "quatrième",
|
||||
"cinquième", "sixième", "septième", "huitième",
|
||||
"neuvième", "dixième", "onzième", "douzième",
|
||||
"treizième", "quatorzième", "quinzième",
|
||||
"seizième", "dix-septième", "dix-huitième",
|
||||
"dix-neuvième", "vingtième", "vingt-et-unième",
|
||||
"vingt-deuxième", "vingt-troisième",
|
||||
"vingt-quatrième", "vingt-cinquième",
|
||||
"vingt-sixième", "vingt-septième",
|
||||
"vingt-huitième", "vingt-neuvième",
|
||||
"trentième", ]
|
||||
_level_name = [
|
||||
"première",
|
||||
"deuxième",
|
||||
"troisième",
|
||||
"quatrième",
|
||||
"cinquième",
|
||||
"sixième",
|
||||
"septième",
|
||||
"huitième",
|
||||
"neuvième",
|
||||
"dixième",
|
||||
"onzième",
|
||||
"douzième",
|
||||
"treizième",
|
||||
"quatorzième",
|
||||
"quinzième",
|
||||
"seizième",
|
||||
"dix-septième",
|
||||
"dix-huitième",
|
||||
"dix-neuvième",
|
||||
"vingtième",
|
||||
"vingt-et-unième",
|
||||
"vingt-deuxième",
|
||||
"vingt-troisième",
|
||||
"vingt-quatrième",
|
||||
"vingt-cinquième",
|
||||
"vingt-sixième",
|
||||
"vingt-septième",
|
||||
"vingt-huitième",
|
||||
"vingt-neuvième",
|
||||
"trentième",
|
||||
]
|
||||
|
||||
# pour le degrè (canon et civil), limitation 20+20 ainsi que pour
|
||||
# LE [premier] cousin
|
||||
# pour le degrè (canon et civil), limitation 20+20 ainsi que pour
|
||||
# LE [premier] cousin
|
||||
|
||||
_removed_level = [ "premier", "deuxième", "troisième", "quatrième",
|
||||
"cinquième", "sixième", "septième", "huitième",
|
||||
"neuvième", "dixième", "onzième", "douzième",
|
||||
"treizième", "quatorzième", "quinzième",
|
||||
"seizième", "dix-septième", "dix-huitième",
|
||||
"dix-neuvième", "vingtième", "vingt-et-unième",
|
||||
"vingt-deuxième", "vingt-troisième",
|
||||
"vingt-quatrième", "vingt-cinquième",
|
||||
"vingt-sixième", "vingt-septième",
|
||||
"vingt-huitième", "vingt-neuvième",
|
||||
"trentième", "trente-et-unième",
|
||||
"trente-deuxième", "trente-troisième",
|
||||
"trente-quatrième", "trente-cinquième",
|
||||
"trente-sixième", "trente-septième",
|
||||
"trente-huitième", "trente-neuvième",
|
||||
"quarantième", "quanrante-et-unième", ]
|
||||
_removed_level = [
|
||||
"premier",
|
||||
"deuxième",
|
||||
"troisième",
|
||||
"quatrième",
|
||||
"cinquième",
|
||||
"sixième",
|
||||
"septième",
|
||||
"huitième",
|
||||
"neuvième",
|
||||
"dixième",
|
||||
"onzième",
|
||||
"douzième",
|
||||
"treizième",
|
||||
"quatorzième",
|
||||
"quinzième",
|
||||
"seizième",
|
||||
"dix-septième",
|
||||
"dix-huitième",
|
||||
"dix-neuvième",
|
||||
"vingtième",
|
||||
"vingt-et-unième",
|
||||
"vingt-deuxième",
|
||||
"vingt-troisième",
|
||||
"vingt-quatrième",
|
||||
"vingt-cinquième",
|
||||
"vingt-sixième",
|
||||
"vingt-septième",
|
||||
"vingt-huitième",
|
||||
"vingt-neuvième",
|
||||
"trentième",
|
||||
"trente-et-unième",
|
||||
"trente-deuxième",
|
||||
"trente-troisième",
|
||||
"trente-quatrième",
|
||||
"trente-cinquième",
|
||||
"trente-sixième",
|
||||
"trente-septième",
|
||||
"trente-huitième",
|
||||
"trente-neuvième",
|
||||
"quarantième",
|
||||
"quanrante-et-unième",
|
||||
]
|
||||
|
||||
# listes volontairement limitées | small lists, use generation level if > [5]
|
||||
|
||||
_father_level = [ "", "le père%s", "le grand-père%s",
|
||||
"l'arrière-grand-père%s", "le trisaïeul%s", ]
|
||||
_father_level = ["", "le père%s", "le grand-père%s",
|
||||
"l'arrière-grand-père%s", "le trisaïeul%s"]
|
||||
|
||||
_mother_level = [ "", "la mère%s", "la grand-mère%s",
|
||||
"l'arrière-grand-mère%s", "la trisaïeule%s", ]
|
||||
_mother_level = ["", "la mère%s", "la grand-mère%s",
|
||||
"l'arrière-grand-mère%s", "la trisaïeule%s"]
|
||||
|
||||
_son_level = [ "", "le fils%s", "le petit-fils%s", "l'arrière-petit-fils%s", ]
|
||||
_son_level = ["", "le fils%s", "le petit-fils%s",
|
||||
"l'arrière-petit-fils%s"]
|
||||
|
||||
_daughter_level = [ "", "la fille%s", "la petite-fille%s",
|
||||
"l'arrière-petite-fille%s", ]
|
||||
_daughter_level = ["", "la fille%s", "la petite-fille%s",
|
||||
"l'arrière-petite-fille%s"]
|
||||
|
||||
_sister_level = [ "", "la sœur%s", "la tante%s", "la grand-tante%s",
|
||||
"l'arrière-grand-tante%s", ]
|
||||
_sister_level = ["", "la sœur%s", "la tante%s", "la grand-tante%s",
|
||||
"l'arrière-grand-tante%s"]
|
||||
|
||||
_brother_level = [ "", "le frère%s", "l'oncle%s", "le grand-oncle%s",
|
||||
"l'arrière-grand-oncle%s", ]
|
||||
_brother_level = ["", "le frère%s", "l'oncle%s", "le grand-oncle%s",
|
||||
"l'arrière-grand-oncle%s"]
|
||||
|
||||
_nephew_level = [ "", "le neveu%s", "le petit-neveu%s",
|
||||
"l'arrière-petit-neveu%s", ]
|
||||
_nephew_level = ["", "le neveu%s", "le petit-neveu%s",
|
||||
"l'arrière-petit-neveu%s"]
|
||||
|
||||
_niece_level = [ "", "la nièce%s", "la petite-nièce%s",
|
||||
"l'arrière-petite-nièce%s", ]
|
||||
_niece_level = ["", "la nièce%s", "la petite-nièce%s",
|
||||
"l'arrière-petite-nièce%s"]
|
||||
|
||||
# kinship report
|
||||
|
||||
_parents_level = [ "", "les parents", "les grands-parents",
|
||||
"les arrières-grands-parents", "les trisaïeux", ]
|
||||
_parents_level = ["", "les parents", "les grands-parents",
|
||||
"les arrières-grands-parents", "les trisaïeux"]
|
||||
|
||||
_children_level = [ "", "les enfants", "les petits-enfants",
|
||||
"les arrières-petits-enfants",
|
||||
"les arrières-arrières-petits-enfants", ]
|
||||
_children_level = ["", "les enfants", "les petits-enfants",
|
||||
"les arrières-petits-enfants",
|
||||
"les arrières-arrières-petits-enfants"]
|
||||
|
||||
_siblings_level = [ "", "les frères et les sœurs",
|
||||
"les oncles et les tantes",
|
||||
"les grands-oncles et les grands-tantes",
|
||||
"les arrières-grands-oncles et les arrières-grands-tantes",
|
||||
]
|
||||
_siblings_level = ["", "les frères et les sœurs",
|
||||
"les oncles et les tantes",
|
||||
"les grands-oncles et les grands-tantes",
|
||||
"les arrières-grands-oncles et les arrières-grands-tantes"]
|
||||
|
||||
_nephews_nieces_level = [ "", "les neveux et les nièces",
|
||||
"les petits-neveux et les petites-nièces",
|
||||
"les arrière-petits-neveux et les arrières-petites-nièces",
|
||||
]
|
||||
_nephews_nieces_level = ["", "les neveux et les nièces",
|
||||
"les petits-neveux et les petites-nièces",
|
||||
"les arrière-petits-neveux et les arrières-petites-nièces"]
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -124,10 +170,10 @@ _nephews_nieces_level = [ "", "les neveux et les nièces",
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
|
||||
class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
|
||||
INLAW = ' (par alliance)'
|
||||
|
||||
INLAW = ' (par alliance)'
|
||||
|
||||
def __init__(self):
|
||||
Relationship.RelationshipCalculator.__init__(self)
|
||||
@ -136,111 +182,109 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
|
||||
# de la personne active à l'ascendant commun Ga=[level]
|
||||
|
||||
def get_cousin(self, level, removed, dir = '', inlaw=''):
|
||||
def get_cousin(self, level, removed, dir="", inlaw=""):
|
||||
if removed == 0 and level < len(_level_name):
|
||||
return "le %s cousin%s" % (_removed_level[level-1],
|
||||
inlaw)
|
||||
elif (level) < (removed):
|
||||
rel_str = self.get_uncle(level-1, inlaw)
|
||||
return "le %s cousin%s" % (_removed_level[level - 1], inlaw)
|
||||
elif level < removed:
|
||||
rel_str = self.get_uncle(level - 1, inlaw)
|
||||
else:
|
||||
# limitation gen = 29
|
||||
return "le cousin lointain, relié à la %s génération" % (
|
||||
_level_name[removed])
|
||||
|
||||
def get_cousine(self, level, removed, dir = '', inlaw=''):
|
||||
# limitation gen = 29
|
||||
|
||||
return "le cousin lointain, relié à la %s génération" % \
|
||||
_level_name[removed]
|
||||
|
||||
def get_cousine(self, level, removed, dir="", inlaw=""):
|
||||
if removed == 0 and level < len(_level_name):
|
||||
return "la %s cousine%s" % (_level_name[level-1],
|
||||
inlaw)
|
||||
elif (level) < (removed):
|
||||
rel_str = self.get_aunt(level-1, inlaw)
|
||||
return "la %s cousine%s" % (_level_name[level - 1], inlaw)
|
||||
elif level < removed:
|
||||
rel_str = self.get_aunt(level - 1, inlaw)
|
||||
else:
|
||||
return "la cousine lointaine, reliée à la %s génération" % (
|
||||
_level_name[removed])
|
||||
return "la cousine lointaine, reliée à la %s génération" % \
|
||||
_level_name[removed]
|
||||
|
||||
def get_parents(self, level):
|
||||
if level > len(_parents_level)-1:
|
||||
return "les ascendants lointains, à la %s génération" % (
|
||||
_level_name[level])
|
||||
if level > len(_parents_level) - 1:
|
||||
return "les ascendants lointains, à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _parents_level[level]
|
||||
|
||||
def get_father(self, level, inlaw=''):
|
||||
if level > len(_father_level)-1:
|
||||
return "l'ascendant lointain, à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_father(self, level, inlaw=""):
|
||||
if level > len(_father_level) - 1:
|
||||
return "l'ascendant lointain, à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _father_level[level] % inlaw
|
||||
|
||||
def get_mother(self, level, inlaw=''):
|
||||
if level > len(_mother_level)-1:
|
||||
return "l'ascendante lointaine, à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_mother(self, level, inlaw=""):
|
||||
if level > len(_mother_level) - 1:
|
||||
return "l'ascendante lointaine, à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _mother_level[level] % inlaw
|
||||
|
||||
def get_parent_unknown(self, level, inlaw=''):
|
||||
if level > len(_level_name)-1:
|
||||
return "l'ascendant lointain, à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_parent_unknown(self, level, inlaw=""):
|
||||
if level > len(_level_name) - 1:
|
||||
return "l'ascendant lointain, à la %s génération" % \
|
||||
_level_name[level]
|
||||
elif level == 1:
|
||||
return "un parent%s" % (inlaw)
|
||||
return "un parent%s" % inlaw
|
||||
else:
|
||||
return "un parent lointain%s" % (inlaw)
|
||||
return "un parent lointain%s" % inlaw
|
||||
|
||||
def get_son(self, level, inlaw=''):
|
||||
if level > len(_son_level)-1:
|
||||
return "le descendant lointain, à la %s génération" % (
|
||||
_level_name[level+1])
|
||||
def get_son(self, level, inlaw=""):
|
||||
if level > len(_son_level) - 1:
|
||||
return "le descendant lointain, à la %s génération" % \
|
||||
_level_name[level + 1]
|
||||
else:
|
||||
return _son_level[level] % (inlaw)
|
||||
return _son_level[level] % inlaw
|
||||
|
||||
def get_daughter(self, level, inlaw=''):
|
||||
if level > len(_daughter_level)-1:
|
||||
return "la descendante lointaine, à la %s génération" % (
|
||||
_level_name[level+1])
|
||||
def get_daughter(self, level, inlaw=""):
|
||||
if level > len(_daughter_level) - 1:
|
||||
return "la descendante lointaine, à la %s génération" % \
|
||||
_level_name[level + 1]
|
||||
else:
|
||||
return _daughter_level[level] % (inlaw)
|
||||
return _daughter_level[level] % inlaw
|
||||
|
||||
def get_child_unknown(self, level, inlaw=''):
|
||||
if level > len(_level_name)-1:
|
||||
return "le descendant lointain, à la %s génération" % (
|
||||
_level_name[level+1])
|
||||
def get_child_unknown(self, level, inlaw=""):
|
||||
if level > len(_level_name) - 1:
|
||||
return "le descendant lointain, à la %s génération" % \
|
||||
_level_name[level + 1]
|
||||
elif level == 1:
|
||||
return "un enfant%s" % (inlaw)
|
||||
return "un enfant%s" % inlaw
|
||||
else:
|
||||
return "un descendant lointain%s" % (inlaw)
|
||||
return "un descendant lointain%s" % inlaw
|
||||
|
||||
def get_sibling_unknown(self, level, inlaw=''):
|
||||
return "un parent lointain%s" % (inlaw)
|
||||
def get_sibling_unknown(self, level, inlaw=""):
|
||||
return "un parent lointain%s" % inlaw
|
||||
|
||||
def get_uncle(self, level, inlaw=''):
|
||||
if level > len(_brother_level)-1:
|
||||
return "l'oncle lointain, relié à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_uncle(self, level, inlaw=""):
|
||||
if level > len(_brother_level) - 1:
|
||||
return "l'oncle lointain, relié à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _brother_level[level] % (inlaw)
|
||||
return _brother_level[level] % inlaw
|
||||
|
||||
def get_aunt(self, level, inlaw=''):
|
||||
if level > len(_sister_level)-1:
|
||||
return "la tante lointaine, reliée à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_aunt(self, level, inlaw=""):
|
||||
if level > len(_sister_level) - 1:
|
||||
return "la tante lointaine, reliée à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _sister_level[level] % (inlaw)
|
||||
return _sister_level[level] % inlaw
|
||||
|
||||
def get_nephew(self, level, inlaw=''):
|
||||
if level > len(_nephew_level)-1:
|
||||
return "le neveu lointain, à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_nephew(self, level, inlaw=""):
|
||||
if level > len(_nephew_level) - 1:
|
||||
return "le neveu lointain, à la %s génération" % _level_name[level]
|
||||
else:
|
||||
return _nephew_level[level] % (inlaw)
|
||||
return _nephew_level[level] % inlaw
|
||||
|
||||
def get_niece(self, level, inlaw=''):
|
||||
if level > len(_niece_level)-1:
|
||||
return "la nièce lointaine, à la %s génération" % (
|
||||
_level_name[level])
|
||||
def get_niece(self, level, inlaw=""):
|
||||
if level > len(_niece_level) - 1:
|
||||
return "la nièce lointaine, à la %s génération" % \
|
||||
_level_name[level]
|
||||
else:
|
||||
return _niece_level[level] % (inlaw)
|
||||
|
||||
return _niece_level[level] % inlaw
|
||||
|
||||
# kinship report
|
||||
|
||||
@ -248,230 +292,285 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
"""
|
||||
voir Relationship.py
|
||||
"""
|
||||
|
||||
rel_str = "des parents lointains"
|
||||
gen = " à la %sème génération"
|
||||
bygen = " par la %sème génération"
|
||||
cmt = " (frères ou sœurs d'un ascendant" + gen % (
|
||||
Ga) + ")"
|
||||
cmt = " (frères ou sœurs d'un ascendant" + gen % Ga + ")"
|
||||
if Ga == 0:
|
||||
|
||||
# These are descendants
|
||||
|
||||
if Gb < len(_children_level):
|
||||
rel_str = _children_level[Gb]
|
||||
else:
|
||||
rel_str = "les descendants" + gen % (
|
||||
Gb+1)
|
||||
rel_str = "les descendants" + gen % (Gb + 1)
|
||||
elif Gb == 0:
|
||||
|
||||
# These are parents/grand parents
|
||||
|
||||
if Ga < len(_parents_level):
|
||||
rel_str = _parents_level[Ga]
|
||||
else:
|
||||
rel_str = "les ascendants" + gen % (
|
||||
Ga+1)
|
||||
rel_str = "les ascendants" + gen % (Ga + 1)
|
||||
elif Gb == 1:
|
||||
|
||||
# These are siblings/aunts/uncles
|
||||
|
||||
if Ga < len(_siblings_level):
|
||||
rel_str = _siblings_level[Ga]
|
||||
else:
|
||||
rel_str = "Les enfants d'un ascendant" + gen % (
|
||||
Ga+1) + cmt
|
||||
rel_str = "Les enfants d'un ascendant" + gen % (Ga + 1) + \
|
||||
cmt
|
||||
elif Ga == 1:
|
||||
|
||||
# These are nieces/nephews
|
||||
|
||||
if Gb < len(_nephews_nieces_level):
|
||||
rel_str = _nephews_nieces_level[Gb-1]
|
||||
rel_str = _nephews_nieces_level[Gb - 1]
|
||||
else:
|
||||
rel_str = "les neveux et les nièces" + gen % (
|
||||
Gb)
|
||||
rel_str = "les neveux et les nièces" + gen % Gb
|
||||
elif Ga > 1 and Ga == Gb:
|
||||
|
||||
# These are cousins in the same generation
|
||||
# use custom level for latin words
|
||||
|
||||
if Ga == 2:
|
||||
rel_str = "les cousins germains et cousines germaines"
|
||||
rel_str = "les cousins germains et cousines germaines"
|
||||
elif Ga <= len(_level_name):
|
||||
|
||||
# %ss for plural
|
||||
rel_str = "les %ss cousins et cousines" % _level_name[Ga-2]
|
||||
# security
|
||||
|
||||
rel_str = "les %ss cousins et cousines" % _level_name[Ga -
|
||||
2]
|
||||
else:
|
||||
|
||||
# security
|
||||
|
||||
rel_str = "les cousins et cousines"
|
||||
elif Ga > 1 and Ga > Gb:
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a higher generation from the common ancestor than the
|
||||
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a higher generation from the common ancestor than the
|
||||
# first person.
|
||||
# use custom level for latin words and specific relation
|
||||
|
||||
if Ga == 3 and Gb == 2:
|
||||
desc = " (cousins germains d'un parent)"
|
||||
rel_str = "les oncles et tantes à la mode de Bretagne" + desc
|
||||
elif Gb <= len(_level_name) and (Ga-Gb) < len(_removed_level) and (Ga+Gb+1) < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (
|
||||
_removed_level[Gb], _removed_level[Ga] )
|
||||
civ = " et au %s degré (civil)" % ( _removed_level[Ga+Gb+1] )
|
||||
rel_str = "les oncles et tantes à la mode de Bretagne" + \
|
||||
desc
|
||||
elif Gb <= len(_level_name) and Ga - Gb < len(_removed_level) and \
|
||||
Ga + Gb + 1 < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (_removed_level[Gb],
|
||||
_removed_level[Ga])
|
||||
civ = " et au %s degré (civil)" % _removed_level[Ga + Gb +
|
||||
1]
|
||||
rel_str = "les oncles et tantes" + can + civ
|
||||
elif Ga < len(_level_name):
|
||||
rel_str = "les grands-oncles et grands-tantes" + bygen % (
|
||||
Ga+1)
|
||||
rel_str = "les grands-oncles et grands-tantes" + bygen % \
|
||||
(Ga + 1)
|
||||
else:
|
||||
return rel_str
|
||||
elif Gb > 1 and Gb > Ga:
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a lower generation from the common ancestor than the
|
||||
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a lower generation from the common ancestor than the
|
||||
# first person.
|
||||
# use custom level for latin words and specific relation
|
||||
|
||||
if Ga == 2 and Gb == 3:
|
||||
info = " (cousins issus d'un germain)"
|
||||
rel_str = "les neveux et nièces à la mode de Bretagne" + info
|
||||
elif Ga <= len(_level_name) and (Gb-Ga) < len(_removed_level) and (Ga+Gb+1) < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (
|
||||
_removed_level[Gb], _removed_level[Ga] )
|
||||
civ = " et au %s degré (civil)" % ( _removed_level[Ga+Gb+1] )
|
||||
rel_str = "les neveux et nièces à la mode de Bretagne" + \
|
||||
info
|
||||
elif Ga <= len(_level_name) and Gb - Ga < len(_removed_level) and \
|
||||
Ga + Gb + 1 < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (_removed_level[Gb],
|
||||
_removed_level[Ga])
|
||||
civ = " et au %s degré (civil)" % _removed_level[Ga + Gb +
|
||||
1]
|
||||
rel_str = "les neveux et nièces" + can + civ
|
||||
elif Ga < len(_level_name):
|
||||
rel_str = "les neveux et nièces" + bygen % (
|
||||
Gb)
|
||||
rel_str = "les neveux et nièces" + bygen % Gb
|
||||
else:
|
||||
return rel_str
|
||||
return rel_str
|
||||
|
||||
|
||||
# quick report (missing on RelCalc tool - Status Bar)
|
||||
|
||||
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):
|
||||
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,
|
||||
):
|
||||
"""
|
||||
voir Relationship.py
|
||||
"""
|
||||
|
||||
if only_birth:
|
||||
step = ''
|
||||
step = ""
|
||||
else:
|
||||
step = self.STEP
|
||||
|
||||
if in_law_a or in_law_b :
|
||||
if in_law_a or in_law_b:
|
||||
inlaw = self.INLAW
|
||||
else:
|
||||
inlaw = ''
|
||||
|
||||
|
||||
rel_str = "un parent lointains%s" % (inlaw)
|
||||
inlaw = ""
|
||||
|
||||
rel_str = "un parent lointains%s" % inlaw
|
||||
bygen = " par la %sème génération"
|
||||
if Ga == 0:
|
||||
|
||||
# b is descendant of a
|
||||
if Gb == 0 :
|
||||
|
||||
if Gb == 0:
|
||||
rel_str = 'le même individu'
|
||||
elif gender_b == gen.lib.Person.MALE and Gb < len(_son_level):
|
||||
|
||||
# spouse of daughter
|
||||
|
||||
if inlaw and Gb == 1 and not step:
|
||||
rel_str = "le gendre"
|
||||
else:
|
||||
rel_str = self.get_son(Gb)
|
||||
elif gender_b == gen.lib.Person.FEMALE and Gb < len(_daughter_level):
|
||||
|
||||
# spouse of son
|
||||
|
||||
if inlaw and Gb == 1 and not step:
|
||||
rel_str = "la bru"
|
||||
else:
|
||||
rel_str = self.get_daughter(Gb)
|
||||
# don't display inlaw
|
||||
elif Gb < len(_level_name) and gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le descendant lointain (%dème génération)" % (
|
||||
Gb+1)
|
||||
|
||||
# don't display inlaw
|
||||
|
||||
rel_str = "le descendant lointain (%dème génération)" % \
|
||||
(Gb + 1)
|
||||
elif Gb < len(_level_name) and gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "la descendante lointaine (%dème génération)" % (
|
||||
Gb+1)
|
||||
rel_str = "la descendante lointaine (%dème génération)" % \
|
||||
(Gb + 1)
|
||||
else:
|
||||
return self.get_child_unknown(Gb)
|
||||
elif Gb == 0:
|
||||
|
||||
# b is parents/grand parent of a
|
||||
|
||||
if gender_b == gen.lib.Person.MALE and Ga < len(_father_level):
|
||||
|
||||
# other spouse of father (new parent)
|
||||
|
||||
if Ga == 1 and inlaw and self.STEP_SIB:
|
||||
rel_str = "le beau-père"
|
||||
# father of spouse (family of spouse)
|
||||
elif Ga == 1 and inlaw:
|
||||
|
||||
# father of spouse (family of spouse)
|
||||
|
||||
rel_str = "le père du conjoint"
|
||||
else:
|
||||
rel_str = self.get_father(Ga, inlaw)
|
||||
elif gender_b == gen.lib.Person.FEMALE and Ga < len(_mother_level):
|
||||
|
||||
# other spouse of mother (new parent)
|
||||
|
||||
if Ga == 1 and inlaw and self.STEP_SIB:
|
||||
rel_str = "la belle-mère"
|
||||
# mother of spouse (family of spouse)
|
||||
elif Ga == 1 and inlaw:
|
||||
|
||||
# mother of spouse (family of spouse)
|
||||
|
||||
rel_str = "la mère du conjoint"
|
||||
else:
|
||||
rel_str = self.get_mother(Ga, inlaw)
|
||||
elif Ga < len(_level_name) and gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "l'ascendant lointain%s (%dème génération)" % (
|
||||
inlaw, Ga+1)
|
||||
rel_str = "l'ascendant lointain%s (%dème génération)" % \
|
||||
(inlaw, Ga + 1)
|
||||
elif Ga < len(_level_name) and gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "l'ascendante lointaine%s (%dème génération)" % (
|
||||
inlaw, Ga+1)
|
||||
rel_str = "l'ascendante lointaine%s (%dème génération)" % \
|
||||
(inlaw, Ga + 1)
|
||||
else:
|
||||
return self.get_parent_unknown(Ga, inlaw)
|
||||
elif Gb == 1:
|
||||
|
||||
# b is sibling/aunt/uncle of a
|
||||
|
||||
if gender_b == gen.lib.Person.MALE and Ga < len(_brother_level):
|
||||
rel_str = self.get_uncle(Ga, inlaw)
|
||||
elif gender_b == gen.lib.Person.FEMALE and Ga < len(_sister_level):
|
||||
rel_str = self.get_aunt(Ga, inlaw)
|
||||
else:
|
||||
|
||||
# don't display inlaw
|
||||
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "l'oncle lointain" + bygen % (
|
||||
Ga+1)
|
||||
rel_str = "l'oncle lointain" + bygen % (Ga + 1)
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "la tante lointaine" + bygen % (
|
||||
Ga+1)
|
||||
rel_str = "la tante lointaine" + bygen % (Ga + 1)
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
elif Ga == 1:
|
||||
|
||||
# b is niece/nephew of a
|
||||
|
||||
if gender_b == gen.lib.Person.MALE and Gb < len(_nephew_level):
|
||||
rel_str = self.get_nephew(Gb-1, inlaw)
|
||||
rel_str = self.get_nephew(Gb - 1, inlaw)
|
||||
elif gender_b == gen.lib.Person.FEMALE and Gb < len(_niece_level):
|
||||
rel_str = self.get_niece(Gb-1, inlaw)
|
||||
rel_str = self.get_niece(Gb - 1, inlaw)
|
||||
else:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le neveu lointain%s (%dème génération)" % (
|
||||
inlaw, Gb)
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le neveu lointain%s (%dème génération)" % \
|
||||
(inlaw, Gb)
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "la nièce lointaine%s (%dème génération)" % (
|
||||
inlaw, Gb)
|
||||
rel_str = "la nièce lointaine%s (%dème génération)" % \
|
||||
(inlaw, Gb)
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
elif Ga == Gb:
|
||||
|
||||
# a and b cousins in the same generation
|
||||
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = self.get_cousin(Ga-1, 0, dir = '',
|
||||
inlaw=inlaw)
|
||||
rel_str = self.get_cousin(Ga - 1, 0, dir="", inlaw=inlaw)
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = self.get_cousine(Ga-1, 0, dir = '',
|
||||
inlaw=inlaw)
|
||||
rel_str = self.get_cousine(Ga - 1, 0, dir="", inlaw=
|
||||
inlaw)
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga-1, inlaw)
|
||||
rel_str = self.get_sibling_unknown(Ga - 1, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
elif Ga > 1 and Ga > Gb:
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a higher generation from the common ancestor than the
|
||||
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a higher generation from the common ancestor than the
|
||||
# first person.
|
||||
|
||||
if Ga == 3 and Gb == 2:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
desc = " (cousin germain d'un parent)"
|
||||
rel_str = "l'oncle à la mode de Bretagne" + desc
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
desc = " (cousine germaine d'un parent)"
|
||||
rel_str = "la tante à la mode de Bretagne" + desc
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
return self.get_sibling_unknown(Ga, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
elif Gb <= len(_level_name) and (Ga-Gb) < len(_removed_level) and (Ga+Gb+1) < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (
|
||||
_removed_level[Gb], _removed_level[Ga] )
|
||||
civ = " et au %s degré (civil)" % ( _removed_level[Ga+Gb+1] )
|
||||
elif Gb <= len(_level_name) and Ga - Gb < len(_removed_level) and \
|
||||
Ga + Gb + 1 < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (_removed_level[Gb],
|
||||
_removed_level[Ga])
|
||||
civ = " et au %s degré (civil)" % _removed_level[Ga + Gb +
|
||||
1]
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "l'oncle" + can + civ
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
@ -481,32 +580,36 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
else:
|
||||
return rel_str
|
||||
else:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = self.get_uncle(Ga, inlaw)
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = self.get_aunt(Ga, inlaw)
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
return rel_str
|
||||
elif Gb > 1 and Gb > Ga:
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a lower generation from the common ancestor than the
|
||||
|
||||
# These are cousins in different generations with the second person
|
||||
# being in a lower generation from the common ancestor than the
|
||||
# first person.
|
||||
|
||||
if Ga == 2 and Gb == 3:
|
||||
info = " (cousins issus d'un germain)"
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le neveu à la mode de Bretagne" + info
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "la nièce à la mode de Bretagne" + info
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga, inlaw)
|
||||
else:
|
||||
return rel_str
|
||||
elif Ga <= len(_level_name) and (Gb-Ga) < len(_removed_level) and (Ga+Gb+1) < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (
|
||||
_removed_level[Gb], _removed_level[Ga] )
|
||||
civ = " et au %s degré (civil)" % ( _removed_level[Ga+Gb+1] )
|
||||
return rel_str
|
||||
elif Ga <= len(_level_name) and Gb - Ga < len(_removed_level) and \
|
||||
Ga + Gb + 1 < len(_removed_level):
|
||||
can = " du %s au %s degré (canon)" % (_removed_level[Gb],
|
||||
_removed_level[Ga])
|
||||
civ = " et au %s degré (civil)" % _removed_level[Ga + Gb +
|
||||
1]
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le neveu" + can + civ
|
||||
if gender_b == gen.lib.Person.FEMALE:
|
||||
@ -520,7 +623,7 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
else:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = self.get_nephew(Ga, inlaw)
|
||||
elif gender_b ==gen.lib.Person.FEMALE:
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = self.get_niece(Ga, inlaw)
|
||||
elif gender_b == gen.lib.Person.UNKNOWN:
|
||||
rel_str = self.get_sibling_unknown(Ga, inlaw)
|
||||
@ -530,14 +633,14 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
|
||||
# RelCalc tool - Status Bar
|
||||
|
||||
def get_sibling_relationship_string(self, sib_type, gender_a, gender_b,
|
||||
in_law_a=False, in_law_b=False):
|
||||
def get_sibling_relationship_string(self, sib_type, gender_a,
|
||||
gender_b, in_law_a=False, in_law_b=False):
|
||||
|
||||
if in_law_a or in_law_b :
|
||||
if in_law_a or in_law_b:
|
||||
inlaw = self.INLAW
|
||||
else:
|
||||
inlaw = ''
|
||||
|
||||
inlaw = ""
|
||||
|
||||
if sib_type == self.NORM_SIB:
|
||||
if not inlaw:
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
@ -568,16 +671,20 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
rel_str = "la belle-sœur"
|
||||
else:
|
||||
rel_str = "le beau-frère ou la belle-sœur"
|
||||
# Logique inversée ! Pourquoi ?
|
||||
elif sib_type == self.HALF_SIB_MOTHER:
|
||||
|
||||
# Logique inversée ! Pourquoi ?
|
||||
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le demi-frère consanguin"
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
rel_str = "la demi-sœur consanguine"
|
||||
else:
|
||||
rel_str = "le demi-frère ou la demi-sœur consanguin(e)"
|
||||
# Logique inversée ! Pourquoi ?
|
||||
elif sib_type == self.HALF_SIB_FATHER:
|
||||
|
||||
# Logique inversée ! Pourquoi ?
|
||||
|
||||
if gender_b == gen.lib.Person.MALE:
|
||||
rel_str = "le demi-frère utérin"
|
||||
elif gender_b == gen.lib.Person.FEMALE:
|
||||
@ -596,24 +703,37 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Register this class with the Plugins system
|
||||
# Register this class with the Plugins system
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
pmgr = PluginManager.get_instance()
|
||||
pmgr.register_relcalc(RelationshipCalculator,
|
||||
["fr", "FR", "fr_FR", "fr_CA", "francais", "Francais", "fr_FR.UTF8",
|
||||
"fr_FR@euro", "fr_FR.UTF8@euro",
|
||||
"french","French", "fr_FR.UTF-8", "fr_FR.utf-8", "fr_FR.utf8",
|
||||
"fr_CA.UTF-8"])
|
||||
pmgr.register_relcalc(RelationshipCalculator, [
|
||||
"fr",
|
||||
"FR",
|
||||
"fr_FR",
|
||||
"fr_CA",
|
||||
"francais",
|
||||
"Francais",
|
||||
"fr_FR.UTF8",
|
||||
"fr_FR@euro",
|
||||
"fr_FR.UTF8@euro",
|
||||
"french",
|
||||
"French",
|
||||
"fr_FR.UTF-8",
|
||||
"fr_FR.utf-8",
|
||||
"fr_FR.utf8",
|
||||
"fr_CA.UTF-8",
|
||||
])
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
||||
# Test function. Call it as follows from the command line (so as to find
|
||||
# imported modules):
|
||||
# export PYTHONPATH=/path/to/gramps/src
|
||||
# python src/plugins/rel_fr.py
|
||||
# export PYTHONPATH=/path/to/gramps/src
|
||||
# python src/plugins/rel_fr.py
|
||||
# (Above not needed here)
|
||||
|
||||
|
||||
"""TRANSLATORS, copy this if statement at the bottom of your
|
||||
rel_xx.py module, and test your work with:
|
||||
python src/plugins/rel_xx.py
|
||||
|
Loading…
Reference in New Issue
Block a user