* src/plugins/rel_nl.py: new half sibling types

* src/plugins/rel_it.py: new half sibling types
	* src/Relationship.py: change the sibling type to distinguish
	side of relation. Correct bug in sibling type determination.

2007-11-23 Benny Malengier <benny.malengier@gramps-project.org>


svn: r9390
This commit is contained in:
Benny Malengier 2007-11-23 15:02:30 +00:00
parent 5a37ee41ea
commit f000b4575a
4 changed files with 42 additions and 15 deletions

View File

@ -1,3 +1,9 @@
2007-11-23 Benny Malengier <benny.malengier@gramps-project.org>
* src/plugins/rel_nl.py: new half sibling types
* src/plugins/rel_it.py: new half sibling types
* src/Relationship.py: change the sibling type to distinguish
side of relation. Correct bug in sibling type determination.
2007-11-23 Benny Malengier <benny.malengier@gramps-project.org> 2007-11-23 Benny Malengier <benny.malengier@gramps-project.org>
* src/DataViews/_RelationView.py: tooltip cleanup, see also #256 * src/DataViews/_RelationView.py: tooltip cleanup, see also #256

View File

@ -356,10 +356,11 @@ class RelationshipCalculator:
REL_FAM_INLAW_PREFIX = 'L' # going to the partner. REL_FAM_INLAW_PREFIX = 'L' # going to the partner.
#sibling types #sibling types
NORM_SIB = 0 NORM_SIB = 0 # same birth parents
HALF_SIB = 1 HALF_SIB_MOTHER = 1 # same mother, father known to be different
STEP_SIB = 2 HALF_SIB_FATHER = 2 # same father, mother known to be different
UNKNOWN_SIB = 3 STEP_SIB = 3 # birth parents known to be different
UNKNOWN_SIB = 4 # insufficient data to draw conclusion
#sibling strings #sibling strings
STEP= 'step' STEP= 'step'
@ -545,9 +546,11 @@ class RelationshipCalculator:
if fatherorig and motherorig and fatherother and motherother: if fatherorig and motherorig and fatherother and motherother:
if fatherother == fatherorig and motherother == motherorig: if fatherother == fatherorig and motherother == motherorig:
return self.NORM_SIB return self.NORM_SIB
elif fatherother == fatherorig or motherother == motherorig: elif fatherother == fatherorig:
#all birth parents are known, one #all birth parents are known, one
return self.HALF_SIB return self.HALF_SIB_FATHER
elif motherother == motherorig:
return self.HALF_SIB_MOTHER
else : else :
return self.STEP_SIB return self.STEP_SIB
else: else:
@ -556,17 +559,29 @@ class RelationshipCalculator:
orig_nb_par = self._get_nonbirth_parent_list(db, orig) orig_nb_par = self._get_nonbirth_parent_list(db, orig)
if fatherother and fatherother in orig_nb_par: if fatherother and fatherother in orig_nb_par:
#the birth parent of other is non-birth of orig #the birth parent of other is non-birth of orig
return self.STEP_SIB if motherother and motherother == motherorig:
return self.HALF_SIB_MOTHER
else:
return self.STEP_SIB
if motherother and motherother in orig_nb_par: if motherother and motherother in orig_nb_par:
#the birth parent of other is non-birth of orig #the birth parent of other is non-birth of orig
return self.STEP_SIB if fatherother and fatherother == fatherorig:
return self.HALF_SIB_FATHER
else:
return self.STEP_SIB
other_nb_par = self._get_nonbirth_parent_list(db, other) other_nb_par = self._get_nonbirth_parent_list(db, other)
if fatherorig and fatherorig in other_nb_par: if fatherorig and fatherorig in other_nb_par:
#the one birth parent of other is non-birth of orig #the one birth parent of other is non-birth of orig
return self.STEP_SIB if motherorig and motherother == motherorig:
return self.HALF_SIB_MOTHER
else:
return self.STEP_SIB
if motherorig and motherorig in other_nb_par: if motherorig and motherorig in other_nb_par:
#the one birth parent of other is non-birth of orig #the one birth parent of other is non-birth of orig
return self.STEP_SIB if fatherother and fatherother == fatherorig:
return self.HALF_SIB_FATHER
else:
return self.STEP_SIB
#there is an unknown birth parent, it could be that this is the #there is an unknown birth parent, it could be that this is the
# birth parent of the other person # birth parent of the other person
return self.UNKNOWN_SIB return self.UNKNOWN_SIB
@ -1606,7 +1621,8 @@ class RelationshipCalculator:
""" """
if sib_type == self.NORM_SIB or sib_type == self.UNKNOWN_SIB: if sib_type == self.NORM_SIB or sib_type == self.UNKNOWN_SIB:
typestr = '' typestr = ''
elif sib_type == self.HALF_SIB: elif sib_type == self.HALF_SIB_MOTHER \
or sib_type == self.HALF_SIB_FATHER:
typestr = self.HALF typestr = self.HALF
elif sib_type == self.STEP_SIB: elif sib_type == self.STEP_SIB:
typestr = self.STEP typestr = self.STEP
@ -2059,7 +2075,9 @@ def _test(rc, onlybirth, inlawa, inlawb, printrelstr):
print rel print rel
def _testsibling(rc): def _testsibling(rc):
vals = [(rc.NORM_SIB, 'sibling'), (rc.HALF_SIB, 'half sib'), vals = [(rc.NORM_SIB, 'sibling'),
(rc.HALF_SIB_MOTHER, 'half sib mother side'),
(rc.HALF_SIB_FATHER, 'half sib father side'),
(rc.STEP_SIB, 'step sib'), (rc.UNKNOWN_SIB, 'undetermined sib')] (rc.STEP_SIB, 'step sib'), (rc.UNKNOWN_SIB, 'undetermined sib')]
FMT = '%+50s' FMT = '%+50s'
for gendr, strgen in [(gen.lib.Person.MALE, 'male'), for gendr, strgen in [(gen.lib.Person.MALE, 'male'),

View File

@ -484,7 +484,9 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
rel_str = 'la cognata' rel_str = 'la cognata'
else: else:
rel_str = 'il cognato/a' rel_str = 'il cognato/a'
elif sib_type == self.HALF_SIB or sib_type == self.STEP_SIB: elif sib_type == self.HALF_SIB_FATHER \
or sib_type == self.HALF_SIB_MOTHER \
or sib_type == self.STEP_SIB:
#Italian has no difference between half and step sibling! #Italian has no difference between half and step sibling!
if not inlaw: if not inlaw:
if gender_b == gen.lib.Person.MALE: if gender_b == gen.lib.Person.MALE:

View File

@ -514,7 +514,8 @@ class RelationshipCalculator(Relationship.RelationshipCalculator):
""" """
if sib_type == self.NORM_SIB or sib_type == self.UNKNOWN_SIB: if sib_type == self.NORM_SIB or sib_type == self.UNKNOWN_SIB:
typestr = '' typestr = ''
elif sib_type == self.HALF_SIB: elif sib_type == self.HALF_SIB_FATHER \
or sib_type == self.HALF_SIB_MOTHER:
typestr = self.HALF typestr = self.HALF
elif sib_type == self.STEP_SIB: elif sib_type == self.STEP_SIB:
typestr = self.STEP typestr = self.STEP