diff --git a/src/DateHandler/_Date_fr.py b/src/DateHandler/_Date_fr.py index 81512f3ff..8de8cdd4d 100644 --- a/src/DateHandler/_Date_fr.py +++ b/src/DateHandler/_Date_fr.py @@ -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.+)\s+(à)\s+(?P.+)", re.IGNORECASE) - self._range = re.compile(u"(entre|ent\.|ent)\s+(?P.+)\s+(et)\s+(?P.+)", re.IGNORECASE) + + self._numeric = re.compile("((\d+)[/\. ])?\s*((\d+)[/\.])?\s*(\d+)\s*$") + self._span = re.compile(u"(de)\s+(?P.+)\s+(à)\s+(?P.+)", + re.IGNORECASE) + self._range = re.compile(u"(entre|ent\.|ent)\s+(?P.+)\s+(et)\s+(?P.+)", + 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) diff --git a/src/plugins/rel/rel_fr.py b/src/plugins/rel/rel_fr.py index 66882c32e..6fe0b0f5e 100644 --- a/src/plugins/rel/rel_fr.py +++ b/src/plugins/rel/rel_fr.py @@ -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