* src/plugins/ImportGeneWeb.py: Add line numbers to error messages; Support for "csrc" and "cbp" fields; Catch empty date
svn: r4343
This commit is contained in:
parent
88e5406249
commit
ad1621c3ea
@ -3,6 +3,9 @@
|
|||||||
|
|
||||||
* src/plugins/Check.py: Fix events, that reference non existing places
|
* src/plugins/Check.py: Fix events, that reference non existing places
|
||||||
|
|
||||||
|
* src/plugins/ImportGeneWeb.py: Add line numbers to error messages;
|
||||||
|
Support for "csrc" and "cbp" fields; Catch empty date
|
||||||
|
|
||||||
2005-04-10 Alex Roitman <shura@gramps-project.org>
|
2005-04-10 Alex Roitman <shura@gramps-project.org>
|
||||||
* Release: Version 1.1.95 "When danger reared its ugly head,
|
* Release: Version 1.1.95 "When danger reared its ugly head,
|
||||||
he bravely turned his tail and fled" released.
|
he bravely turned his tail and fled" released.
|
||||||
|
@ -97,6 +97,7 @@ class GeneWebParser:
|
|||||||
self.filename = file
|
self.filename = file
|
||||||
|
|
||||||
def get_next_line(self):
|
def get_next_line(self):
|
||||||
|
self.lineno += 1
|
||||||
line = self.f.readline()
|
line = self.f.readline()
|
||||||
if line:
|
if line:
|
||||||
line = line.strip()
|
line = line.strip()
|
||||||
@ -109,6 +110,7 @@ class GeneWebParser:
|
|||||||
self.trans.set_batch(True)
|
self.trans.set_batch(True)
|
||||||
self.db.disable_signals()
|
self.db.disable_signals()
|
||||||
t = time.time()
|
t = time.time()
|
||||||
|
self.lineno = 0
|
||||||
self.index = 0
|
self.index = 0
|
||||||
self.fam_count = 0
|
self.fam_count = 0
|
||||||
self.indi_count = 0
|
self.indi_count = 0
|
||||||
@ -121,6 +123,8 @@ class GeneWebParser:
|
|||||||
self.current_mode = None
|
self.current_mode = None
|
||||||
self.current_family = None
|
self.current_family = None
|
||||||
self.current_husband_handle = None
|
self.current_husband_handle = None
|
||||||
|
self.current_child_birthplace_handle = None
|
||||||
|
self.current_child_source_handle = None
|
||||||
try:
|
try:
|
||||||
while 1:
|
while 1:
|
||||||
line = self.get_next_line()
|
line = self.get_next_line()
|
||||||
@ -140,6 +144,8 @@ class GeneWebParser:
|
|||||||
self.read_witness_line(line,fields)
|
self.read_witness_line(line,fields)
|
||||||
elif fields[0] == "cbp":
|
elif fields[0] == "cbp":
|
||||||
self.read_children_birthplace_line(line,fields)
|
self.read_children_birthplace_line(line,fields)
|
||||||
|
elif fields[0] == "csrc":
|
||||||
|
self.read_children_source_line(line,fields)
|
||||||
elif fields[0] == "beg":
|
elif fields[0] == "beg":
|
||||||
self.read_children_lines()
|
self.read_children_lines()
|
||||||
elif fields[0] == "comm":
|
elif fields[0] == "comm":
|
||||||
@ -149,7 +155,7 @@ class GeneWebParser:
|
|||||||
elif fields[0] == "end":
|
elif fields[0] == "end":
|
||||||
self.current_mode = None
|
self.current_mode = None
|
||||||
else:
|
else:
|
||||||
print "Token >%s< unknown. line skipped: %s" % (fields[0],line)
|
print "Token >%s< unknown. line %d skipped: %s" % (fields[0],self.lineno,line)
|
||||||
except Errors.GedcomError, err:
|
except Errors.GedcomError, err:
|
||||||
self.errmsg(str(err))
|
self.errmsg(str(err))
|
||||||
|
|
||||||
@ -167,6 +173,8 @@ class GeneWebParser:
|
|||||||
|
|
||||||
def read_family_line(self,line,fields):
|
def read_family_line(self,line,fields):
|
||||||
self.current_husband_handle = None
|
self.current_husband_handle = None
|
||||||
|
self.current_child_birthplace_handle = None
|
||||||
|
self.current_child_source_handle = None
|
||||||
self.current_family = RelLib.Family()
|
self.current_family = RelLib.Family()
|
||||||
self.db.add_family(self.current_family,self.trans)
|
self.db.add_family(self.current_family,self.trans)
|
||||||
self.db.commit_family(self.current_family,self.trans)
|
self.db.commit_family(self.current_family,self.trans)
|
||||||
@ -194,7 +202,7 @@ class GeneWebParser:
|
|||||||
|
|
||||||
def read_source_line(self,line,fields):
|
def read_source_line(self,line,fields):
|
||||||
if not self.current_family:
|
if not self.current_family:
|
||||||
print "Unknown family of child!"
|
print "Unknown family of child in line %d!" % self.lineno
|
||||||
return None
|
return None
|
||||||
source = self.get_or_create_source(self.decode(fields[1]))
|
source = self.get_or_create_source(self.decode(fields[1]))
|
||||||
self.current_family.add_source_reference(source)
|
self.current_family.add_source_reference(source)
|
||||||
@ -214,12 +222,12 @@ class GeneWebParser:
|
|||||||
def read_children_lines(self):
|
def read_children_lines(self):
|
||||||
father_surname = "Dummy"
|
father_surname = "Dummy"
|
||||||
if not self.current_husband_handle:
|
if not self.current_husband_handle:
|
||||||
print "Unknown father for child!"
|
print "Unknown father for child in line %d!" % self.lineno
|
||||||
return None
|
return None
|
||||||
husb = self.db.get_person_from_handle(self.current_husband_handle)
|
husb = self.db.get_person_from_handle(self.current_husband_handle)
|
||||||
father_surname = husb.get_primary_name().get_surname()
|
father_surname = husb.get_primary_name().get_surname()
|
||||||
if not self.current_family:
|
if not self.current_family:
|
||||||
print "Unknown family of child!"
|
print "Unknown family of child in line %d!" % self.lineno
|
||||||
return None
|
return None
|
||||||
while 1:
|
while 1:
|
||||||
line = self.get_next_line()
|
line = self.get_next_line()
|
||||||
@ -243,6 +251,15 @@ class GeneWebParser:
|
|||||||
self.current_family.add_child_handle(child.get_handle())
|
self.current_family.add_child_handle(child.get_handle())
|
||||||
self.db.commit_family(self.current_family,self.trans)
|
self.db.commit_family(self.current_family,self.trans)
|
||||||
child.add_parent_family_handle(self.current_family.get_handle(),RelLib.Person.CHILD_REL_BIRTH,RelLib.Person.CHILD_REL_BIRTH)
|
child.add_parent_family_handle(self.current_family.get_handle(),RelLib.Person.CHILD_REL_BIRTH,RelLib.Person.CHILD_REL_BIRTH)
|
||||||
|
if self.current_child_birthplace_handle:
|
||||||
|
birth_handle = child.get_birth_handle()
|
||||||
|
birth = self.db.get_event_from_handle(birth_handle)
|
||||||
|
if not birth:
|
||||||
|
birth = RelLib.Event()
|
||||||
|
birth.set_place_handle(self.current_child_birthplace_handle)
|
||||||
|
self.db.commit_event(birth,self.trans)
|
||||||
|
if self.current_child_source_handle:
|
||||||
|
child.add_source_reference(self.current_child_source_handle)
|
||||||
self.db.commit_person(child,self.trans)
|
self.db.commit_person(child,self.trans)
|
||||||
else:
|
else:
|
||||||
break
|
break
|
||||||
@ -250,11 +267,19 @@ class GeneWebParser:
|
|||||||
|
|
||||||
|
|
||||||
def read_children_birthplace_line(self,line,fields):
|
def read_children_birthplace_line(self,line,fields):
|
||||||
|
cbp = self.get_or_create_place(self.decode(fields[1]))
|
||||||
|
if cbp:
|
||||||
|
self.current_child_birthplace_handle = cbp.get_handle()
|
||||||
|
return None
|
||||||
|
|
||||||
|
def read_children_source_line(self,line,fields):
|
||||||
|
csrc = self.get_or_create_source(self.decode(fields[1]))
|
||||||
|
self.current_child_source_handle = csrc
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def read_family_comment(self,line,fields):
|
def read_family_comment(self,line,fields):
|
||||||
if not self.current_family:
|
if not self.current_family:
|
||||||
print "Unknown family of child!"
|
print "Unknown family of child in line %d!" % self.lineno
|
||||||
return None
|
return None
|
||||||
self.current_family.set_note(self.cnv(line))
|
self.current_family.set_note(self.cnv(line))
|
||||||
self.db.commit_family(self.current_family,self.trans)
|
self.db.commit_family(self.current_family,self.trans)
|
||||||
@ -301,7 +326,7 @@ class GeneWebParser:
|
|||||||
#Alex: this failed when fields[idx] was an empty line. Fixed.
|
#Alex: this failed when fields[idx] was an empty line. Fixed.
|
||||||
#while idx < len(fields) and not fields[idx][0] == "+":
|
#while idx < len(fields) and not fields[idx][0] == "+":
|
||||||
while idx < len(fields) and not (fields[idx] and fields[idx][0] == "+"):
|
while idx < len(fields) and not (fields[idx] and fields[idx][0] == "+"):
|
||||||
print "Unknown field: "+fields[idx]
|
print "Unknown field: '%s' in line %d!" %(fields[idx],self.lineno)
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
|
|
||||||
while idx < len(fields) and mariageDataRe.match(fields[idx]):
|
while idx < len(fields) and mariageDataRe.match(fields[idx]):
|
||||||
@ -337,7 +362,7 @@ class GeneWebParser:
|
|||||||
engaged = 1
|
engaged = 1
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
else:
|
else:
|
||||||
print "Unknown field for mariage: %s" % fields[idx]
|
print "Unknown field '%s'for mariage in line %d!" % (fields[idx],self.lineno)
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
|
|
||||||
if mar_date or mar_place or mar_source:
|
if mar_date or mar_place or mar_source:
|
||||||
@ -367,7 +392,7 @@ class GeneWebParser:
|
|||||||
|
|
||||||
if not father_surname:
|
if not father_surname:
|
||||||
if not idx < len(fields):
|
if not idx < len(fields):
|
||||||
print "Missing surname of person"
|
print "Missing surname of person in line %d!" % self.lineno
|
||||||
return (idx,None)
|
return (idx,None)
|
||||||
surname = self.decode(fields[idx])
|
surname = self.decode(fields[idx])
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
@ -375,7 +400,7 @@ class GeneWebParser:
|
|||||||
surname = father_surname
|
surname = father_surname
|
||||||
|
|
||||||
if not idx < len(fields):
|
if not idx < len(fields):
|
||||||
print "Missing firstname of person"
|
print "Missing firstname of person in line %d!" % self.lineno
|
||||||
return (idx,None)
|
return (idx,None)
|
||||||
firstname = self.decode(self.cnv(fields[idx]))
|
firstname = self.decode(self.cnv(fields[idx]))
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
@ -534,7 +559,7 @@ class GeneWebParser:
|
|||||||
death_date = self.parse_date(self.decode(fields[idx]))
|
death_date = self.parse_date(self.decode(fields[idx]))
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
else:
|
else:
|
||||||
print "Unknown field for person: %s" % fields[idx]
|
print "Unknown field '%s' for person in line %d!" % (fields[idx],self.lineno)
|
||||||
idx = idx + 1
|
idx = idx + 1
|
||||||
|
|
||||||
if public_name:
|
if public_name:
|
||||||
@ -611,6 +636,8 @@ class GeneWebParser:
|
|||||||
return (idx,person)
|
return (idx,person)
|
||||||
|
|
||||||
def parse_date(self,field):
|
def parse_date(self,field):
|
||||||
|
if field == "0":
|
||||||
|
return None
|
||||||
date = _dp.parse(field)
|
date = _dp.parse(field)
|
||||||
return date
|
return date
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user