and rel_it.py.
* src/ArgHandler.py: Split off gramps_main into a separate file. * src/gramps_main.py: Likewise. * src/Makefile.am, src/Makefile.in: Ship src/ArgHandler.py. * NEWS: More items. svn: r2242
This commit is contained in:
parent
1b8ea5487c
commit
3d69bafa2f
@ -3,7 +3,11 @@
|
|||||||
Remove extra files.
|
Remove extra files.
|
||||||
* AUTHORS: Consolidate with src/AUTHORS.
|
* AUTHORS: Consolidate with src/AUTHORS.
|
||||||
* src/plugins/Makefile.am, src/plugins/Makefile.in: Ship RelGraph.py
|
* src/plugins/Makefile.am, src/plugins/Makefile.in: Ship RelGraph.py
|
||||||
and rel_it.py.
|
and rel_it.py.
|
||||||
|
* src/ArgHandler.py: Split off gramps_main into a separate file.
|
||||||
|
* src/gramps_main.py: Likewise.
|
||||||
|
* src/Makefile.am, src/Makefile.in: Ship src/ArgHandler.py.
|
||||||
|
* NEWS: More items.
|
||||||
|
|
||||||
2003-10-12 Don Allingham <dallingham@users.sourceforge.net>
|
2003-10-12 Don Allingham <dallingham@users.sourceforge.net>
|
||||||
* src/RelLib.py : support for capitalized name formats
|
* src/RelLib.py : support for capitalized name formats
|
||||||
|
11
NEWS
11
NEWS
@ -1,6 +1,11 @@
|
|||||||
Version 0.9.6?
|
Version 0.9.6
|
||||||
* Person View uses a tree format instead of list format
|
* More compliance with GNOME HIG.
|
||||||
* Captialization is done as a display format, not as a database modification
|
* New BookReport dialog layout.
|
||||||
|
* Person View uses a tree format instead of list format.
|
||||||
|
* Captialization is done as a display format, not as a database modification.
|
||||||
|
* New Advanced Relationship Graph report generator (Lorenzo Cappelletti).
|
||||||
|
* Italian relationship calculator (Lorenzo Cappelletti).
|
||||||
|
* Bugfixes.
|
||||||
|
|
||||||
Version 0.9.5 -- the "Fix me up" release
|
Version 0.9.5 -- the "Fix me up" release
|
||||||
* Fixed problem with deleting/merging people.
|
* Fixed problem with deleting/merging people.
|
||||||
|
334
src/ArgHandler.py
Normal file
334
src/ArgHandler.py
Normal file
@ -0,0 +1,334 @@
|
|||||||
|
#
|
||||||
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
|
#
|
||||||
|
# Copyright (C) 2000-2003 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$
|
||||||
|
|
||||||
|
#
|
||||||
|
# Written by Alex Roitman
|
||||||
|
#
|
||||||
|
|
||||||
|
"""
|
||||||
|
Module responsible for handling the command line arguments for GRAMPS.
|
||||||
|
"""
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Standard python modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import os
|
||||||
|
import getopt
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# gramps modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import const
|
||||||
|
import ReadXML
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# ArgHandler
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
class ArgHandler:
|
||||||
|
|
||||||
|
def __init__(self,parent,args):
|
||||||
|
self.parent = parent
|
||||||
|
self.handle_args(args)
|
||||||
|
|
||||||
|
def handle_args(self,args):
|
||||||
|
try:
|
||||||
|
options,leftargs = getopt.getopt(args,
|
||||||
|
const.shortopts,const.longopts)
|
||||||
|
except getopt.GetoptError,msg:
|
||||||
|
print "Error: %s. Exiting." % msg
|
||||||
|
os._exit(1)
|
||||||
|
except:
|
||||||
|
print "Error parsing arguments: %s " % args
|
||||||
|
if leftargs:
|
||||||
|
print "Unrecognized option: %s" % leftargs[0]
|
||||||
|
os._exit(1)
|
||||||
|
exports = []
|
||||||
|
actions = []
|
||||||
|
imports = []
|
||||||
|
for opt_ix in range(len(options)):
|
||||||
|
o = options[opt_ix][0][1]
|
||||||
|
if o == '-':
|
||||||
|
continue
|
||||||
|
elif o == 'i':
|
||||||
|
fname = options[opt_ix][1]
|
||||||
|
if opt_ix<len(options)-1 and options[opt_ix+1][0][1]=='f':
|
||||||
|
format = options[opt_ix+1][1]
|
||||||
|
if format not in [ 'gedcom', 'gramps', 'gramps-pkg' ]:
|
||||||
|
print "Invalid format: %s" % format
|
||||||
|
os._exit(1)
|
||||||
|
elif fname[-3:].upper()== "GED":
|
||||||
|
format = 'gedcom'
|
||||||
|
elif fname[-3:].upper() == "TGZ":
|
||||||
|
format = 'gramps-pkg'
|
||||||
|
elif os.path.isdir(fname):
|
||||||
|
format = 'gramps'
|
||||||
|
else:
|
||||||
|
print "Unrecognized format for input file %s" % fname
|
||||||
|
os._exit(1)
|
||||||
|
imports.append((fname,format))
|
||||||
|
elif o == 'o':
|
||||||
|
outfname = options[opt_ix][1]
|
||||||
|
if opt_ix<len(options)-1 and options[opt_ix+1][0][1]=='f':
|
||||||
|
outformat = options[opt_ix+1][1]
|
||||||
|
if outformat not in [ 'gedcom', 'gramps', 'gramps-pkg', 'iso', 'wft' ]:
|
||||||
|
print "Invalid format: %s" % outformat
|
||||||
|
os._exit(1)
|
||||||
|
elif outfname[-3:].upper() == "GED":
|
||||||
|
outformat = 'gedcom'
|
||||||
|
elif outfname[-3:].upper() == "TGZ":
|
||||||
|
outformat = 'gramps-pkg'
|
||||||
|
elif outfname[-3:].upper() == "WFT":
|
||||||
|
outformat = 'wft'
|
||||||
|
elif not os.path.isfile(outfname):
|
||||||
|
if not os.path.isdir(outfname):
|
||||||
|
try:
|
||||||
|
os.makedirs(outfname,0700)
|
||||||
|
except:
|
||||||
|
print "Cannot create directory %s" % outfname
|
||||||
|
os._exit(1)
|
||||||
|
outformat = 'gramps'
|
||||||
|
else:
|
||||||
|
print "Unrecognized format for output file %s" % outfname
|
||||||
|
os._exit(1)
|
||||||
|
exports.append((outfname,outformat))
|
||||||
|
elif o == 'a':
|
||||||
|
action = options[opt_ix][1]
|
||||||
|
if action not in [ 'check', 'summary' ]:
|
||||||
|
print "Unknown action: %s." % action
|
||||||
|
os._exit(1)
|
||||||
|
actions.append(action)
|
||||||
|
|
||||||
|
if imports:
|
||||||
|
self.parent.cl = bool(exports or actions)
|
||||||
|
# Create dir for imported database(s)
|
||||||
|
self.impdir_path = os.path.expanduser("~/.gramps/import" )
|
||||||
|
if not os.path.isdir(self.impdir_path):
|
||||||
|
try:
|
||||||
|
os.mkdir(self.impdir_path,0700)
|
||||||
|
except:
|
||||||
|
print "Could not create import directory %s. Exiting." \
|
||||||
|
% self.impdir_path
|
||||||
|
os._exit(1)
|
||||||
|
elif not os.access(self.impdir_path,os.W_OK):
|
||||||
|
print "Import directory %s is not writable. Exiting." \
|
||||||
|
% self.impdir_path
|
||||||
|
os._exit(1)
|
||||||
|
# and clean it up before use
|
||||||
|
files = os.listdir(self.impdir_path) ;
|
||||||
|
for fn in files:
|
||||||
|
if os.path.isfile(os.path.join(self.impdir_path,fn)):
|
||||||
|
os.remove(os.path.join(self.impdir_path,fn))
|
||||||
|
self.parent.clear_database(0)
|
||||||
|
self.parent.db.setSavePath(self.impdir_path)
|
||||||
|
for imp in imports:
|
||||||
|
print "Importing: file %s, format %s." % (imp[0],imp[1])
|
||||||
|
self.cl_import(imp[0],imp[1])
|
||||||
|
else:
|
||||||
|
print "No data was given. Launching interactive session."
|
||||||
|
print "To use in the command-line mode,", \
|
||||||
|
"supply at least one input file to process."
|
||||||
|
|
||||||
|
if self.parent.cl:
|
||||||
|
for expt in exports:
|
||||||
|
print "Exporting: file %s, format %s." % (expt[0],expt[1])
|
||||||
|
self.cl_export(expt[0],expt[1])
|
||||||
|
|
||||||
|
for action in actions:
|
||||||
|
print "Performing action: %s." % action
|
||||||
|
self.cl_action(action)
|
||||||
|
|
||||||
|
print "Cleaning up."
|
||||||
|
# clean import dir up after use
|
||||||
|
files = os.listdir(self.impdir_path) ;
|
||||||
|
for fn in files:
|
||||||
|
if os.path.isfile(os.path.join(self.impdir_path,fn)):
|
||||||
|
os.remove(os.path.join(self.impdir_path,fn))
|
||||||
|
print "Exiting."
|
||||||
|
os._exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
def cl_import(self,filename,format):
|
||||||
|
if format == 'gedcom':
|
||||||
|
import ReadGedcom
|
||||||
|
filename = os.path.normpath(os.path.abspath(filename))
|
||||||
|
try:
|
||||||
|
g = ReadGedcom.GedcomParser(self.parent.db,filename,None)
|
||||||
|
g.parse_gedcom_file()
|
||||||
|
g.resolve_refns()
|
||||||
|
del g
|
||||||
|
except:
|
||||||
|
print "Error importing %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'gramps':
|
||||||
|
try:
|
||||||
|
dbname = os.path.join(filename,const.xmlFile)
|
||||||
|
ReadXML.importData(self.parent.db,dbname,None,self.parent.cl)
|
||||||
|
except:
|
||||||
|
print "Error importing %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'gramps-pkg':
|
||||||
|
# Create tempdir, if it does not exist, then check for writability
|
||||||
|
tmpdir_path = os.path.expanduser("~/.gramps/tmp" )
|
||||||
|
if not os.path.isdir(tmpdir_path):
|
||||||
|
try:
|
||||||
|
os.mkdir(tmpdir_path,0700)
|
||||||
|
except:
|
||||||
|
print "Could not create temporary directory %s" % tmpdir_path
|
||||||
|
os._exit(1)
|
||||||
|
elif not os.access(tmpdir_path,os.W_OK):
|
||||||
|
print "Temporary directory %s is not writable" % tmpdir_path
|
||||||
|
os._exit(1)
|
||||||
|
else: # tempdir exists and writable -- clean it up if not empty
|
||||||
|
files = os.listdir(tmpdir_path) ;
|
||||||
|
for fn in files:
|
||||||
|
os.remove( os.path.join(tmpdir_path,fn) )
|
||||||
|
|
||||||
|
try:
|
||||||
|
import TarFile
|
||||||
|
t = TarFile.ReadTarFile(filename,tmpdir_path)
|
||||||
|
t.extract()
|
||||||
|
t.close()
|
||||||
|
except:
|
||||||
|
print "Error extracting into %s" % tmpdir_path
|
||||||
|
os._exit(1)
|
||||||
|
|
||||||
|
dbname = os.path.join(tmpdir_path,const.xmlFile)
|
||||||
|
|
||||||
|
try:
|
||||||
|
ReadXML.importData(self.parent.db,dbname,None)
|
||||||
|
except:
|
||||||
|
print "Error importing %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
# Clean up tempdir after ourselves
|
||||||
|
files = os.listdir(tmpdir_path)
|
||||||
|
for fn in files:
|
||||||
|
os.remove(os.path.join(tmpdir_path,fn))
|
||||||
|
os.rmdir(tmpdir_path)
|
||||||
|
else:
|
||||||
|
print "Invalid format: %s" % format
|
||||||
|
os._exit(1)
|
||||||
|
if not self.parent.cl:
|
||||||
|
return self.parent.post_load(self.impdir_path)
|
||||||
|
|
||||||
|
def cl_export(self,filename,format):
|
||||||
|
if format == 'gedcom':
|
||||||
|
import WriteGedcom
|
||||||
|
try:
|
||||||
|
g = WriteGedcom.GedcomWriter(self.parent.db,None,1,filename)
|
||||||
|
del g
|
||||||
|
except:
|
||||||
|
print "Error exporting %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'gramps':
|
||||||
|
filename = os.path.normpath(os.path.abspath(filename))
|
||||||
|
dbname = os.path.join(filename,const.xmlFile)
|
||||||
|
if filename:
|
||||||
|
try:
|
||||||
|
self.parent.save_media(filename)
|
||||||
|
self.parent.db.save(dbname,None)
|
||||||
|
except:
|
||||||
|
print "Error exporting %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'gramps-pkg':
|
||||||
|
import TarFile
|
||||||
|
import time
|
||||||
|
import WriteXML
|
||||||
|
from cStringIO import StringIO
|
||||||
|
|
||||||
|
try:
|
||||||
|
t = TarFile.TarFile(filename)
|
||||||
|
mtime = time.time()
|
||||||
|
except:
|
||||||
|
print "Error creating %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
|
||||||
|
try:
|
||||||
|
# Write media files first, since the database may be modified
|
||||||
|
# during the process (i.e. when removing object)
|
||||||
|
ObjectMap = self.parent.db.getObjectMap()
|
||||||
|
for ObjectId in ObjectMap.keys():
|
||||||
|
oldfile = ObjectMap[ObjectId].getPath()
|
||||||
|
base = os.path.basename(oldfile)
|
||||||
|
if os.path.isfile(oldfile):
|
||||||
|
g = open(oldfile,"rb")
|
||||||
|
t.add_file(base,mtime,g)
|
||||||
|
g.close()
|
||||||
|
else:
|
||||||
|
print "Warning: media file %s was not found," % base,\
|
||||||
|
"so it was ignored."
|
||||||
|
except:
|
||||||
|
print "Error exporting media files to %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
try:
|
||||||
|
# Write XML now
|
||||||
|
g = StringIO()
|
||||||
|
gfile = WriteXML.XmlWriter(self.parent.db,None,1)
|
||||||
|
gfile.write_handle(g)
|
||||||
|
mtime = time.time()
|
||||||
|
t.add_file("data.gramps",mtime,g)
|
||||||
|
g.close()
|
||||||
|
t.close()
|
||||||
|
except:
|
||||||
|
print "Error exporting data to %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'iso':
|
||||||
|
import WriteCD
|
||||||
|
try:
|
||||||
|
WriteCD.PackageWriter(self.parent.db,1,filename)
|
||||||
|
except:
|
||||||
|
print "Error exporting %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
elif format == 'wft':
|
||||||
|
import WriteFtree
|
||||||
|
try:
|
||||||
|
WriteFtree.FtreeWriter(self.parent.db,None,1,filename)
|
||||||
|
except:
|
||||||
|
print "Error exporting %s" % filename
|
||||||
|
os._exit(1)
|
||||||
|
else:
|
||||||
|
print "Invalid format: %s" % format
|
||||||
|
os._exit(1)
|
||||||
|
|
||||||
|
def cl_action(self,action):
|
||||||
|
if action == 'check':
|
||||||
|
import Check
|
||||||
|
checker = Check.CheckIntegrity(self.parent.db)
|
||||||
|
checker.check_for_broken_family_links()
|
||||||
|
checker.cleanup_missing_photos(1)
|
||||||
|
checker.check_parent_relationships()
|
||||||
|
checker.cleanup_empty_families(0)
|
||||||
|
errs = checker.build_report(1)
|
||||||
|
if errs:
|
||||||
|
checker.report(1)
|
||||||
|
elif action == 'summary':
|
||||||
|
import Summary
|
||||||
|
text = Summary.build_report(self.parent.db,None)
|
||||||
|
print text
|
||||||
|
else:
|
||||||
|
print "Unknown action: %s." % action
|
||||||
|
os._exit(1)
|
@ -93,7 +93,8 @@ pkgpython_PYTHON = \
|
|||||||
VersionControl.py\
|
VersionControl.py\
|
||||||
Witness.py\
|
Witness.py\
|
||||||
WriteXML.py\
|
WriteXML.py\
|
||||||
SelectPerson.py
|
SelectPerson.py\
|
||||||
|
ArgHandler.py
|
||||||
|
|
||||||
# Could use GNU make's ':=' syntax for nice wildcard use.
|
# Could use GNU make's ':=' syntax for nice wildcard use.
|
||||||
# If not using GNU make, then list all files individually
|
# If not using GNU make, then list all files individually
|
||||||
|
@ -169,6 +169,8 @@ pkgpython_PYTHON = \
|
|||||||
NoteEdit.py\
|
NoteEdit.py\
|
||||||
PaperMenu.py\
|
PaperMenu.py\
|
||||||
PedView.py\
|
PedView.py\
|
||||||
|
PeopleView.py\
|
||||||
|
PeopleStore.py\
|
||||||
PlaceView.py\
|
PlaceView.py\
|
||||||
Plugins.py\
|
Plugins.py\
|
||||||
QuestionDialog.py\
|
QuestionDialog.py\
|
||||||
@ -195,7 +197,8 @@ pkgpython_PYTHON = \
|
|||||||
VersionControl.py\
|
VersionControl.py\
|
||||||
Witness.py\
|
Witness.py\
|
||||||
WriteXML.py\
|
WriteXML.py\
|
||||||
SelectPerson.py
|
SelectPerson.py\
|
||||||
|
ArgHandler.py
|
||||||
|
|
||||||
|
|
||||||
# Could use GNU make's ':=' syntax for nice wildcard use.
|
# Could use GNU make's ':=' syntax for nice wildcard use.
|
||||||
@ -562,8 +565,8 @@ install-data-local:
|
|||||||
$(INSTALL_DATA) $(srcdir)/gramps.png $(DESTDIR)$(prefix)/share/pixmaps
|
$(INSTALL_DATA) $(srcdir)/gramps.png $(DESTDIR)$(prefix)/share/pixmaps
|
||||||
$(INSTALL) -d $(DESTDIR)$(prefix)/share/gnome/apps/Applications
|
$(INSTALL) -d $(DESTDIR)$(prefix)/share/gnome/apps/Applications
|
||||||
$(INSTALL_DATA) $(srcdir)/gramps.desktop $(DESTDIR)$(prefix)/share/gnome/apps/Applications
|
$(INSTALL_DATA) $(srcdir)/gramps.desktop $(DESTDIR)$(prefix)/share/gnome/apps/Applications
|
||||||
$(INSTALL) -d $(pkglibdir)
|
$(INSTALL) -d $(DESTDIR)$(pkglibdir)
|
||||||
$(INSTALL_DATA) grampslib.so $(pkglibdir)
|
$(INSTALL_DATA) grampslib.so $(DESTDIR)$(pkglibdir)
|
||||||
|
|
||||||
uninstall-local:
|
uninstall-local:
|
||||||
-rm $(DESTDIR)$(prefix)/share/pixmaps/gramps.png
|
-rm $(DESTDIR)$(prefix)/share/pixmaps/gramps.png
|
||||||
|
@ -18,6 +18,8 @@
|
|||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# $Id$
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# Standard python modules
|
# Standard python modules
|
||||||
@ -152,7 +154,8 @@ class Gramps:
|
|||||||
self.init_interface()
|
self.init_interface()
|
||||||
|
|
||||||
if args:
|
if args:
|
||||||
self.handle_args(args)
|
import ArgHandler
|
||||||
|
ArgHandler.ArgHandler(self,args)
|
||||||
elif GrampsCfg.lastfile and GrampsCfg.autoload:
|
elif GrampsCfg.lastfile and GrampsCfg.autoload:
|
||||||
self.auto_save_load(GrampsCfg.lastfile)
|
self.auto_save_load(GrampsCfg.lastfile)
|
||||||
else:
|
else:
|
||||||
@ -1017,283 +1020,6 @@ class Gramps:
|
|||||||
self.people_view.apply_filter()
|
self.people_view.apply_filter()
|
||||||
self.goto_active_person(1)
|
self.goto_active_person(1)
|
||||||
|
|
||||||
def handle_args(self,args):
|
|
||||||
try:
|
|
||||||
options,leftargs = getopt.getopt(args,
|
|
||||||
const.shortopts,const.longopts)
|
|
||||||
except getopt.GetoptError,msg:
|
|
||||||
print "Error: %s. Exiting." % msg
|
|
||||||
os._exit(1)
|
|
||||||
except:
|
|
||||||
print "Error parsing arguments: %s " % args
|
|
||||||
if leftargs:
|
|
||||||
print "Unrecognized option: %s" % leftargs[0]
|
|
||||||
os._exit(1)
|
|
||||||
exports = []
|
|
||||||
actions = []
|
|
||||||
imports = []
|
|
||||||
for opt_ix in range(len(options)):
|
|
||||||
o = options[opt_ix][0][1]
|
|
||||||
if o == '-':
|
|
||||||
continue
|
|
||||||
elif o == 'i':
|
|
||||||
fname = options[opt_ix][1]
|
|
||||||
if opt_ix<len(options)-1 and options[opt_ix+1][0][1]=='f':
|
|
||||||
format = options[opt_ix+1][1]
|
|
||||||
if format not in [ 'gedcom', 'gramps', 'gramps-pkg' ]:
|
|
||||||
print "Invalid format: %s" % format
|
|
||||||
os._exit(1)
|
|
||||||
elif fname[-3:].upper()== "GED":
|
|
||||||
format = 'gedcom'
|
|
||||||
elif fname[-3:].upper() == "TGZ":
|
|
||||||
format = 'gramps-pkg'
|
|
||||||
elif os.path.isdir(fname):
|
|
||||||
format = 'gramps'
|
|
||||||
else:
|
|
||||||
print "Unrecognized format for input file %s" % fname
|
|
||||||
os._exit(1)
|
|
||||||
imports.append((fname,format))
|
|
||||||
elif o == 'o':
|
|
||||||
outfname = options[opt_ix][1]
|
|
||||||
if opt_ix<len(options)-1 and options[opt_ix+1][0][1]=='f':
|
|
||||||
outformat = options[opt_ix+1][1]
|
|
||||||
if outformat not in [ 'gedcom', 'gramps', 'gramps-pkg', 'iso', 'wft' ]:
|
|
||||||
print "Invalid format: %s" % outformat
|
|
||||||
os._exit(1)
|
|
||||||
elif outfname[-3:].upper() == "GED":
|
|
||||||
outformat = 'gedcom'
|
|
||||||
elif outfname[-3:].upper() == "TGZ":
|
|
||||||
outformat = 'gramps-pkg'
|
|
||||||
elif outfname[-3:].upper() == "WFT":
|
|
||||||
outformat = 'wft'
|
|
||||||
elif not os.path.isfile(outfname):
|
|
||||||
if not os.path.isdir(outfname):
|
|
||||||
try:
|
|
||||||
os.makedirs(outfname,0700)
|
|
||||||
except:
|
|
||||||
print "Cannot create directory %s" % outfname
|
|
||||||
os._exit(1)
|
|
||||||
outformat = 'gramps'
|
|
||||||
else:
|
|
||||||
print "Unrecognized format for output file %s" % outfname
|
|
||||||
os._exit(1)
|
|
||||||
exports.append((outfname,outformat))
|
|
||||||
elif o == 'a':
|
|
||||||
action = options[opt_ix][1]
|
|
||||||
if action not in [ 'check', 'summary' ]:
|
|
||||||
print "Unknown action: %s." % action
|
|
||||||
os._exit(1)
|
|
||||||
actions.append(action)
|
|
||||||
|
|
||||||
if imports:
|
|
||||||
self.cl = bool(exports or actions)
|
|
||||||
# Create dir for imported database(s)
|
|
||||||
self.impdir_path = os.path.expanduser("~/.gramps/import" )
|
|
||||||
if not os.path.isdir(self.impdir_path):
|
|
||||||
try:
|
|
||||||
os.mkdir(self.impdir_path,0700)
|
|
||||||
except:
|
|
||||||
print "Could not create import directory %s. Exiting." \
|
|
||||||
% self.impdir_path
|
|
||||||
os._exit(1)
|
|
||||||
elif not os.access(self.impdir_path,os.W_OK):
|
|
||||||
print "Import directory %s is not writable. Exiting." \
|
|
||||||
% self.impdir_path
|
|
||||||
os._exit(1)
|
|
||||||
# and clean it up before use
|
|
||||||
files = os.listdir(self.impdir_path) ;
|
|
||||||
for fn in files:
|
|
||||||
if os.path.isfile(os.path.join(self.impdir_path,fn)):
|
|
||||||
os.remove(os.path.join(self.impdir_path,fn))
|
|
||||||
|
|
||||||
self.clear_database(0)
|
|
||||||
self.db.setSavePath(self.impdir_path)
|
|
||||||
for imp in imports:
|
|
||||||
print "Importing: file %s, format %s." % (imp[0],imp[1])
|
|
||||||
self.cl_import(imp[0],imp[1])
|
|
||||||
else:
|
|
||||||
print "No data was given. Launching interactive session."
|
|
||||||
print "To use in the command-line mode,", \
|
|
||||||
"supply at least one input file to process."
|
|
||||||
|
|
||||||
if self.cl:
|
|
||||||
for expt in exports:
|
|
||||||
print "Exporting: file %s, format %s." % (expt[0],expt[1])
|
|
||||||
self.cl_export(expt[0],expt[1])
|
|
||||||
|
|
||||||
for action in actions:
|
|
||||||
print "Performing action: %s." % action
|
|
||||||
self.cl_action(action)
|
|
||||||
|
|
||||||
print "Cleaning up."
|
|
||||||
# clean import dir up after use
|
|
||||||
files = os.listdir(self.impdir_path) ;
|
|
||||||
for fn in files:
|
|
||||||
if os.path.isfile(os.path.join(self.impdir_path,fn)):
|
|
||||||
os.remove(os.path.join(self.impdir_path,fn))
|
|
||||||
print "Exiting."
|
|
||||||
os._exit(0)
|
|
||||||
|
|
||||||
def cl_import(self,filename,format):
|
|
||||||
if format == 'gedcom':
|
|
||||||
import ReadGedcom
|
|
||||||
filename = os.path.normpath(os.path.abspath(filename))
|
|
||||||
try:
|
|
||||||
g = ReadGedcom.GedcomParser(self.db,filename,None)
|
|
||||||
g.parse_gedcom_file()
|
|
||||||
g.resolve_refns()
|
|
||||||
del g
|
|
||||||
except:
|
|
||||||
print "Error importing %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'gramps':
|
|
||||||
try:
|
|
||||||
dbname = os.path.join(filename,const.xmlFile)
|
|
||||||
ReadXML.importData(self.db,dbname,None,self.cl)
|
|
||||||
except:
|
|
||||||
print "Error importing %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'gramps-pkg':
|
|
||||||
# Create tempdir, if it does not exist, then check for writability
|
|
||||||
tmpdir_path = os.path.expanduser("~/.gramps/tmp" )
|
|
||||||
if not os.path.isdir(tmpdir_path):
|
|
||||||
try:
|
|
||||||
os.mkdir(tmpdir_path,0700)
|
|
||||||
except:
|
|
||||||
print "Could not create temporary directory %s" % tmpdir_path
|
|
||||||
os._exit(1)
|
|
||||||
elif not os.access(tmpdir_path,os.W_OK):
|
|
||||||
print "Temporary directory %s is not writable" % tmpdir_path
|
|
||||||
os._exit(1)
|
|
||||||
else: # tempdir exists and writable -- clean it up if not empty
|
|
||||||
files = os.listdir(tmpdir_path) ;
|
|
||||||
for fn in files:
|
|
||||||
os.remove( os.path.join(tmpdir_path,fn) )
|
|
||||||
|
|
||||||
try:
|
|
||||||
import TarFile
|
|
||||||
t = TarFile.ReadTarFile(filename,tmpdir_path)
|
|
||||||
t.extract()
|
|
||||||
t.close()
|
|
||||||
except:
|
|
||||||
print "Error extracting into %s" % tmpdir_path
|
|
||||||
os._exit(1)
|
|
||||||
|
|
||||||
dbname = os.path.join(tmpdir_path,const.xmlFile)
|
|
||||||
|
|
||||||
try:
|
|
||||||
ReadXML.importData(self.db,dbname,None)
|
|
||||||
except:
|
|
||||||
print "Error importing %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
# Clean up tempdir after ourselves
|
|
||||||
files = os.listdir(tmpdir_path)
|
|
||||||
for fn in files:
|
|
||||||
os.remove(os.path.join(tmpdir_path,fn))
|
|
||||||
os.rmdir(tmpdir_path)
|
|
||||||
else:
|
|
||||||
print "Invalid format: %s" % format
|
|
||||||
os._exit(1)
|
|
||||||
if not self.cl:
|
|
||||||
return self.post_load(self.impdir_path)
|
|
||||||
|
|
||||||
def cl_export(self,filename,format):
|
|
||||||
if format == 'gedcom':
|
|
||||||
import WriteGedcom
|
|
||||||
try:
|
|
||||||
g = WriteGedcom.GedcomWriter(self.db,None,1,filename)
|
|
||||||
del g
|
|
||||||
except:
|
|
||||||
print "Error exporting %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'gramps':
|
|
||||||
filename = os.path.normpath(os.path.abspath(filename))
|
|
||||||
dbname = os.path.join(filename,const.xmlFile)
|
|
||||||
if filename:
|
|
||||||
try:
|
|
||||||
self.save_media(filename)
|
|
||||||
self.db.save(dbname,None)
|
|
||||||
except:
|
|
||||||
print "Error exporting %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'gramps-pkg':
|
|
||||||
import TarFile
|
|
||||||
import time
|
|
||||||
import WriteXML
|
|
||||||
from cStringIO import StringIO
|
|
||||||
|
|
||||||
try:
|
|
||||||
t = TarFile.TarFile(filename)
|
|
||||||
mtime = time.time()
|
|
||||||
except:
|
|
||||||
print "Error creating %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
|
|
||||||
try:
|
|
||||||
# Write media files first, since the database may be modified
|
|
||||||
# during the process (i.e. when removing object)
|
|
||||||
ObjectMap = self.db.getObjectMap()
|
|
||||||
for ObjectId in ObjectMap.keys():
|
|
||||||
oldfile = ObjectMap[ObjectId].getPath()
|
|
||||||
base = os.path.basename(oldfile)
|
|
||||||
if os.path.isfile(oldfile):
|
|
||||||
g = open(oldfile,"rb")
|
|
||||||
t.add_file(base,mtime,g)
|
|
||||||
g.close()
|
|
||||||
else:
|
|
||||||
print "Warning: media file %s was not found," % base,\
|
|
||||||
"so it was ignored."
|
|
||||||
except:
|
|
||||||
print "Error exporting media files to %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
try:
|
|
||||||
# Write XML now
|
|
||||||
g = StringIO()
|
|
||||||
gfile = WriteXML.XmlWriter(self.db,None,1)
|
|
||||||
gfile.write_handle(g)
|
|
||||||
mtime = time.time()
|
|
||||||
t.add_file("data.gramps",mtime,g)
|
|
||||||
g.close()
|
|
||||||
t.close()
|
|
||||||
except:
|
|
||||||
print "Error exporting data to %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'iso':
|
|
||||||
import WriteCD
|
|
||||||
try:
|
|
||||||
WriteCD.PackageWriter(self.db,1,filename)
|
|
||||||
except:
|
|
||||||
print "Error exporting %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
elif format == 'wft':
|
|
||||||
import WriteFtree
|
|
||||||
try:
|
|
||||||
WriteFtree.FtreeWriter(self.db,None,1,filename)
|
|
||||||
except:
|
|
||||||
print "Error exporting %s" % filename
|
|
||||||
os._exit(1)
|
|
||||||
else:
|
|
||||||
print "Invalid format: %s" % format
|
|
||||||
os._exit(1)
|
|
||||||
|
|
||||||
def cl_action(self,action):
|
|
||||||
if action == 'check':
|
|
||||||
import Check
|
|
||||||
checker = Check.CheckIntegrity(self.db)
|
|
||||||
checker.check_for_broken_family_links()
|
|
||||||
checker.cleanup_missing_photos(1)
|
|
||||||
checker.check_parent_relationships()
|
|
||||||
checker.cleanup_empty_families(0)
|
|
||||||
errs = checker.build_report(1)
|
|
||||||
if errs:
|
|
||||||
checker.report(1)
|
|
||||||
elif action == 'summary':
|
|
||||||
import Summary
|
|
||||||
text = Summary.build_report(self.db,None)
|
|
||||||
print text
|
|
||||||
else:
|
|
||||||
print "Unknown action: %s." % action
|
|
||||||
os._exit(1)
|
|
||||||
|
|
||||||
def on_ok_button2_clicked(self,obj):
|
def on_ok_button2_clicked(self,obj):
|
||||||
filename = obj.get_filename()
|
filename = obj.get_filename()
|
||||||
|
Loading…
Reference in New Issue
Block a user