gedcom cleanup
svn: r6884
This commit is contained in:
parent
475e167e21
commit
b359aaf466
@ -57,6 +57,7 @@ familyConstantEvents = {
|
|||||||
RelLib.EventType.ANNULMENT : "ANUL",
|
RelLib.EventType.ANNULMENT : "ANUL",
|
||||||
RelLib.EventType.DIV_FILING : "DIVF",
|
RelLib.EventType.DIV_FILING : "DIVF",
|
||||||
RelLib.EventType.DIVORCE : "DIV",
|
RelLib.EventType.DIVORCE : "DIV",
|
||||||
|
RelLib.EventType.CENSUS : "CENS",
|
||||||
RelLib.EventType.ENGAGEMENT : "ENGA",
|
RelLib.EventType.ENGAGEMENT : "ENGA",
|
||||||
RelLib.EventType.MARR_BANNS : "MARB",
|
RelLib.EventType.MARR_BANNS : "MARB",
|
||||||
RelLib.EventType.MARR_CONTR : "MARC",
|
RelLib.EventType.MARR_CONTR : "MARC",
|
||||||
|
@ -178,6 +178,7 @@ ged2fam_custom = {}
|
|||||||
intRE = re.compile(r"\s*(\d+)\s*$")
|
intRE = re.compile(r"\s*(\d+)\s*$")
|
||||||
nameRegexp= re.compile(r"/?([^/]*)(/([^/]*)(/([^/]*))?)?")
|
nameRegexp= re.compile(r"/?([^/]*)(/([^/]*)(/([^/]*))?)?")
|
||||||
snameRegexp= re.compile(r"/([^/]*)/([^/]*)")
|
snameRegexp= re.compile(r"/([^/]*)/([^/]*)")
|
||||||
|
modRegexp = re.compile(r"\s*(EST|CAL)\s+(.*)$")
|
||||||
calRegexp = re.compile(r"\s*(ABT|BEF|AFT)?\s*@#D([^@]+)@\s*(.*)$")
|
calRegexp = re.compile(r"\s*(ABT|BEF|AFT)?\s*@#D([^@]+)@\s*(.*)$")
|
||||||
rangeRegexp = re.compile(r"\s*BET\s+@#D([^@]+)@\s*(.*)\s+AND\s+@#D([^@]+)@\s*(.*)$")
|
rangeRegexp = re.compile(r"\s*BET\s+@#D([^@]+)@\s*(.*)\s+AND\s+@#D([^@]+)@\s*(.*)$")
|
||||||
spanRegexp = re.compile(r"\s*FROM\s+@#D([^@]+)@\s*(.*)\s+TO\s+@#D([^@]+)@\s*(.*)$")
|
spanRegexp = re.compile(r"\s*FROM\s+@#D([^@]+)@\s*(.*)\s+TO\s+@#D([^@]+)@\s*(.*)$")
|
||||||
@ -637,7 +638,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
TOKEN_STAT : self.func_person_attr_ignore,
|
TOKEN_STAT : self.func_person_attr_ignore,
|
||||||
TOKEN_TEMP : self.func_person_attr_ignore,
|
TOKEN_TEMP : self.func_person_attr_ignore,
|
||||||
TOKEN_OBJE : self.func_person_attr_ignore,
|
TOKEN_OBJE : self.func_person_attr_ignore,
|
||||||
TOKEN_DATE : self.func_person_attr_ignore,
|
|
||||||
TOKEN_SOUR : self.func_person_attr_source,
|
TOKEN_SOUR : self.func_person_attr_source,
|
||||||
TOKEN_PLAC : self.func_person_attr_place,
|
TOKEN_PLAC : self.func_person_attr_place,
|
||||||
TOKEN_NOTE : self.func_person_attr_note,
|
TOKEN_NOTE : self.func_person_attr_note,
|
||||||
@ -1441,7 +1441,8 @@ class GedcomParser(UpdateCallback):
|
|||||||
else:
|
else:
|
||||||
event.set_type(RelLib.EventType.UNKNOWN)
|
event.set_type(RelLib.EventType.UNKNOWN)
|
||||||
|
|
||||||
if matches[2] and not event.get_description():
|
if matches[2] and not event.get_description() and \
|
||||||
|
matches[2] != 'Y':
|
||||||
event.set_description(matches[2])
|
event.set_description(matches[2])
|
||||||
|
|
||||||
self.parse_event(event, self.generic_event_map, 2)
|
self.parse_event(event, self.generic_event_map, 2)
|
||||||
@ -1813,7 +1814,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
else:
|
else:
|
||||||
if not ged2gramps.has_key(matches[2]) and \
|
if not ged2gramps.has_key(matches[2]) and \
|
||||||
not ged2fam.has_key(matches[2]) and \
|
not ged2fam.has_key(matches[2]) and \
|
||||||
matches[2] != 'Y':
|
matches[2][0] != 'Y':
|
||||||
event.set_description(matches[2])
|
event.set_description(matches[2])
|
||||||
|
|
||||||
def func_event_privacy(self, matches, event, level):
|
def func_event_privacy(self, matches, event, level):
|
||||||
@ -2107,9 +2108,13 @@ class GedcomParser(UpdateCallback):
|
|||||||
self.lexer.set_broken_conc(self.gedsource.get_conc())
|
self.lexer.set_broken_conc(self.gedsource.get_conc())
|
||||||
elif matches[1] == TOKEN_CHAR and not self.override:
|
elif matches[1] == TOKEN_CHAR and not self.override:
|
||||||
if matches[2] == "ANSEL":
|
if matches[2] == "ANSEL":
|
||||||
|
print "ANSEL"
|
||||||
self.lexer.set_charset_fn(ansel_to_utf8)
|
self.lexer.set_charset_fn(ansel_to_utf8)
|
||||||
elif matches[2] not in ("UNICODE","UTF-8","UTF8"):
|
elif matches[2] not in ("UNICODE","UTF-8","UTF8"):
|
||||||
|
print "ASCII/LATIN"
|
||||||
self.lexer.set_charset_fn(latin_to_utf8)
|
self.lexer.set_charset_fn(latin_to_utf8)
|
||||||
|
else:
|
||||||
|
print "UNICODE"
|
||||||
self.ignore_sub_junk(2)
|
self.ignore_sub_junk(2)
|
||||||
elif matches[1] == TOKEN_GEDC:
|
elif matches[1] == TOKEN_GEDC:
|
||||||
self.ignore_sub_junk(2)
|
self.ignore_sub_junk(2)
|
||||||
@ -2230,6 +2235,14 @@ class GedcomParser(UpdateCallback):
|
|||||||
def extract_date(self,text):
|
def extract_date(self,text):
|
||||||
dateobj = RelLib.Date()
|
dateobj = RelLib.Date()
|
||||||
try:
|
try:
|
||||||
|
match = modRegexp.match(text)
|
||||||
|
if match:
|
||||||
|
(mod, text) = match.groups()
|
||||||
|
if mod == "CAL":
|
||||||
|
dateobj.set_quality(RelLib.Date.QUAL_CALCULATED)
|
||||||
|
elif mod == "EST":
|
||||||
|
dateobj.set_quality(RelLib.Date.QUAL_ESTIMATED)
|
||||||
|
|
||||||
match = rangeRegexp.match(text)
|
match = rangeRegexp.match(text)
|
||||||
if match:
|
if match:
|
||||||
(cal1,data1,cal2,data2) = match.groups()
|
(cal1,data1,cal2,data2) = match.groups()
|
||||||
@ -2786,7 +2799,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
event = RelLib.Event()
|
event = RelLib.Event()
|
||||||
event.set_gramps_id(self.emapper.find_next())
|
event.set_gramps_id(self.emapper.find_next())
|
||||||
if matches[2]:
|
if matches[2] and matches[2] != 'Y':
|
||||||
event.set_description(matches[2])
|
event.set_description(matches[2])
|
||||||
event.type.set(RelLib.EventType.DEATH)
|
event.type.set(RelLib.EventType.DEATH)
|
||||||
self.parse_event(event, self.generic_event_map, 2)
|
self.parse_event(event, self.generic_event_map, 2)
|
||||||
@ -2809,7 +2822,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
event = RelLib.Event()
|
event = RelLib.Event()
|
||||||
event.set_gramps_id(self.emapper.find_next())
|
event.set_gramps_id(self.emapper.find_next())
|
||||||
if matches[2]:
|
if matches[2] and matches[2] != 'Y':
|
||||||
event.set_description(matches[2])
|
event.set_description(matches[2])
|
||||||
self.parse_event(event, self.generic_event_map, 2)
|
self.parse_event(event, self.generic_event_map, 2)
|
||||||
the_type = event.get_type()
|
the_type = event.get_type()
|
||||||
@ -2872,7 +2885,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
event.set_type((RelLib.EventType.CUSTOM,n))
|
event.set_type((RelLib.EventType.CUSTOM,n))
|
||||||
|
|
||||||
self.parse_event(event, self.generic_event_map, 2)
|
self.parse_event(event, self.generic_event_map, 2)
|
||||||
if matches[2]:
|
if matches[2] and matches[2] != 'Y':
|
||||||
event.set_description(matches[2])
|
event.set_description(matches[2])
|
||||||
person_event_name(event,state.person)
|
person_event_name(event,state.person)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user