* src/GrampsBSDDB.py (rebuild_secondary): properly rebuild

secondary indices relying on BSD DB rather than manually re-adding
every record.
* src/plugins/Rebuild.py (__init__): Use fixed 7 progress steps
for 1 removing step and 6 index rebuilds.


svn: r5870
This commit is contained in:
Alex Roitman 2006-02-03 04:33:14 +00:00
parent f37c2d5ccb
commit c284652cc3
3 changed files with 90 additions and 89 deletions

View File

@ -1,3 +1,10 @@
2006-02-02 Alex Roitman <shura@gramps-project.org>
* src/GrampsBSDDB.py (rebuild_secondary): properly rebuild
secondary indices relying on BSD DB rather than manually re-adding
every record.
* src/plugins/Rebuild.py (__init__): Use fixed 7 progress steps
for 1 removing step and 6 index rebuilds.
2006-01-26 Brian Matherly <pez4brian@users.sourceforge.net>
* src/docgen/ODFDoc.py (init): Correct name for parent style;
Use handling program name obtained from the mime system.

View File

@ -1,7 +1,7 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2000-2005 Donald N. Allingham
# 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
@ -216,96 +216,88 @@ class GrampsBSDDB(GrampsDbBase):
return 1
def rebuild_secondary(self,callback=None):
openflags = db.DB_CREATE
# Repair secondary indices related to person_map
# Repair secondary indices related to person_map
self.id_trans.close()
junk = db.DB(self.env)
junk.remove(self.save_name,"idtrans")
self.surnames.close()
junk = db.DB(self.env)
junk.remove(self.save_name,"surnames")
# Repair secondary indices related to place_map
self.pid_trans.close()
junk = db.DB(self.env)
junk.remove(self.save_name,"pidtrans")
# Repair secondary indices related to media_map
self.oid_trans.close()
junk = db.DB(self.env)
junk.remove(self.save_name,"oidtrans")
# Repair secondary indices related to source_map
self.sid_trans.close()
junk = db.DB(self.env)
junk.remove(self.save_name,"sidtrans")
if callback:
callback()
self.id_trans = db.DB(self.env)
self.id_trans.set_flags(db.DB_DUP)
self.id_trans.open(self.save_name, "idtrans", db.DB_HASH,
flags=db.DB_CREATE)
self.id_trans.truncate()
self.id_trans.open(self.save_name, "idtrans",
db.DB_HASH, flags=openflags)
self.person_map.associate(self.id_trans, find_idmap, openflags)
self.id_trans.sync()
if callback:
callback()
self.surnames = db.DB(self.env)
self.surnames.set_flags(db.DB_DUP)
self.surnames.open(self.save_name, "surnames", db.DB_HASH,
flags=db.DB_CREATE)
self.surnames.truncate()
self.surnames.open(self.save_name, "surnames",
db.DB_HASH, flags=openflags)
self.person_map.associate(self.surnames, find_surname, openflags)
self.surnames.sync()
if callback:
callback()
self.person_map.associate(self.surnames, find_surname, db.DB_CREATE)
self.person_map.associate(self.id_trans, find_idmap, db.DB_CREATE)
for key in self.person_map.keys():
if callback:
callback()
self.person_map[key] = self.person_map[key]
self.person_map.sync()
# Repair secondary indices related to family_map
self.fid_trans.close()
self.fid_trans = db.DB(self.env)
self.fid_trans.set_flags(db.DB_DUP)
self.fid_trans.open(self.save_name, "fidtrans", db.DB_HASH,
flags=db.DB_CREATE)
self.fid_trans.truncate()
self.family_map.associate(self.fid_trans, find_idmap, db.DB_CREATE)
self.fid_trans.open(self.save_name, "fidtrans",
db.DB_HASH, flags=openflags)
self.family_map.associate(self.fid_trans, find_idmap, openflags)
self.fid_trans.sync()
if callback:
callback()
for key in self.family_map.keys():
if callback:
callback()
self.family_map[key] = self.family_map[key]
self.family_map.sync()
# Repair secondary indices related to place_map
self.pid_trans.close()
self.pid_trans = db.DB(self.env)
self.pid_trans.set_flags(db.DB_DUP)
self.pid_trans.open(self.save_name, "pidtrans", db.DB_HASH,
flags=db.DB_CREATE)
self.pid_trans.truncate()
self.place_map.associate(self.pid_trans, find_idmap, db.DB_CREATE)
self.pid_trans.open(self.save_name, "pidtrans",
db.DB_HASH, flags=openflags)
self.place_map.associate(self.pid_trans, find_idmap, openflags)
self.pid_trans.sync()
if callback:
callback()
for key in self.place_map.keys():
if callback:
callback()
self.place_map[key] = self.place_map[key]
self.place_map.sync()
# Repair secondary indices related to media_map
self.oid_trans.close()
self.oid_trans = db.DB(self.env)
self.oid_trans.set_flags(db.DB_DUP)
self.oid_trans.open(self.save_name, "oidtrans", db.DB_HASH,
flags=db.DB_CREATE)
self.oid_trans.truncate()
self.media_map.associate(self.oid_trans, find_idmap, db.DB_CREATE)
for key in self.media_map.keys():
if callback:
callback()
self.media_map[key] = self.media_map[key]
self.media_map.sync()
# Repair secondary indices related to source_map
self.sid_trans.close()
self.sid_trans = db.DB(self.env)
self.sid_trans.set_flags(db.DB_DUP)
self.sid_trans.open(self.save_name, "sidtrans", db.DB_HASH,
flags=db.DB_CREATE)
self.sid_trans.truncate()
self.source_map.associate(self.sid_trans, find_idmap, db.DB_CREATE)
self.sid_trans.open(self.save_name, "sidtrans",
db.DB_HASH, flags=openflags)
self.source_map.associate(self.sid_trans, find_idmap, openflags)
self.sid_trans.sync()
if callback:
callback()
for key in self.source_map.keys():
if callback:
callback()
self.source_map[key] = self.source_map[key]
self.source_map.sync()
self.oid_trans = db.DB(self.env)
self.oid_trans.set_flags(db.DB_DUP)
self.oid_trans.open(self.save_name, "oidtrans",
db.DB_HASH, flags=openflags)
self.media_map.associate(self.oid_trans, find_idmap, openflags)
self.oid_trans.sync()
if callback:
callback()
def abort_changes(self):
while self.undo():
@ -863,7 +855,10 @@ class GrampsBSDDB(GrampsDbBase):
for handle in handle_list:
event = self.get_event_from_handle(handle)
self.individual_event_names.add(event.name)
data = cursor.next()
try:
data = cursor.next()
except:
data = None
cursor.close()
cursor = self.get_family_cursor()
@ -875,7 +870,8 @@ class GrampsBSDDB(GrampsDbBase):
# Check to prevent crash on corrupted data (event_list=None)
for handle in handle_list:
event = self.get_event_from_handle(handle)
self.family_event_names.add(event.name)
if event:
self.family_event_names.add(event.name)
data = cursor.next()
cursor.close()
@ -886,13 +882,14 @@ if __name__ == "__main__":
d = GrampsBSDDB()
d.load(sys.argv[1],lambda x: x)
c = d.get_person_cursor()
data = c.first()
while data:
person = Person(data[1])
print data[0], person.get_primary_name().get_name(),
data = c.next()
c.close()
print d.surnames.keys()
## c = d.get_person_cursor()
## data = c.first()
## while data:
## person = Person(data[1])
## print data[0], person.get_primary_name().get_name(),
## data = c.next()
## c.close()
## print d.surnames.keys()

View File

@ -1,7 +1,7 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2000-2005 Donald N. Allingham
# 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
@ -65,16 +65,13 @@ class Rebuild(Tool.Tool):
# checking of a read only database
return
total = db.get_number_of_people() + \
db.get_number_of_families() + \
db.get_number_of_places() + \
db.get_number_of_sources() + \
db.get_number_of_media_objects()
db.disable_signals()
if parent:
progress = Utils.ProgressMeter(
_('Rebuilding Secondary Indices'))
# Six indices to rebuild, and the first step is removing
# old ones
total = 7
progress.set_pass('',total)
db.rebuild_secondary(progress.step)
progress.close()