GEDCOM fixes

svn: r392
This commit is contained in:
Don Allingham 2001-09-08 20:12:38 +00:00
parent 15fbfe6286
commit 90677086b9
5 changed files with 340 additions and 176 deletions

View File

@ -56,9 +56,17 @@ class Find:
def find_next(self): def find_next(self):
"""Advances to the next person that matches the dialog text""" """Advances to the next person that matches the dialog text"""
text = self.entry.get_text() text = self.entry.get_text()
try:
row = self.clist.selection[0] row = self.clist.selection[0]
if row == None or text == "": except IndexError:
gtk.gdk_beep()
return return
if row == None or text == "":
gtk.gdk_beep()
return
row = row + 1 row = row + 1
last = self.clist.rows last = self.clist.rows
person = None person = None
@ -75,9 +83,17 @@ class Find:
def find_prev(self): def find_prev(self):
"""Advances to the previous person that matches the dialog text""" """Advances to the previous person that matches the dialog text"""
text = self.entry.get_text() text = self.entry.get_text()
try:
row = self.clist.selection[0] row = self.clist.selection[0]
if row == None or text == "": except IndexError:
gtk.gdk_beep()
return return
if row == None or text == "":
gtk.gdk_beep()
return
row = row - 1 row = row - 1
person = None person = None
while row >= 0: while row >= 0:

View File

