* src/Exporter.py (Exporter.native_export): Use callback.
* src/Utils.py (get_new_filename): Add path separator. * src/GrampsDb/_WriteGrdb.py: Proper export of tables with and without transaction support, add callback. svn: r6600
This commit is contained in:
parent
8133c888f8
commit
8a8d5342ce
@ -1,4 +1,8 @@
|
|||||||
2006-05-09 Alex Roitman <shura@gramps-project.org>
|
2006-05-09 Alex Roitman <shura@gramps-project.org>
|
||||||
|
* src/Exporter.py (Exporter.native_export): Use callback.
|
||||||
|
* src/Utils.py (get_new_filename): Add path separator.
|
||||||
|
* src/GrampsDb/_WriteGrdb.py: Proper export of tables with and
|
||||||
|
without transaction support, add callback.
|
||||||
* src/plugins/WriteCD.py: Correctly import XmlWriter.
|
* src/plugins/WriteCD.py: Correctly import XmlWriter.
|
||||||
* src/GrampsDb/_WriteXML.py (write_object): Check whether path is
|
* src/GrampsDb/_WriteXML.py (write_object): Check whether path is
|
||||||
empty before removing leading slash.
|
empty before removing leading slash.
|
||||||
|
@ -331,7 +331,7 @@ class Exporter:
|
|||||||
else:
|
else:
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
def native_export(self,database,filename,person):
|
def native_export(self,database,filename,person,callback=None):
|
||||||
"""
|
"""
|
||||||
Native database export.
|
Native database export.
|
||||||
|
|
||||||
@ -340,7 +340,8 @@ class Exporter:
|
|||||||
try:
|
try:
|
||||||
gramps_db_writer_factory(const.app_gramps)(database,
|
gramps_db_writer_factory(const.app_gramps)(database,
|
||||||
filename,
|
filename,
|
||||||
person)
|
person,
|
||||||
|
callback)
|
||||||
return 1
|
return 1
|
||||||
except IOError, msg:
|
except IOError, msg:
|
||||||
QuestionDialog.ErrorDialog(
|
QuestionDialog.ErrorDialog(
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# Gramps - a GTK+/GNOME based genealogy program
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
#
|
#
|
||||||
# Copyright (C) 2005 Donald N. Allingham
|
# Copyright (C) 2005-2006 Donald N. Allingham
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# 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
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -45,8 +45,25 @@ from QuestionDialog import ErrorDialog
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def exportData(database, filename, person=None, callback=None, cl=False):
|
def exportData(database, filename, person=None, callback=None, cl=False):
|
||||||
|
|
||||||
filename = os.path.normpath(filename)
|
if '__call__' in dir(callback): # callback is really callable
|
||||||
|
update = update_real
|
||||||
|
|
||||||
|
# Prepare length for the callback
|
||||||
|
person_len = database.get_number_of_people()
|
||||||
|
family_len = database.get_number_of_families()
|
||||||
|
event_len = database.get_number_of_events()
|
||||||
|
source_len = database.get_number_of_sources()
|
||||||
|
place_len = database.get_number_of_places()
|
||||||
|
repo_len = database.get_number_of_repositories()
|
||||||
|
obj_len = database.get_number_of_media_objects()
|
||||||
|
|
||||||
|
total = person_len + family_len + event_len + place_len + \
|
||||||
|
source_len + obj_len + repo_len
|
||||||
|
else:
|
||||||
|
update = update_empty
|
||||||
|
total = 0
|
||||||
|
|
||||||
|
filename = os.path.normpath(filename)
|
||||||
new_database = GrampsBSDDB()
|
new_database = GrampsBSDDB()
|
||||||
try:
|
try:
|
||||||
new_database.load(filename,callback)
|
new_database.load(filename,callback)
|
||||||
@ -57,28 +74,70 @@ def exportData(database, filename, person=None, callback=None, cl=False):
|
|||||||
ErrorDialog(_("%s could not be opened") % filename)
|
ErrorDialog(_("%s could not be opened") % filename)
|
||||||
return
|
return
|
||||||
|
|
||||||
# copy all data from new_database to database,
|
# copy all data from new_database to database
|
||||||
|
|
||||||
for handle in database.person_map.keys():
|
# Need different adders depending on whether the new db is transactional
|
||||||
new_database.person_map.put(handle,
|
if new_database.UseTXN:
|
||||||
database.person_map.get(handle))
|
add_data = add_data_txn
|
||||||
for handle in database.family_map.keys():
|
else:
|
||||||
new_database.family_map.put(handle,
|
add_data = add_data_notxn
|
||||||
database.family_map.get(handle))
|
|
||||||
for handle in database.place_map.keys():
|
primary_tables = {
|
||||||
new_database.place_map.put(handle,
|
'Person': {'cursor_func': database.get_person_cursor,
|
||||||
database.place_map.get(handle))
|
'new_table': new_database.person_map },
|
||||||
for handle in database.source_map.keys():
|
'Family': {'cursor_func': database.get_family_cursor,
|
||||||
new_database.source_map.put(handle,
|
'new_table': new_database.family_map },
|
||||||
database.source_map.get(handle))
|
'Event': {'cursor_func': database.get_event_cursor,
|
||||||
for handle in database.media_map.keys():
|
'new_table': new_database.event_map },
|
||||||
new_database.media_map.put(handle,
|
'Place': {'cursor_func': database.get_place_cursor,
|
||||||
database.media_map.get(handle))
|
'new_table': new_database.place_map },
|
||||||
for handle in database.event_map.keys():
|
'Source': {'cursor_func': database.get_source_cursor,
|
||||||
new_database.event_map.put(handle,
|
'new_table': new_database.source_map },
|
||||||
database.event_map.get(handle))
|
'MediaObject': {'cursor_func': database.get_media_cursor,
|
||||||
|
'new_table': new_database.media_map },
|
||||||
|
'Repository': {'cursor_func': database.get_repository_cursor,
|
||||||
|
'new_table': new_database.repository_map },
|
||||||
|
}
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
oldval = 0
|
||||||
|
|
||||||
|
for table_name in primary_tables.keys():
|
||||||
|
cursor_func = primary_tables[table_name]['cursor_func']
|
||||||
|
new_table = primary_tables[table_name]['new_table']
|
||||||
|
|
||||||
|
cursor = cursor_func()
|
||||||
|
item = cursor.first()
|
||||||
|
while item:
|
||||||
|
(handle,data) = item
|
||||||
|
add_data(new_database,new_table,handle,data)
|
||||||
|
item = cursor.next()
|
||||||
|
count,oldval = update(callback,count,oldval,total)
|
||||||
|
cursor.close()
|
||||||
|
|
||||||
|
# The metadata is always transactionless,
|
||||||
|
# and the table is small, so using key iteration is OK here.
|
||||||
for handle in database.metadata.keys():
|
for handle in database.metadata.keys():
|
||||||
new_database.metadata.put(handle,
|
new_database.metadata.put(handle,database.metadata.get(handle))
|
||||||
database.metadata.get(handle))
|
|
||||||
|
|
||||||
new_database.close()
|
new_database.close()
|
||||||
|
|
||||||
|
|
||||||
|
def add_data_txn(db,table,handle,data):
|
||||||
|
the_txn = db.env.txn_begin()
|
||||||
|
table.put(handle,data,txn=the_txn)
|
||||||
|
the_txn.commit()
|
||||||
|
|
||||||
|
def add_data_notxn(db,table,handle,data):
|
||||||
|
table.put(handle,data)
|
||||||
|
|
||||||
|
def update_empty(callback,count,oldval,total):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def update_real(callback,count,oldval,total):
|
||||||
|
count += 1
|
||||||
|
newval = int(100.0*count/total)
|
||||||
|
if newval != oldval:
|
||||||
|
callback(newval)
|
||||||
|
oldval = newval
|
||||||
|
return count,oldval
|
||||||
|
@ -905,13 +905,14 @@ def get_media_referents(media_handle,db):
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
_NEW_NAME_PATTERN = '%sUntitled_%d.%s'
|
_NEW_NAME_PATTERN = '%s%sUntitled_%d.%s'
|
||||||
|
|
||||||
def get_new_filename(ext,folder='~/'):
|
def get_new_filename(ext,folder='~/'):
|
||||||
ix = 1
|
ix = 1
|
||||||
while os.path.isfile(os.path.expanduser(_NEW_NAME_PATTERN % (folder,ix,ext) )):
|
while os.path.isfile(os.path.expanduser(_NEW_NAME_PATTERN %
|
||||||
|
(folder,os.path.sep,ix,ext))):
|
||||||
ix = ix + 1
|
ix = ix + 1
|
||||||
return os.path.expanduser(_NEW_NAME_PATTERN % (folder,ix,ext))
|
return os.path.expanduser(_NEW_NAME_PATTERN % (folder,os.path.sep,ix,ext))
|
||||||
|
|
||||||
def get_type_converter(val):
|
def get_type_converter(val):
|
||||||
"""
|
"""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user