ac39ec2207
menu 2007-07-17 Don Allingham <don@gramps-project.org> svn: r8735
153 lines
4.7 KiB
Python
153 lines
4.7 KiB
Python
#
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
#
|
|
# Copyright (C) 2000-2006 Donald N. Allingham
|
|
#
|
|
# 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
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
|
|
# $Id$
|
|
|
|
"Import from GEDCOM"
|
|
|
|
import os
|
|
import gtk
|
|
|
|
import Errors
|
|
from _GedcomParse import GedcomParser, StageOne
|
|
from QuestionDialog import ErrorDialog, DBErrorDialog
|
|
|
|
#-------------------------------------------------------------------------
|
|
#
|
|
#
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
def importData(database, filename, callback=None, use_trans=False):
|
|
|
|
try:
|
|
ifile = open(filename, "r")
|
|
except IOError:
|
|
return
|
|
|
|
ansel = False
|
|
gramps = False
|
|
for index in range(50):
|
|
line = ifile.readline().split()
|
|
if len(line) == 0:
|
|
break
|
|
if len(line) > 2 and line[1][0:4] == 'CHAR' and line[2] == "ANSEL":
|
|
ansel = True
|
|
if len(line) > 2 and line[1][0:4] == 'SOUR' and line[2] == "GRAMPS":
|
|
gramps = True
|
|
ifile.close()
|
|
|
|
if not gramps and ansel:
|
|
glade_file = "%s/gedcomimport.glade" % os.path.dirname(__file__)
|
|
top = gtk.glade.XML(glade_file, 'encoding','gramps')
|
|
code = top.get_widget('codeset')
|
|
code.set_active(0)
|
|
dialog = top.get_widget('encoding')
|
|
dialog.run()
|
|
enc = ['ANSEL', 'ANSEL', 'ANSI', 'ASCII', 'UTF-8']
|
|
code_set = enc[ code.get_active()]
|
|
dialog.destroy()
|
|
else:
|
|
code_set = ""
|
|
|
|
import2(database, filename, callback, code_set, use_trans)
|
|
|
|
def import2(database, filename, callback, code_set, use_trans):
|
|
# add some checking here
|
|
|
|
assert(type(code_set) == str or type(code_set) == unicode)
|
|
|
|
try:
|
|
ifile = open(filename,"rU")
|
|
np = StageOne(ifile)
|
|
np.parse()
|
|
|
|
if code_set:
|
|
np.set_encoding(code_set)
|
|
ifile.seek(0)
|
|
gedparse = GedcomParser(database, ifile, filename, callback, np)
|
|
except IOError, msg:
|
|
ErrorDialog(_("%s could not be opened\n") % filename, str(msg))
|
|
return
|
|
except Errors.GedcomError, msg:
|
|
ErrorDialog(_("Invalid GEDCOM file"),
|
|
_("%s could not be imported") % filename + "\n" + str(msg))
|
|
return
|
|
|
|
if database.get_number_of_people() == 0:
|
|
use_trans = False
|
|
|
|
try:
|
|
read_only = database.readonly
|
|
database.readonly = False
|
|
close = gedparse.parse_gedcom_file(use_trans)
|
|
database.readonly = read_only
|
|
ifile.close()
|
|
except IOError, msg:
|
|
msg = _("%s could not be opened\n") % filename
|
|
ErrorDialog(msg, str(msg))
|
|
return
|
|
except Errors.DbError, msg:
|
|
DBErrorDialog(str(msg.value))
|
|
return
|
|
except Errors.GedcomError, msg:
|
|
ErrorDialog(_('Error reading GEDCOM file'), str(msg))
|
|
return
|
|
|
|
def import_from_string(database, text, callback, code_set, use_trans):
|
|
# add some checking here
|
|
|
|
from cStringIO import StringIO
|
|
|
|
ifile = StringIO(text)
|
|
|
|
try:
|
|
np = NoteParser(ifile, False, code_set)
|
|
ifile.seek(0)
|
|
gedparse = GedcomParser(database, ifile, "inline-string", callback,
|
|
code_set, np.get_map(), np.get_lines(),
|
|
np.get_persons())
|
|
except IOError, msg:
|
|
ErrorDialog(_("%s could not be opened\n") % "inline-string", str(msg))
|
|
return
|
|
|
|
if database.get_number_of_people() == 0:
|
|
use_trans = False
|
|
|
|
try:
|
|
read_only = database.readonly
|
|
database.readonly = False
|
|
gedparse.parse_gedcom_file(use_trans)
|
|
database.readonly = read_only
|
|
ifile.close()
|
|
except IOError, msg:
|
|
msg = _("%s could not be opened\n") % 'inline-string'
|
|
ErrorDialog(msg, str(msg))
|
|
return
|
|
except Errors.DbError, msg:
|
|
WarningDialog(_('Database corruption detected'),
|
|
_('A problem was detected with the database. Please '
|
|
'run the Check and Repair Database tool to fix the '
|
|
'problem.'))
|
|
return
|
|
except Errors.GedcomError, msg:
|
|
ErrorDialog(_('Error reading GEDCOM file'), str(msg))
|
|
return
|
|
|