Code Search for Developers
 
 
  

_ReadGedcom.py from gramps at Krugle


Show _ReadGedcom.py syntax highlighted

#
# 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: _ReadGedcom.py 8735 2007-07-18 04:33:20Z dallingham $

"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





See more files for this project here

gramps

GRAMPS is a GNOME genealogy program for Linux and FreeBSD that allows you to easily build\r\nand keep track of your family tree.

Project homepage: http://sourceforge.net/projects/gramps
Programming language(s): Python
License: other

  Makefile.am
  _Backup.py
  _FilterProxyDb.py
  _GedcomChar.py
  _GedcomInfo.py
  _GedcomLex.py
  _GedcomParse.py
  _GedcomTokens.py
  _GedcomUtils.py
  _GrampsDbWRFactories.py
  _LivingProxyDb.py
  _PrivateProxyDb.py
  _ProxyDbBase.py
  _ReadGedcom.py
  _ReadXML.py
  _WriteGedcom.py
  _WriteGrdb.py
  _WriteXML.py
  __init__.py
  gedcomimport.glade