@ -220,6 +220,7 @@ personalConstantEvents = {
"Immigration" : "IMMI", "Immigration" : "IMMI",
"Occupation" : "OCCU", "Occupation" : "OCCU",
"Probate" : "PROB", "Probate" : "PROB",
"Property" : "PROP",
"Religion" : "RELI", "Religion" : "RELI",
"Residence" : "RESI", "Residence" : "RESI",
"Retirement" : "RETI", "Retirement" : "RETI",
@ -254,6 +255,7 @@ _pe_e2l = {
"Occupation" : _("Occupation"), "Occupation" : _("Occupation"),
"Ordination" : _("Ordination"), "Ordination" : _("Ordination"),
"Probate" : _("Probate"), "Probate" : _("Probate"),
"Property" : _("Property"),
"Religion" : _("Religion"), "Religion" : _("Religion"),
"Residence" : _("Residence"), "Residence" : _("Residence"),
"Retirement" : _("Retirement"), "Retirement" : _("Retirement"),

View File

@ -2,7 +2,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2000 Donald N. Allingham # Copyright (C) 2000 Bruce J. DeGrasse
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
@ -126,7 +126,9 @@ class AncestorReport:
def write_children(self, family): def write_children(self, family):
""" List children """ """ List children """
num_children= len(family.getChildList()) num_children= len(family.getChildList())
#print "Children= ", len(family.getChildList())
if num_children > 0: if num_children > 0:
self.doc.start_paragraph("ChildTitle") self.doc.start_paragraph("ChildTitle")
self.doc.write_text("Children:") self.doc.write_text("Children:")
@ -135,50 +137,63 @@ class AncestorReport:
for child in family.getChildList(): for child in family.getChildList():
self.doc.start_paragraph("ChildList") self.doc.start_paragraph("ChildList")
t= child.getPrimaryName().getRegularName() t= child.getPrimaryName().getRegularName()
if child.getBirth().getDate() != "" or child.getBirth().getPlace() != "": if child.getBirth().getDate() != "" and \
child.getBirth().getPlaceName() != "":
t= t+ " Born: "+child.getBirth().getDate() + \ t= t+ " Born: "+child.getBirth().getDate() + \
" "+child.getBirth().getPlace() " "+child.getBirth().getPlaceName()
if child.getDeath().getDate() != "" or child.getDeath().getPlace() != "": if child.getDeath().getPlaceName() != "":
if child.getDeath().getDate() != "" or child.getDeath().getPlaceName() != "":
t= t+ " Died: "+child.getDeath().getDate() + \ t= t+ " Died: "+child.getDeath().getDate() + \
" "+child.getDeath().getPlace() " "+child.getDeath().getPlaceName()
self.doc.write_text(_(t)) self.doc.write_text(_(t))
self.doc.end_paragraph() self.doc.end_paragraph()
def write_person(self, key): def write_person(self, key, rptOptions):
"""Output birth, death, parentage, marriage and notes information """
self.doc.start_paragraph("Entry","%s." % str(key)) self.doc.start_paragraph("Entry","%s." % str(key))
person = self.map[key] person = self.map[key]
name = person.getPrimaryName().getRegularName() name = person.getPrimaryName().getRegularName()
if rptOptions.firstName == reportOptions.Yes:
firstName= person.getPrimaryName().getFirstName()
elif person.getGender() == RelLib.Person.male:
firstName= "He"
else:
firstName= "She"
self.doc.start_bold() self.doc.start_bold()
self.doc.write_text(name) self.doc.write_text(name)
self.doc.end_bold() self.doc.end_bold()
# Check birth record # Check birth record
print person.getPrimaryName().getRegularName()
birth = person.getBirth() birth = person.getBirth()
if birth: if birth:
date = birth.getDateObj().get_start_date() date = birth.getDateObj().get_start_date()
place = birth.getPlace() place = birth.getPlaceName()
if place[-1:] == '.': if place[-1:] == '.':
place = place[:-1] place = place[:-1]
if date.getDate() != "" or place != "": t= ""
if date.getDate() != "": if date.getDate() != "":
if date.getDay() != -1 and date.getMonth() != -1: if date.getDay() != -1 and date.getMonth() != -1 and \
rptOptions.fullDate == reportOptions.Yes:
t= "on %s" % date.getDate()
else:
t= "in the year %s" % date.getYear()
elif rptOptions.dateBlank == reportOptions.Yes:
t= "on _______________"
if place != "": if place != "":
t = _(" was born on %s in %s. ") % \ t= t + " in %s" % place
(date.getDate(),place) elif rptOptions.placeBlank == reportOptions.Yes:
else: t= t + " in _____________________"
t = _(" was born on %s. ") % \
(date.getDate())
else:
if place != "":
t = _(" was born in the year %s in %s. ") % \
(date.getDate(),place)
else:
t = _(" was born in the year %s. ") % \
(date.getDate())
self.doc.write_text(t)
if t != "":
self.doc.write_text(_(" was born " + t + "."))
else: self.doc.write_text(_("."))
t= ""
death = person.getDeath() death = person.getDeath()
buried = None buried = None
for event in person.getEventList(): for event in person.getEventList():
@ -187,119 +202,124 @@ class AncestorReport:
if death: if death:
date = death.getDateObj().get_start_date() date = death.getDateObj().get_start_date()
place = death.getPlace() place = death.getPlaceName()
if place[-1:] == '.': if place[-1:] == '.':
place = place[:-1] place = place[:-1]
if date.getDate() != "" or place != "": t= " %s died " % firstName
if person.getGender() == RelLib.Person.male:
male = 1
else:
male = 0
if date.getDate() != "": if date.getDate() != "":
if date.getDay() != -1 and date.getMonth() != -1: if date.getDay() != -1 and date.getMonth() != -1 and \
if male: rptOptions.fullDate == reportOptions.Yes:
if place != "": t= t + ("on %s" % date.getDate())
t = _("He died on %s in %s") % \
(date.getDate(),place)
else: else:
t = _("He died on %s") % date.getDate() t= t + ("in the year %s" % date.getDate())
else: elif rptOptions.dateBlank == reportOptions.Yes:
if place != "": t= "on ______________"
t = _("She died on %s in %s") % \
(date.getDate(),place)
else:
t = _("She died on %s") % date.getDate()
else:
if male:
if place != "":
t = _("He died in the year %s in %s") % \
(date.getDate(),place)
else:
t = _("He died in the year %s") % date.getDate()
else:
if place != "":
t = _("She died in the year %s in %s") % \
(date.getDate(),place)
else:
t = _("She died in the year %s") % date.getDate()
self.doc.write_text(t) if place != "":
t= t + (" in %s") % place
elif rptOptions.placeBlank == reportOptions.Yes:
t= t + (" in _____________")
if buried: if buried:
date = buried.getDateObj().get_start_date() date = buried.getDateObj().get_start_date()
place = buried.getPlace() place = buried.getPlaceName()
if place[-1:] == '.': if place[-1:] == '.':
place = place[:-1] place = place[:-1]
if date.getDate() != "" or place != "": if date.getDate() != "" or place != "":
t= t + ", and was buried "
if date.getDate() != "": if date.getDate() != "":
if date.getDay() != -1 and date.getMonth() != -1: if date.getDay() != -1 and date.getMonth() != -1 and \
rptOptions.fullDate == reportOptions.Yes:
t= t + "on %s" % date.getDate()
if place != "": if place != "":
t = _(", and was buried on %s in %s.") % \ t = t + " in %s" % place
(date.getDate(),place)
else:
t = _(", and was buried on %s.") % \
date.getDate()
else: else:
t = t + "in the year %s" % date.getDate()
elif rptOptions.dateBlank == reportOptions.Yes:
t= t + " on ___________"
if place != "": if place != "":
t = _(", and was buried in the year %s in %s.") % \ t = t + " in %s" % place
(date.getDate(),place)
else: if rptOptions.calcAgeFlag == reportOptions.Yes:
t = _(", and was buried in the year %s.") % \ t= t + rptOptions.calcAge(birth.date.start, death.date.start)
date.getDate() if t != "":
else: self.doc.write_text(_(t+"."))
t = _(" and was buried in %s." % place)
self.doc.write_text(t)
else:
self.doc.write_text(".")
ext_family= person.getMainFamily() ext_family= person.getMainFamily()
if ext_family != None: if ext_family != None:
if ext_family.getFather() != "": if ext_family.getFather() != None:
father= ext_family.getFather().getPrimaryName().getRegularName()
else: father= ""
if ext_family.getMother() != None:
mother= ext_family.getMother().getPrimaryName().getRegularName()
else: mother= ""
if father != "" or mother != "":
t = " %s was the " % firstName
if person.getGender() == RelLib.Person.male: if person.getGender() == RelLib.Person.male:
t= " He was the son of " t= t + "son of"
else: else:
t= " She was the daughter of " t= t + "daughter of"
father= ext_family.getFather() if father != "":
t= t+father.getPrimaryName().getRegularName() t= t + " %s" % father
if ext_family.getMother() != "": if mother != "":
mother= ext_family.getMother() t= t + " and %s" % mother
if mother != None: else: t= t + " %s" % mother
t= t + " and " + mother.getPrimaryName().getRegularName()
self.doc.write_text(_(t + ".")) self.doc.write_text(_(t + "."))
t= ""
famList= person.getFamilyList() famList= person.getFamilyList()
#print "len of famList=", len(famList)
if len(famList) > 0: if len(famList) > 0:
for family in famList:
famList= person.getFamilyList()
if len(famList) > 0:
spouse= ""
for fam in famList: for fam in famList:
#print "fam", fam.__dict__
spouse= ""
if person.getGender() == RelLib.Person.male: if person.getGender() == RelLib.Person.male:
if fam.getMother() != None: if fam.getMother() != None:
spouse= fam.getMother().getPrimaryName().getRegularName() spouse= fam.getMother().getPrimaryName().getRegularName()
heshe= "He" heshe= "He"
else: else:
heshe= "She"
if fam.getFather() != None: if fam.getFather() != None:
spouse= fam.getFather().getPrimaryName().getRegularName() spouse= fam.getFather().getPrimaryName().getRegularName()
heshe= "She"
marriage= family.getMarriage() marriage= fam.getMarriage()
if marriage != None:
#print "marriage", marriage.__dict__
if spouse != "": if spouse != "":
t= " %s married %s" % (heshe, spouse) t= " %s married %s" % (heshe, spouse)
if marriage != None: else:
if marriage.getDate() != "": t= " %s was married" % heshe
t= t+ " on "+marriage.getDate() date= marriage.getDateObj()
if marriage.getPlace() != "": if date != None:
t= t+ " in "+marriage.getPlace() #print "date", date.__dict__
#print "date.start=", date.start.__dict__
if date.getYear() != -1:
if date.getDay() != -1 and \
date.getMonth() != -1 and \
rptOptions.fullDate == reportOptions.Yes:
t= t + " on "+date.getDate()
else: t= t + " in the year %s" % date.getYear()
elif rptOptions.dateBlank == reportOptions.Yes:
t= t + " on __________"
else: t= t + " on __________"
if marriage.getPlaceName() != "":
t= t + " in " + marriage.getPlaceName()
elif rptOptions.placeBlank == reportOptions.Yes:
t= t + " in ____________"
self.doc.write_text(_(t+".")) self.doc.write_text(_(t+"."))
if person.getNote() != "":
if person.getNote() != "" and rptOptions.includeNotes == reportOptions.Yes:
self.doc.end_paragraph()
self.doc.start_paragraph("Entry")
self.doc.write_text(_("Notes for %s" % name))
self.doc.end_paragraph() self.doc.end_paragraph()
self.doc.start_paragraph("Entry") self.doc.start_paragraph("Entry")
st = _("Notes for %s" % name)
self.doc.write_text(st)
self.doc.write_text(person.getNote()) self.doc.write_text(person.getNote())
#print person.getNote()
self.doc.end_paragraph() self.doc.end_paragraph()
#-------------------------------------------------------------------- #--------------------------------------------------------------------
@ -310,6 +330,7 @@ class AncestorReport:
def write_report(self): def write_report(self):
self.filter(self.start,1) self.filter(self.start,1)
rptOpt= reportOptions()
name = self.start.getPrimaryName().getRegularName() name = self.start.getPrimaryName().getRegularName()
self.doc.start_paragraph("Title") self.doc.start_paragraph("Title")
@ -332,10 +353,12 @@ class AncestorReport:
self.doc.end_paragraph() self.doc.end_paragraph()
generation = generation + 1 generation = generation + 1
self.write_person(key) self.write_person(key, rptOpt)
person = self.map[key] person = self.map[key]
if person.getGender() == RelLib.Person.female: if person.getGender() == RelLib.Person.female and \
rptOpt.listChildren == reportOptions.Yes and \
len(person.getFamilyList()) > 0:
family= person.getFamilyList()[0] family= person.getFamilyList()[0]
self.write_children(family) self.write_children(family)
@ -484,17 +507,6 @@ def on_save_clicked(obj):
utils.destroy_passed_object(obj) utils.destroy_passed_object(obj)
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
def get_description():
return _("Produces a detailed textual ancestral report")
def get_name():
return _("Generate files/Detailed Ancestral Report")
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# #
@ -555,3 +567,113 @@ def get_xpm_image():
" ", " ",
" ", " ",
" "] " "]
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
from Plugins import register_report
register_report(
report,
_("Produces a detailed textual ancestral report"),
category=_("Generate Files"),
description= _("Detailed Ancestral Report"),
xpm= get_xpm_image()
)
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
class reportOptions:
Yes=1
No= 0
Left= 2
Right= 3
def __init__(self):
### Initialize report options###
#Use first name in place of he or she in text
self.firstName= reportOptions.Yes
#Use year only, not full date/month
self.fullDate= reportOptions.Yes
#Do not list children
self.listChildren= reportOptions.Yes
#Add stepchildren to the list of children
#self.addStepChildren= reportOptions.Yes
#Print notes
self.includeNotes= reportOptions.Yes
#Selectively print notes (omit private information)
#self.omitPrivInfo= reportOptions.No
#generate header for each page, specify text
#self.noHeader= reportOptions.Yes
#Inculde reference notes
#self.noRefNotes= reportOptions.Yes
#Include source notes
#self.noSourceNotes= reportOptions.Yes
#Replace missing with ___________
self.placeBlank= reportOptions.Yes
#Replace missing dates with __________
self.dateBlank= reportOptions.Yes
#Omit country code
#self.noCountryInfo= reportOptions.No
#Put title before or after name (Dr., Lt., etc.)
#self.titleAfter= reportOptions.Yes
#Add "Died at the age of NN" in text
self.calcAgeFlag= reportOptions.Yes
#Omit sensitive information such as birth, christening, marriage
# for living after XXXXX date.
#Add photos/images
#self.images.append(key, kname, align, width, height)
#self.images= []
#self.images.append(1, "TMDeG_72.pjg", Right, 144, 205)
#def addImages(self, key= 0, fname= "", align= Right, Width= none, height= None):
#if key == 0 or fname == "" or (align != Left and align != Right):
#print Invalid Image Specification: ke= %s, fname= %s width %s % key, fname, align
#else:
#self.images.append(key, fname, align, width, height)
def calcAge(self, birth, death):
### Calulate age ###
self.t= ""
if birth.year != -1 and death.year != -1:
self.age= death.year - birth.year
self.units= "year"
if birth.month != -1 and death.month != -1:
if birth.month > death.month:
self.age= self.age -1
if birth.day != -1 and death.day != -1:
if birth.month == death.month and birth.day > death.day:
self.age= self.age -1
self.units= "month"
if self.age == 0:
self.age= death.month - birth.month # calc age in months
if birth.day > death.day:
self.age= self.age - 1
if self.age == 0:
self.age= death.day + 31 - birth.day # calc age in days
self.units= "day"
self.t= " at the age of %d %s" % (self.age, self.units)
if self.age > 1: self.t= self.t + "s"
return self.t

