svn: r8125
This commit is contained in:
parent
91b7257b57
commit
bf831a400d
@ -37,3 +37,6 @@ GRAMPS_PY_MODPATH = "../"
|
|||||||
pycheck:
|
pycheck:
|
||||||
(export PYTHONPATH=$(GRAMPS_PY_MODPATH); \
|
(export PYTHONPATH=$(GRAMPS_PY_MODPATH); \
|
||||||
pychecker $(pkgdata_PYTHON));
|
pychecker $(pkgdata_PYTHON));
|
||||||
|
|
||||||
|
pylint:
|
||||||
|
(export PYTHONPATH=..:.; pylint --rcfile=pylintrc _GedcomParse.py)
|
||||||
|
@ -104,7 +104,7 @@ from gettext import gettext as _
|
|||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
import logging
|
import logging
|
||||||
log = logging.getLogger(".GedcomImport")
|
LOG = logging.getLogger(".GedcomImport")
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -132,7 +132,7 @@ try:
|
|||||||
import Config
|
import Config
|
||||||
DEFAULT_SOURCE = Config.get(Config.DEFAULT_SOURCE)
|
DEFAULT_SOURCE = Config.get(Config.DEFAULT_SOURCE)
|
||||||
except:
|
except:
|
||||||
log.warn("No Config module available using defaults.")
|
LOG.warn("No Config module available using defaults.")
|
||||||
DEFAULT_SOURCE = False
|
DEFAULT_SOURCE = False
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -251,52 +251,11 @@ GED_2_FAMILY_CUSTOM = {}
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
INT_RE = re.compile(r"\s*(\d+)\s*$")
|
INT_RE = re.compile(r"\s*(\d+)\s*$")
|
||||||
NAME_RE = re.compile(r"/?([^/]*)(/([^/]*)(/([^/]*))?)?")
|
|
||||||
SURNAME_RE = re.compile(r"/([^/]*)/([^/]*)")
|
|
||||||
NOTE_RE = re.compile(r"\s*\d+\s+\@(\S+)\@\s+NOTE(.*)$")
|
NOTE_RE = re.compile(r"\s*\d+\s+\@(\S+)\@\s+NOTE(.*)$")
|
||||||
CONT_RE = re.compile(r"\s*\d+\s+CONT\s?(.*)$")
|
CONT_RE = re.compile(r"\s*\d+\s+CONT\s?(.*)$")
|
||||||
CONC_RE = re.compile(r"\s*\d+\s+CONC\s?(.*)$")
|
CONC_RE = re.compile(r"\s*\d+\s+CONC\s?(.*)$")
|
||||||
PERSON_RE = re.compile(r"\s*\d+\s+\@(\S+)\@\s+INDI(.*)$")
|
PERSON_RE = re.compile(r"\s*\d+\s+\@(\S+)\@\s+INDI(.*)$")
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# CurrentState
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
class CurrentState:
|
|
||||||
"""
|
|
||||||
Keeps track of the current state variables
|
|
||||||
"""
|
|
||||||
def __init__(self, person=None, level=0, event=None, event_ref=None):
|
|
||||||
"""
|
|
||||||
Initializes the object
|
|
||||||
"""
|
|
||||||
self.note = ""
|
|
||||||
self.name_cnt = 0
|
|
||||||
self.person = person
|
|
||||||
self.level = level
|
|
||||||
self.event = event
|
|
||||||
self.event_ref = event_ref
|
|
||||||
self.source_ref = None
|
|
||||||
|
|
||||||
def __getattr__(self, name):
|
|
||||||
"""
|
|
||||||
Returns the value associated with the specified attribute.
|
|
||||||
"""
|
|
||||||
return self.__dict__.get(name)
|
|
||||||
|
|
||||||
def __setattr__(self, name, value):
|
|
||||||
"""
|
|
||||||
Sets the value associated with the specified attribute.
|
|
||||||
"""
|
|
||||||
self.__dict__[name] = value
|
|
||||||
|
|
||||||
def add_to_note(self, text):
|
|
||||||
self.note += text
|
|
||||||
|
|
||||||
def get_text(self):
|
|
||||||
return self.note
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -332,6 +291,7 @@ class NoteParser:
|
|||||||
|
|
||||||
ifile.seek(0)
|
ifile.seek(0)
|
||||||
innote = False
|
innote = False
|
||||||
|
noteobj = None
|
||||||
|
|
||||||
for line in ifile:
|
for line in ifile:
|
||||||
try:
|
try:
|
||||||
@ -388,6 +348,10 @@ class NoteParser:
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
class GedcomParser(UpdateCallback):
|
class GedcomParser(UpdateCallback):
|
||||||
|
"""
|
||||||
|
Performs the second pass of the GEDCOM parser, which does all the heavy
|
||||||
|
lifting.
|
||||||
|
"""
|
||||||
|
|
||||||
SyntaxError = "Syntax Error"
|
SyntaxError = "Syntax Error"
|
||||||
BadFile = "Not a GEDCOM file"
|
BadFile = "Not a GEDCOM file"
|
||||||
@ -799,6 +763,159 @@ class GedcomParser(UpdateCallback):
|
|||||||
self.gedattr[amap[val]] = val
|
self.gedattr[amap[val]] = val
|
||||||
self.search_paths = []
|
self.search_paths = []
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Create new objects
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def _find_from_handle(self, gramps_id, table):
|
||||||
|
"""
|
||||||
|
Finds a handle corresponding the the specified GRAMPS ID. The passed
|
||||||
|
table contains the mapping. If the value is found, we return it, otherwise
|
||||||
|
we create a new handle, store it, and return it.
|
||||||
|
"""
|
||||||
|
intid = table.get(gramps_id)
|
||||||
|
if not intid:
|
||||||
|
intid = Utils.create_id()
|
||||||
|
table[gramps_id] = intid
|
||||||
|
return intid
|
||||||
|
|
||||||
|
def find_person_handle(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Returns the database handle associated with the person's GRAMPS ID
|
||||||
|
"""
|
||||||
|
return self._find_from_handle(gramps_id, self.gid2id)
|
||||||
|
|
||||||
|
def find_family_handle(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Returns the database handle associated with the family's GRAMPS ID
|
||||||
|
"""
|
||||||
|
return self._find_from_handle(gramps_id, self.fid2id)
|
||||||
|
|
||||||
|
def find_or_create_person(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Finds or creates a person based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new person, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
person = RelLib.Person()
|
||||||
|
intid = self.gid2id.get(gramps_id)
|
||||||
|
if self.db.has_person_handle(intid):
|
||||||
|
person.unserialize(self.db.get_raw_person_data(intid))
|
||||||
|
else:
|
||||||
|
intid = self._find_from_handle(gramps_id, self.gid2id)
|
||||||
|
person.set_handle(intid)
|
||||||
|
person.set_gramps_id(gramps_id)
|
||||||
|
return person
|
||||||
|
|
||||||
|
def find_or_create_family(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Finds or creates a family based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new family, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
family = RelLib.Family()
|
||||||
|
intid = self.fid2id.get(gramps_id)
|
||||||
|
if self.db.has_family_handle(intid):
|
||||||
|
family.unserialize(self.db.get_raw_family_data(intid))
|
||||||
|
else:
|
||||||
|
intid = self._find_from_handle(gramps_id, self.fid2id)
|
||||||
|
family.set_handle(intid)
|
||||||
|
family.set_gramps_id(gramps_id)
|
||||||
|
return family
|
||||||
|
|
||||||
|
def find_or_create_object(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Finds or creates a media object based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new media object, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
obj = RelLib.MediaObject()
|
||||||
|
intid = self.oid2id.get(gramps_id)
|
||||||
|
if self.db.has_object_handle(intid):
|
||||||
|
obj.unserialize(self.db.get_raw_object_data(intid))
|
||||||
|
else:
|
||||||
|
intid = self._find_from_handle(gramps_id, self.oid2id)
|
||||||
|
obj.set_handle(intid)
|
||||||
|
obj.set_gramps_id(gramps_id)
|
||||||
|
return obj
|
||||||
|
|
||||||
|
def find_or_create_source(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Finds or creates a source based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new source, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
obj = RelLib.Source()
|
||||||
|
intid = self.sid2id.get(gramps_id)
|
||||||
|
if self.db.has_source_handle(intid):
|
||||||
|
obj.unserialize(self.db.get_raw_source_data(intid))
|
||||||
|
else:
|
||||||
|
intid = self._find_from_handle(gramps_id, self.sid2id)
|
||||||
|
obj.set_handle(intid)
|
||||||
|
obj.set_gramps_id(gramps_id)
|
||||||
|
return obj
|
||||||
|
|
||||||
|
def find_or_create_repository(self, gramps_id):
|
||||||
|
"""
|
||||||
|
Finds or creates a repository based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new repository, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
repository = RelLib.Repository()
|
||||||
|
if not gramps_id:
|
||||||
|
need_commit = True
|
||||||
|
gramps_id = self.db.find_next_repository_gramps_id()
|
||||||
|
else:
|
||||||
|
need_commit = False
|
||||||
|
|
||||||
|
intid = self.rid2id.get(gramps_id)
|
||||||
|
if self.db.has_repository_handle(intid):
|
||||||
|
repository.unserialize(self.db.get_raw_repository_data(intid))
|
||||||
|
else:
|
||||||
|
intid = self._find_from_handle(gramps_id, self.rid2id)
|
||||||
|
repository.set_handle(intid)
|
||||||
|
repository.set_gramps_id(gramps_id)
|
||||||
|
if need_commit:
|
||||||
|
self.db.commit_repository(repository, self.trans)
|
||||||
|
return repository
|
||||||
|
|
||||||
|
def find_or_create_place(self, title):
|
||||||
|
"""
|
||||||
|
Finds or creates a place based on the GRAMPS ID. If the ID is
|
||||||
|
already used (is in the db), we return the item in the db. Otherwise,
|
||||||
|
we create a new place, assign the handle and GRAMPS ID.
|
||||||
|
"""
|
||||||
|
place = RelLib.Place()
|
||||||
|
|
||||||
|
# check to see if we've encountered this name before
|
||||||
|
# if we haven't we need to get a new GRAMPS ID
|
||||||
|
|
||||||
|
intid = self.place_names.get(title)
|
||||||
|
if intid == None:
|
||||||
|
intid = self.lid2id.get(title)
|
||||||
|
if intid == None:
|
||||||
|
new_id = self.db.find_next_place_gramps_id()
|
||||||
|
else:
|
||||||
|
new_id = None
|
||||||
|
else:
|
||||||
|
new_id = None
|
||||||
|
|
||||||
|
# check to see if the name already existed in the database
|
||||||
|
# if it does, create a new name by appending the GRAMPS ID.
|
||||||
|
# generate a GRAMPS ID if needed
|
||||||
|
|
||||||
|
if self.db.has_place_handle(intid):
|
||||||
|
place.unserialize(self.db.get_raw_place_data(intid))
|
||||||
|
else:
|
||||||
|
intid = Utils.create_id()
|
||||||
|
place.set_handle(intid)
|
||||||
|
place.set_title(title)
|
||||||
|
place.set_gramps_id(new_id)
|
||||||
|
self.db.add_place(place, self.trans)
|
||||||
|
self.lid2id[title] = intid
|
||||||
|
return place
|
||||||
|
|
||||||
def find_file(self, fullname, altpath):
|
def find_file(self, fullname, altpath):
|
||||||
tries = []
|
tries = []
|
||||||
fullname = fullname.replace('\\', os.path.sep)
|
fullname = fullname.replace('\\', os.path.sep)
|
||||||
@ -869,7 +986,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
self.skip_subordinate_levels(level)
|
self.skip_subordinate_levels(level)
|
||||||
|
|
||||||
def warn(self, msg):
|
def warn(self, msg):
|
||||||
log.warning(msg)
|
LOG.warning(msg)
|
||||||
self.error_count += 1
|
self.error_count += 1
|
||||||
|
|
||||||
def backup(self):
|
def backup(self):
|
||||||
@ -1031,7 +1148,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
self.added.add(self.person.handle)
|
self.added.add(self.person.handle)
|
||||||
|
|
||||||
# set up the state for the parsing
|
# set up the state for the parsing
|
||||||
state = CurrentState(person=self.person, level=1)
|
state = GedcomUtils.CurrentState(person=self.person, level=1)
|
||||||
|
|
||||||
# do the actual parsing
|
# do the actual parsing
|
||||||
self.parse_level(state, self.indi_parse_tbl, self.func_person_event)
|
self.parse_level(state, self.indi_parse_tbl, self.func_person_event)
|
||||||
@ -1105,7 +1222,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
state.name_cnt += 1
|
state.name_cnt += 1
|
||||||
|
|
||||||
# Create a new state, and parse the remainder of the NAME level
|
# Create a new state, and parse the remainder of the NAME level
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.name = name
|
sub_state.name = name
|
||||||
sub_state.level = state.level+1
|
sub_state.level = state.level+1
|
||||||
@ -1273,7 +1390,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
addr = RelLib.Address()
|
addr = RelLib.Address()
|
||||||
|
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.level = state.level+1
|
sub_state.level = state.level+1
|
||||||
sub_state.addr = addr
|
sub_state.addr = addr
|
||||||
@ -1304,7 +1421,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
"""
|
"""
|
||||||
state.addr.set_street(line.data)
|
state.addr.set_street(line.data)
|
||||||
|
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.addr = state.addr
|
sub_state.addr = state.addr
|
||||||
sub_state.level = state.level + 1
|
sub_state.level = state.level + 1
|
||||||
self.parse_level(sub_state, self.parse_addr_tbl, self.func_ignore)
|
self.parse_level(sub_state, self.parse_addr_tbl, self.func_ignore)
|
||||||
@ -1388,7 +1505,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
@param state: The current state
|
@param state: The current state
|
||||||
@type state: CurrentState
|
@type state: CurrentState
|
||||||
"""
|
"""
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.attr = line.data
|
sub_state.attr = line.data
|
||||||
sub_state.level = state.level+1
|
sub_state.level = state.level+1
|
||||||
@ -1450,7 +1567,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
@param lds_type: The type of the LDS ordinance
|
@param lds_type: The type of the LDS ordinance
|
||||||
@type line: LdsOrd type
|
@type line: LdsOrd type
|
||||||
"""
|
"""
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.level = state.level + 1
|
sub_state.level = state.level + 1
|
||||||
sub_state.lds_ord = RelLib.LdsOrd()
|
sub_state.lds_ord = RelLib.LdsOrd()
|
||||||
sub_state.lds_ord.set_type(lds_type)
|
sub_state.lds_ord.set_type(lds_type)
|
||||||
@ -1579,13 +1696,12 @@ class GedcomParser(UpdateCallback):
|
|||||||
@type state: CurrentState
|
@type state: CurrentState
|
||||||
"""
|
"""
|
||||||
|
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.level = state.level + 1
|
sub_state.level = state.level + 1
|
||||||
sub_state.ftype = TYPE_BIRTH
|
sub_state.ftype = TYPE_BIRTH
|
||||||
sub_state.primary = False
|
sub_state.primary = False
|
||||||
|
|
||||||
notelist = []
|
|
||||||
gid = GedcomUtils.extract_id(line.data)
|
gid = GedcomUtils.extract_id(line.data)
|
||||||
handle = self.find_family_handle(gid)
|
handle = self.find_family_handle(gid)
|
||||||
|
|
||||||
@ -1726,7 +1842,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
# create a new PersonRef, and assign the handle, add the
|
# create a new PersonRef, and assign the handle, add the
|
||||||
# PersonRef to the active person
|
# PersonRef to the active person
|
||||||
|
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.level = state.level + 1
|
sub_state.level = state.level + 1
|
||||||
sub_state.ref = RelLib.PersonRef()
|
sub_state.ref = RelLib.PersonRef()
|
||||||
@ -1815,7 +1931,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
# parse the family
|
# parse the family
|
||||||
|
|
||||||
state = CurrentState()
|
state = GedcomUtils.CurrentState()
|
||||||
state.level = 1
|
state.level = 1
|
||||||
state.family = family
|
state.family = family
|
||||||
|
|
||||||
@ -1860,9 +1976,9 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def func_family_husb(self, line, state):
|
def func_family_husb(self, line, state):
|
||||||
"""
|
"""
|
||||||
Parses the husband line of a family
|
Parses the husband line of a family
|
||||||
|
|
||||||
n HUSB @<XREF:INDI>@ {0:1}
|
n HUSB @<XREF:INDI>@ {0:1}
|
||||||
|
|
||||||
@param line: The current line in GedLine format
|
@param line: The current line in GedLine format
|
||||||
@type line: GedLine
|
@type line: GedLine
|
||||||
@ -1951,9 +2067,9 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def func_family_chil(self, line, state):
|
def func_family_chil(self, line, state):
|
||||||
"""
|
"""
|
||||||
Parses the child line of a family
|
Parses the child line of a family
|
||||||
|
|
||||||
n CHIL @<XREF:INDI>@ {0:1}
|
n CHIL @<XREF:INDI>@ {0:1}
|
||||||
|
|
||||||
@param line: The current line in GedLine format
|
@param line: The current line in GedLine format
|
||||||
@type line: GedLine
|
@type line: GedLine
|
||||||
@ -1982,20 +2098,20 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def func_family_slgs(self, state, line):
|
def func_family_slgs(self, state, line):
|
||||||
"""
|
"""
|
||||||
n SLGS {1:1}
|
n SLGS {1:1}
|
||||||
+1 STAT <LDS_SPOUSE_SEALING_DATE_STATUS> {0:1}
|
+1 STAT <LDS_SPOUSE_SEALING_DATE_STATUS> {0:1}
|
||||||
+1 DATE <DATE_LDS_ORD> {0:1}
|
+1 DATE <DATE_LDS_ORD> {0:1}
|
||||||
+1 TEMP <TEMPLE_CODE> {0:1}
|
+1 TEMP <TEMPLE_CODE> {0:1}
|
||||||
+1 PLAC <PLACE_LIVING_ORDINANCE> {0:1}
|
+1 PLAC <PLACE_LIVING_ORDINANCE> {0:1}
|
||||||
+1 <<SOURCE_CITATION>> {0:M}
|
+1 <<SOURCE_CITATION>> {0:M}
|
||||||
+1 <<NOTE_STRUCTURE>> {0:M}
|
+1 <<NOTE_STRUCTURE>> {0:M}
|
||||||
|
|
||||||
@param line: The current line in GedLine format
|
@param line: The current line in GedLine format
|
||||||
@type line: GedLine
|
@type line: GedLine
|
||||||
@param state: The current state
|
@param state: The current state
|
||||||
@type state: CurrentState
|
@type state: CurrentState
|
||||||
"""
|
"""
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.level = state.level + 1
|
sub_state.level = state.level + 1
|
||||||
sub_state.lds_ord = RelLib.LdsOrd()
|
sub_state.lds_ord = RelLib.LdsOrd()
|
||||||
sub_state.lds_ord.set_type(RelLib.LdsOrd.SEAL_TO_SPOUSE)
|
sub_state.lds_ord.set_type(RelLib.LdsOrd.SEAL_TO_SPOUSE)
|
||||||
@ -2061,7 +2177,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def func_family_note(self, line, state):
|
def func_family_note(self, line, state):
|
||||||
"""
|
"""
|
||||||
+1 <<NOTE_STRUCTURE>> {0:M}
|
+1 <<NOTE_STRUCTURE>> {0:M}
|
||||||
|
|
||||||
@param line: The current line in GedLine format
|
@param line: The current line in GedLine format
|
||||||
@type line: GedLine
|
@type line: GedLine
|
||||||
@ -2072,7 +2188,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def func_family_chan(self, line, state):
|
def func_family_chan(self, line, state):
|
||||||
"""
|
"""
|
||||||
+1 <<CHANGE_DATE>> {0:1}
|
+1 <<CHANGE_DATE>> {0:1}
|
||||||
|
|
||||||
@param line: The current line in GedLine format
|
@param line: The current line in GedLine format
|
||||||
@type line: GedLine
|
@type line: GedLine
|
||||||
@ -2091,7 +2207,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
state.addr = RelLib.Address()
|
state.addr = RelLib.Address()
|
||||||
state.addr.set_street(line.data)
|
state.addr.set_street(line.data)
|
||||||
self.parse_level(state, self.parse_addr_tbl, self.func_ignore)
|
self.parse_level(state, self.parse_addr_tbl, self.func_ignore)
|
||||||
#self.parse_address(state.addr, state.level)
|
|
||||||
|
|
||||||
def func_family_attr(self, line, state):
|
def func_family_attr(self, line, state):
|
||||||
"""
|
"""
|
||||||
@ -2115,7 +2230,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
@param state: The current state
|
@param state: The current state
|
||||||
@type state: CurrentState
|
@type state: CurrentState
|
||||||
"""
|
"""
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.form = ""
|
sub_state.form = ""
|
||||||
sub_state.filename = ""
|
sub_state.filename = ""
|
||||||
sub_state.title = ""
|
sub_state.title = ""
|
||||||
@ -2187,130 +2302,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
self.idswap[gid] = gid
|
self.idswap[gid] = gid
|
||||||
return self.idswap[gid]
|
return self.idswap[gid]
|
||||||
|
|
||||||
def find_or_create_person(self, gramps_id):
|
|
||||||
person = RelLib.Person()
|
|
||||||
intid = self.gid2id.get(gramps_id)
|
|
||||||
if self.db.has_person_handle(intid):
|
|
||||||
person.unserialize(self.db.get_raw_person_data(intid))
|
|
||||||
else:
|
|
||||||
intid = self.find_person_handle(gramps_id)
|
|
||||||
person.set_handle(intid)
|
|
||||||
person.set_gramps_id(gramps_id)
|
|
||||||
return person
|
|
||||||
|
|
||||||
def find_person_handle(self, gramps_id):
|
|
||||||
intid = self.gid2id.get(gramps_id)
|
|
||||||
if not intid:
|
|
||||||
intid = create_id()
|
|
||||||
self.gid2id[gramps_id] = intid
|
|
||||||
return intid
|
|
||||||
|
|
||||||
def find_object_handle(self, gramps_id):
|
|
||||||
intid = self.oid2id.get(gramps_id)
|
|
||||||
if not intid:
|
|
||||||
intid = create_id()
|
|
||||||
self.oid2id[gramps_id] = intid
|
|
||||||
return intid
|
|
||||||
|
|
||||||
def find_or_create_family(self, gramps_id):
|
|
||||||
family = RelLib.Family()
|
|
||||||
intid = self.fid2id.get(gramps_id)
|
|
||||||
if self.db.has_family_handle(intid):
|
|
||||||
family.unserialize(self.db.get_raw_family_data(intid))
|
|
||||||
else:
|
|
||||||
intid = self.find_family_handle(gramps_id)
|
|
||||||
family.set_handle(intid)
|
|
||||||
family.set_gramps_id(gramps_id)
|
|
||||||
return family
|
|
||||||
|
|
||||||
def find_or_create_repository(self, gramps_id):
|
|
||||||
repository = RelLib.Repository()
|
|
||||||
if not gramps_id:
|
|
||||||
need_commit = True
|
|
||||||
gramps_id = self.db.find_next_repository_gramps_id()
|
|
||||||
else:
|
|
||||||
need_commit = False
|
|
||||||
|
|
||||||
intid = self.rid2id.get(gramps_id)
|
|
||||||
if self.db.has_repository_handle(intid):
|
|
||||||
repository.unserialize(self.db.get_raw_repository_data(intid))
|
|
||||||
else:
|
|
||||||
intid = self.find_repository_handle(gramps_id)
|
|
||||||
repository.set_handle(intid)
|
|
||||||
repository.set_gramps_id(gramps_id)
|
|
||||||
if need_commit:
|
|
||||||
self.db.commit_repository(repository, self.trans)
|
|
||||||
return repository
|
|
||||||
|
|
||||||
def find_or_create_object(self, gramps_id):
|
|
||||||
obj = RelLib.MediaObject()
|
|
||||||
intid = self.oid2id.get(gramps_id)
|
|
||||||
if self.db.has_object_handle(intid):
|
|
||||||
obj.unserialize(self.db.get_raw_object_data(intid))
|
|
||||||
else:
|
|
||||||
intid = self.find_object_handle(gramps_id)
|
|
||||||
obj.set_handle(intid)
|
|
||||||
obj.set_gramps_id(gramps_id)
|
|
||||||
return obj
|
|
||||||
|
|
||||||
def find_repository_handle(self, gramps_id):
|
|
||||||
intid = self.rid2id.get(gramps_id)
|
|
||||||
if not intid:
|
|
||||||
intid = create_id()
|
|
||||||
self.rid2id[gramps_id] = intid
|
|
||||||
return intid
|
|
||||||
|
|
||||||
def find_family_handle(self, gramps_id):
|
|
||||||
intid = self.fid2id.get(gramps_id)
|
|
||||||
if not intid:
|
|
||||||
intid = create_id()
|
|
||||||
self.fid2id[gramps_id] = intid
|
|
||||||
return intid
|
|
||||||
|
|
||||||
def find_or_create_source(self, gramps_id):
|
|
||||||
source = RelLib.Source()
|
|
||||||
intid = self.sid2id.get(gramps_id)
|
|
||||||
if self.db.has_source_handle(intid):
|
|
||||||
source.unserialize(self.db.get_raw_source_data(intid))
|
|
||||||
else:
|
|
||||||
intid = create_id()
|
|
||||||
source.set_handle(intid)
|
|
||||||
source.set_gramps_id(gramps_id)
|
|
||||||
self.db.add_source(source, self.trans)
|
|
||||||
self.sid2id[gramps_id] = intid
|
|
||||||
return source
|
|
||||||
|
|
||||||
def find_or_create_place(self, title):
|
|
||||||
place = RelLib.Place()
|
|
||||||
|
|
||||||
# check to see if we've encountered this name before
|
|
||||||
# if we haven't we need to get a new GRAMPS ID
|
|
||||||
|
|
||||||
intid = self.place_names.get(title)
|
|
||||||
if intid == None:
|
|
||||||
intid = self.lid2id.get(title)
|
|
||||||
if intid == None:
|
|
||||||
new_id = self.db.find_next_place_gramps_id()
|
|
||||||
else:
|
|
||||||
new_id = None
|
|
||||||
else:
|
|
||||||
new_id = None
|
|
||||||
|
|
||||||
# check to see if the name already existed in the database
|
|
||||||
# if it does, create a new name by appending the GRAMPS ID.
|
|
||||||
# generate a GRAMPS ID if needed
|
|
||||||
|
|
||||||
if self.db.has_place_handle(intid):
|
|
||||||
place.unserialize(self.db.get_raw_place_data(intid))
|
|
||||||
else:
|
|
||||||
intid = create_id()
|
|
||||||
place.set_handle(intid)
|
|
||||||
place.set_title(title)
|
|
||||||
place.set_gramps_id(new_id)
|
|
||||||
self.db.add_place(place, self.trans)
|
|
||||||
self.lid2id[title] = intid
|
|
||||||
return place
|
|
||||||
|
|
||||||
def parse_cause(self, event, level):
|
def parse_cause(self, event, level):
|
||||||
while True:
|
while True:
|
||||||
line = self.get_next()
|
line = self.get_next()
|
||||||
@ -2654,7 +2645,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
@param state: The current state
|
@param state: The current state
|
||||||
@type state: CurrentState
|
@type state: CurrentState
|
||||||
"""
|
"""
|
||||||
note = self.parse_note(line, state.addr, state.level+1, '')
|
self.parse_note(line, state.addr, state.level+1, '')
|
||||||
|
|
||||||
def parse_place_as_address(self, street, level):
|
def parse_place_as_address(self, street, level):
|
||||||
note = None
|
note = None
|
||||||
@ -3000,7 +2991,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
def parse_source_reference(self, src_ref, level, handle):
|
def parse_source_reference(self, src_ref, level, handle):
|
||||||
"""Reads the data associated with a SOUR reference"""
|
"""Reads the data associated with a SOUR reference"""
|
||||||
state = CurrentState()
|
state = GedcomUtils.CurrentState()
|
||||||
state.level = level
|
state.level = level
|
||||||
state.src_ref = src_ref
|
state.src_ref = src_ref
|
||||||
state.handle = handle
|
state.handle = handle
|
||||||
@ -3277,9 +3268,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
|
|
||||||
self.db.pmap_index = new_pmax
|
self.db.pmap_index = new_pmax
|
||||||
|
|
||||||
def invert_year(self, subdate):
|
|
||||||
return (subdate[0], subdate[1], -subdate[2], subdate[3])
|
|
||||||
|
|
||||||
#--------------------------------------------------------------------
|
#--------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -3352,7 +3340,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
state.person.add_alternate_name(name)
|
state.person.add_alternate_name(name)
|
||||||
|
|
||||||
# Create a new state, and parse the remainder of the NAME level
|
# Create a new state, and parse the remainder of the NAME level
|
||||||
sub_state = CurrentState()
|
sub_state = GedcomUtils.CurrentState()
|
||||||
sub_state.person = state.person
|
sub_state.person = state.person
|
||||||
sub_state.name = name
|
sub_state.name = name
|
||||||
sub_state.level = 2
|
sub_state.level = 2
|
||||||
@ -3525,20 +3513,8 @@ class GedcomParser(UpdateCallback):
|
|||||||
is not legal in GEDCOM, but oddly enough, is easy to support.
|
is not legal in GEDCOM, but oddly enough, is easy to support.
|
||||||
"""
|
"""
|
||||||
if line.data[0] == '@':
|
if line.data[0] == '@':
|
||||||
aka = RelLib.Name()
|
aka = GedcomUtils.parse_name_personal(line.data)
|
||||||
try:
|
|
||||||
names = NAME_RE.match(line.data).groups()
|
|
||||||
except:
|
|
||||||
names = (line.data, "", "", "", "")
|
|
||||||
if names[0]:
|
|
||||||
aka.set_first_name(names[0].strip())
|
|
||||||
if names[2]:
|
|
||||||
aka.set_surname(names[2].strip())
|
|
||||||
if names[4]:
|
|
||||||
aka.set_suffix(names[4].strip())
|
|
||||||
state.person.add_alternate_name(aka)
|
state.person.add_alternate_name(aka)
|
||||||
else:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def func_name_npfx(self, line, state):
|
def func_name_npfx(self, line, state):
|
||||||
state.name.set_title(line.data.strip())
|
state.name.set_title(line.data.strip())
|
||||||
@ -3595,7 +3571,7 @@ class GedcomParser(UpdateCallback):
|
|||||||
state.name.add_source_reference(sref)
|
state.name.add_source_reference(sref)
|
||||||
|
|
||||||
def parse_repository(self, repo):
|
def parse_repository(self, repo):
|
||||||
state = CurrentState()
|
state = GedcomUtils.CurrentState()
|
||||||
state.repo = repo
|
state.repo = repo
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
@ -3648,7 +3624,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
addr.set_state(groups[3].strip())
|
addr.set_state(groups[3].strip())
|
||||||
addr.set_postal_code(groups[4].strip())
|
addr.set_postal_code(groups[4].strip())
|
||||||
addr.set_country(groups[5].strip())
|
addr.set_country(groups[5].strip())
|
||||||
matched = True
|
|
||||||
|
|
||||||
match = ADDR2_RE.match(text)
|
match = ADDR2_RE.match(text)
|
||||||
if match:
|
if match:
|
||||||
@ -3657,7 +3632,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
addr.set_city(groups[2].strip())
|
addr.set_city(groups[2].strip())
|
||||||
addr.set_state(groups[3].strip())
|
addr.set_state(groups[3].strip())
|
||||||
addr.set_postal_code(groups[4].strip())
|
addr.set_postal_code(groups[4].strip())
|
||||||
matched = True
|
|
||||||
|
|
||||||
match = ADDR3_RE.match(text)
|
match = ADDR3_RE.match(text)
|
||||||
if match:
|
if match:
|
||||||
@ -3665,7 +3639,6 @@ class GedcomParser(UpdateCallback):
|
|||||||
addr.set_street(groups[0].strip())
|
addr.set_street(groups[0].strip())
|
||||||
addr.set_city(groups[2].strip())
|
addr.set_city(groups[2].strip())
|
||||||
addr.set_state(groups[3].strip())
|
addr.set_state(groups[3].strip())
|
||||||
matched = True
|
|
||||||
|
|
||||||
repo.add_address(addr)
|
repo.add_address(addr)
|
||||||
|
|
||||||
@ -3843,16 +3816,6 @@ def family_event_name(event, family):
|
|||||||
}
|
}
|
||||||
event.set_description(text)
|
event.set_description(text)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
|
|
||||||
def create_id():
|
|
||||||
return Utils.create_id()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
import const
|
import const
|
||||||
import sys
|
import sys
|
||||||
|
@ -22,6 +22,45 @@ import re
|
|||||||
|
|
||||||
import RelLib
|
import RelLib
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# CurrentState
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
class CurrentState:
|
||||||
|
"""
|
||||||
|
Keeps track of the current state variables
|
||||||
|
"""
|
||||||
|
def __init__(self, person=None, level=0, event=None, event_ref=None):
|
||||||
|
"""
|
||||||
|
Initializes the object
|
||||||
|
"""
|
||||||
|
self.note = ""
|
||||||
|
self.name_cnt = 0
|
||||||
|
self.person = person
|
||||||
|
self.level = level
|
||||||
|
self.event = event
|
||||||
|
self.event_ref = event_ref
|
||||||
|
self.source_ref = None
|
||||||
|
|
||||||
|
def __getattr__(self, name):
|
||||||
|
"""
|
||||||
|
Returns the value associated with the specified attribute.
|
||||||
|
"""
|
||||||
|
return self.__dict__.get(name)
|
||||||
|
|
||||||
|
def __setattr__(self, name, value):
|
||||||
|
"""
|
||||||
|
Sets the value associated with the specified attribute.
|
||||||
|
"""
|
||||||
|
self.__dict__[name] = value
|
||||||
|
|
||||||
|
def add_to_note(self, text):
|
||||||
|
self.note += text
|
||||||
|
|
||||||
|
def get_text(self):
|
||||||
|
return self.note
|
||||||
|
|
||||||
class PlaceParser:
|
class PlaceParser:
|
||||||
|
|
||||||
field_map = {
|
field_map = {
|
||||||
@ -101,7 +140,7 @@ class IdFinder:
|
|||||||
NAME_RE = re.compile(r"/?([^/]*)(/([^/]*)(/([^/]*))?)?")
|
NAME_RE = re.compile(r"/?([^/]*)(/([^/]*)(/([^/]*))?)?")
|
||||||
SURNAME_RE = re.compile(r"/([^/]*)/([^/]*)")
|
SURNAME_RE = re.compile(r"/([^/]*)/([^/]*)")
|
||||||
|
|
||||||
def parse_name_personal(self, text):
|
def parse_name_personal(text):
|
||||||
name = RelLib.Name()
|
name = RelLib.Name()
|
||||||
|
|
||||||
m = SURNAME_RE.match(text)
|
m = SURNAME_RE.match(text)
|
||||||
@ -119,7 +158,7 @@ def parse_name_personal(self, text):
|
|||||||
name.set_first_name(text.strip())
|
name.set_first_name(text.strip())
|
||||||
return name
|
return name
|
||||||
|
|
||||||
def extract_id(self):
|
def extract_id(value):
|
||||||
"""
|
"""
|
||||||
Extracts a value to use for the GRAMPS ID value from the GEDCOM
|
Extracts a value to use for the GRAMPS ID value from the GEDCOM
|
||||||
reference token. The value should be in the form of @XXX@, and the
|
reference token. The value should be in the form of @XXX@, and the
|
||||||
|
Loading…
x
Reference in New Issue
Block a user