Fixed custom events

svn: r132
This commit is contained in:
Don Allingham 2001-06-14 17:14:16 +00:00
parent 1a4482b867
commit 4df0855aca

View File

@ -50,6 +50,9 @@ clear_data = 0
photo_types = [ "jpeg", "bmp", "pict", "pntg", "tpic", "png", "gif", photo_types = [ "jpeg", "bmp", "pict", "pntg", "tpic", "png", "gif",
"tiff", "pcx" ] "tiff", "pcx" ]
_ADDRX = [ "ADDR", "ADR1", "ADR2" ]
ged2rel = {} ged2rel = {}
for val in const.personalConstantEvents.keys(): for val in const.personalConstantEvents.keys():
key = const.personalConstantEvents[val] key = const.personalConstantEvents[val]
@ -523,13 +526,9 @@ class GedcomParser:
name.setSuffix(names[2]) name.setSuffix(names[2])
self.person.setPrimaryName(name) self.person.setPrimaryName(name)
self.parse_name(name,2) self.parse_name(name,2)
elif matches[1] == "RIN": elif matches[1] == "RIN" or matches[1] == "RFN":
pass pass
elif matches[1] == "RFN": elif matches[1] == "AFN" or matches[1] == "CHAN":
pass
elif matches[1] == "AFN":
pass
elif matches[1] == "CHAN":
self.ignore_sub_junk(2) self.ignore_sub_junk(2)
elif matches[1] == "ALIA": elif matches[1] == "ALIA":
pass pass
@ -545,7 +544,6 @@ class GedcomParser:
else: else:
self.parse_person_object(2) self.parse_person_object(2)
elif matches[1] == "NOTE": elif matches[1] == "NOTE":
print matches[2]
if not string.strip(matches[2]) or matches[2] and matches[2][0] != "@": if not string.strip(matches[2]) or matches[2] and matches[2][0] != "@":
note = matches[2] + self.parse_continue_data(1) note = matches[2] + self.parse_continue_data(1)
self.person.setNote(note) self.person.setNote(note)
@ -562,8 +560,6 @@ class GedcomParser:
self.person.setGender(Person.male) self.person.setGender(Person.male)
else: else:
self.person.setGender(Person.female) self.person.setGender(Person.female)
elif matches[1] == "EVEN":
pass
elif matches[1] == "FAMS": elif matches[1] == "FAMS":
family = self.db.findFamily(matches[2],self.fmap) family = self.db.findFamily(matches[2],self.fmap)
self.person.addFamily(family) self.person.addFamily(family)
@ -768,9 +764,9 @@ class GedcomParser:
break break
elif matches[1] == "DATE": elif matches[1] == "DATE":
address.setDate(matches[2]) address.setDate(matches[2])
elif matches[1] == "AGE" or matches[1] == "AGNC": elif matches[1] == "AGE" or matches[1] in "AGNC":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "CAUS" or matches[1] == "ADDR": elif matches[1] == "CAUS" or matches[1] in "ADDR":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "STAT" or matches[1] == "TEMP": elif matches[1] == "STAT" or matches[1] == "TEMP":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
@ -814,13 +810,14 @@ class GedcomParser:
if int(matches[0]) < level: if int(matches[0]) < level:
self.backup() self.backup()
return return
elif matches[1] == "ADDR" or matches[1] == "ADR1" or matches[1] == "ADR2": elif matches[1] in _ADDRX:
val = address.getStreet() val = address.getStreet()
data = self.parse_continue_data(level+1)
if first == 0: if first == 0:
val = "%s %s" % (matches[2], self.parse_continue_data(level+1)) val = "%s %s" % (matches[2],data)
first = 1 first = 1
else: else:
val = "%s,%s %s" % (val,matches[2],self.parse_continue_data(level+1)) val = "%s,%s %s" % (val,matches[2],data)
address.setStreet(val) address.setStreet(val)
elif matches[1] == "CITY": elif matches[1] == "CITY":
address.setCity(matches[2]) address.setCity(matches[2])
@ -845,16 +842,21 @@ class GedcomParser:
self.backup() self.backup()
break break
elif matches[1] == "TYPE": elif matches[1] == "TYPE":
if event.getName() != "": if event.getName() == "":
try: if ged2rel.has_key(matches[2]):
event.setName(ged2rel[matches[2]]) name = ged2rel[matches[2]]
except: else:
event.setName(matches[2]) name = matches[2]
print name
event.setName(name)
else:
print "*",event.getName()
print event.getName()
elif matches[1] == "DATE": elif matches[1] == "DATE":
event.setDate(matches[2]) event.setDate(matches[2])
elif matches[1] == "AGE" or matches[1] == "AGNC": elif matches[1] == "AGE" or matches[1] == "AGNC":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "CAUS" or matches[1] == "ADDR": elif matches[1] == "CAUS" or matches[1] in "ADDR":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "STAT" or matches[1] == "TEMP": elif matches[1] == "STAT" or matches[1] == "TEMP":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
@ -904,7 +906,7 @@ class GedcomParser:
event.setDate(matches[2]) event.setDate(matches[2])
elif matches[1] == "AGE" or matches[1] == "AGNC": elif matches[1] == "AGE" or matches[1] == "AGNC":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "CAUS" or matches[1] == "ADDR": elif matches[1] == "CAUS" or matches[1] in "ADDR":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
elif matches[1] == "STAT" or matches[1] == "TEMP": elif matches[1] == "STAT" or matches[1] == "TEMP":
self.ignore_sub_junk(level+1) self.ignore_sub_junk(level+1)
@ -1260,7 +1262,7 @@ class GedcomParser:
if int(matches[0]) < level: if int(matches[0]) < level:
self.backup() self.backup()
return return
elif matches[1] == "ADDR": elif matches[1] in "ADDR":
addr.label = matches[2] addr.label = matches[2]
self.parse_sub_addr(level+1, addr) self.parse_sub_addr(level+1, addr)
elif matches[1] == "PHON": elif matches[1] == "PHON":