# # 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" #------------------------------------------------------------------------ # # python modules # #------------------------------------------------------------------------ import os from gettext import gettext as _ import gtk #------------------------------------------------------------------------ # # Set up logging # #------------------------------------------------------------------------ import logging LOG = logging.getLogger(".GedcomImport") #------------------------------------------------------------------------ # # GRAMPS modules # #------------------------------------------------------------------------ import Errors from _GedcomParse import GedcomParser from _GedcomStageOne import StageOne from QuestionDialog import ErrorDialog, DBErrorDialog try: import Config DEFAULT_SOURCE = Config.get(Config.DEFAULT_SOURCE) except ImportError: LOG.warn("No Config module available using defaults.") DEFAULT_SOURCE = False #------------------------------------------------------------------------- # # importData # #------------------------------------------------------------------------- def importData(database, filename, callback=None, use_trans=False): """ Try to handle ANSEL encoded files that are not really ANSEL encoded """ 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) #------------------------------------------------------------------------- # # import2 # #------------------------------------------------------------------------- def import2(database, filename, callback, code_set, use_trans): """ Do the actual import of data """ assert(type(code_set) == str or type(code_set) == unicode) try: ifile = open(filename,"rU") stage_one = StageOne(ifile) stage_one.parse() if code_set: stage_one.set_encoding(code_set) ifile.seek(0) gedparse = GedcomParser(database, ifile, filename, callback, stage_one, DEFAULT_SOURCE) 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 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