View File

@ -454,6 +454,9 @@ class GedcomParser:
elif matches[1] == "_MREL": elif matches[1] == "_MREL":
if string.lower(matches[2]) != "natural": if string.lower(matches[2]) != "natural":
mrel = matches[2] mrel = matches[2]
elif matches[1] == "ADOP":
mrel = "Adopted"
frel = "Adopted"
else: else:
self.barf(level+1) self.barf(level+1)
@ -488,6 +491,8 @@ class GedcomParser:
(frel == "Birth" or frel == "") : (frel == "Birth" or frel == "") :
child.setMainFamily(self.family) child.setMainFamily(self.family)
else: else:
if child.getMainFamily() == self.family:
child.setMainFamily(None)
child.addAltFamily(self.family,mrel,frel) child.addAltFamily(self.family,mrel,frel)
elif matches[1] == "NCHI" or matches[1] == "RIN" or matches[1] == "SUBM": elif matches[1] == "NCHI" or matches[1] == "RIN" or matches[1] == "SUBM":
pass pass
@ -613,6 +618,8 @@ class GedcomParser:
addr.setStreet(matches[2] + self.parse_continue_data(2)) addr.setStreet(matches[2] + self.parse_continue_data(2))
self.parse_address(addr,2) self.parse_address(addr,2)
self.person.addAddress(addr) self.person.addAddress(addr)
elif matches[1] == "TITL":
self.person.getPrimaryName().setTitle(matches[2])
elif matches[1] == "BIRT": elif matches[1] == "BIRT":
event = Event() event = Event()
if self.person.getBirth().getDate() != "" or \ if self.person.getBirth().getDate() != "" or \
@ -922,8 +929,16 @@ class GedcomParser:
self.person.addAltFamily(family,type,type) self.person.addAltFamily(family,type,type)
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "PLAC": elif matches[1] == "PLAC":
val = matches[2]
place = None
for p in self.db.getPlaceMap().values():
if val == p.get_title():
place = p
break
else:
place = Place() place = Place()
place.set_title(matches[2]) place.set_title(matches[2])
self.db.addPlace(place)
event.setPlace(place) event.setPlace(place)
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "NOTE": elif matches[1] == "NOTE":
@ -985,8 +1000,16 @@ class GedcomParser:
self.parse_source_reference(source_ref,level+1) self.parse_source_reference(source_ref,level+1)
event.setSourceRef(source_ref) event.setSourceRef(source_ref)
elif matches[1] == "PLAC": elif matches[1] == "PLAC":
val = matches[2]
place = None
for p in self.db.getPlaceMap().values():
if val == p.get_title():
place = p
break
else:
place = Place() place = Place()
place.set_title(matches[2]) place.set_title(matches[2])
self.db.addPlace(place)
event.setPlace(place) event.setPlace(place)
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "NOTE": elif matches[1] == "NOTE":

View File

@ -28,7 +28,8 @@ import string
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def build_sort_name(n): def build_sort_name(n):
return "%-25s%-30s%s" % (n.Surname,n.FirstName,n.Suffix) return "%-25s%-30s%s" % \
(string.upper(n.Surname),string.upper(n.FirstName),string.upper(n.Suffix))
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #