Bug 3018: ImportGrdb: remove calls to keys() dictionary method where possible

svn: r12563
This commit is contained in:
Gerald Britton 2009-05-22 19:27:46 +00:00
parent fc90d5fce2
commit c5c0ce7bfb

View File

@ -1050,14 +1050,14 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Now we use the functions and classes defined above # Now we use the functions and classes defined above
# to loop through each of the primary object tables. # to loop through each of the primary object tables.
for primary_table_name in primary_tables.keys(): for primary_table_name, primary_table_dict in primary_tables.iteritems():
cursor = primary_tables[primary_table_name]['cursor_func']() cursor = primary_table_dict['cursor_func']()
data = cursor.first() data = cursor.first()
# Grab the real object class here so that the lookup does # Grab the real object class here so that the lookup does
# not happen inside the cursor loop. # not happen inside the cursor loop.
class_func = primary_tables[primary_table_name]['class_func'] class_func = primary_table_dict['class_func']
while data: while data:
found_handle, val = data found_handle, val = data
obj = class_func() obj = class_func()
@ -1331,6 +1331,7 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
The function must be overridden in the derived class. The function must be overridden in the derived class.
""" """
name = str(person.get_primary_name().get_surname()) name = str(person.get_primary_name().get_surname())
print type(surnames)
try: try:
if self.surnames.keys().count(name) == 1: if self.surnames.keys().count(name) == 1:
self.surname_list.remove(unicode(name)) self.surname_list.remove(unicode(name))
@ -1670,9 +1671,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
+ self.get_number_of_families() + self.get_number_of_families()
self.set_total(length) self.set_total(length)
for handle in self.event_map.keys(): for handle, info in self.event_map.iteritems():
info = self.event_map[handle]
(junk_handle, gramps_id, the_type, date, description, (junk_handle, gramps_id, the_type, date, description,
place, cause, source_list, note, media_list, place, cause, source_list, note, media_list,
change, marker, private) = info change, marker, private) = info
@ -1703,9 +1703,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.event_map.sync() self.event_map.sync()
# Personal event references # Personal event references
for handle in self.person_map.keys(): for handle, info in self.person_map.iteritems():
info = self.person_map[handle]
(junk_handle, gramps_id, gender, (junk_handle, gramps_id, gender,
primary_name, alternate_names, death_ref_index, primary_name, alternate_names, death_ref_index,
birth_ref_index, event_ref_list, family_list, birth_ref_index, event_ref_list, family_list,
@ -1743,8 +1742,7 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.person_map.sync() self.person_map.sync()
# Family event references # Family event references
for handle in self.family_map.keys(): for handle, info in self.family_map.iteritems():
info = self.family_map[handle]
(junk_handle, gramps_id, father_handle, (junk_handle, gramps_id, father_handle,
mother_handle, child_ref_list, the_type, event_ref_list, mother_handle, child_ref_list, the_type, event_ref_list,
@ -1796,9 +1794,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.set_total(length) self.set_total(length)
# Personal addresses # Personal addresses
for handle in self.person_map.keys(): for handle, info in self.person_map.iteritems():
info = self.person_map[handle]
(junk_handle, gramps_id, gender, (junk_handle, gramps_id, gender,
primary_name, alternate_names, death_ref_index, primary_name, alternate_names, death_ref_index,
birth_ref_index, event_ref_list, family_list, birth_ref_index, event_ref_list, family_list,
@ -1830,8 +1827,7 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.person_map.sync() self.person_map.sync()
# Repositories # Repositories
for handle in self.repository_map.keys(): for handle, info in self.repository_map.iteritems():
info = self.repository_map[handle]
(junk_handle, gramps_id, the_type, name, note, (junk_handle, gramps_id, the_type, name, note,
address_list, urls, marker, private) = info address_list, urls, marker, private) = info
@ -1855,8 +1851,7 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.repository_map.sync() self.repository_map.sync()
# Places # Places
for handle in self.place_map.keys(): for handle, info in self.place_map.iteritems():
info = self.place_map[handle]
(junk_handle, gramps_id, title, long, lat, main_loc, alt_loc, urls, (junk_handle, gramps_id, title, long, lat, main_loc, alt_loc, urls,
media_list, source_list, note, change, marker, private) = info media_list, source_list, note, change, marker, private) = info
@ -1949,50 +1944,50 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
self.change_13 = int(time.time()) self.change_13 = int(time.time())
# Person upgrade # Person upgrade
for handle in self.person_map.keys(): for handle, info in self.person_map.iteritems():
info = self.person_map[handle]
(new_info, note_handles) = self.convert_notes_13('Person', info) (new_info, note_handles) = self.convert_notes_13('Person', info)
self.commit_13(new_info, PERSON_KEY, self.person_map, note_handles) self.commit_13(new_info, PERSON_KEY, self.person_map, note_handles)
self.update() self.update()
# Family upgrade # Family upgrade
for handle in self.family_map.keys(): for handle, info in self.family_map.iteritems():
info = self.family_map[handle]
(new_info, note_handles) = self.convert_notes_13('Family', info) (new_info, note_handles) = self.convert_notes_13('Family', info)
self.commit_13(new_info, FAMILY_KEY, self.family_map, note_handles) self.commit_13(new_info, FAMILY_KEY, self.family_map, note_handles)
self.update() self.update()
# Event upgrade # Event upgrade
for handle in self.event_map.keys(): for handle, info in self.event_map.iteritems():
info = self.event_map[handle]
(new_info, note_handles) = self.convert_notes_13('Event', info) (new_info, note_handles) = self.convert_notes_13('Event', info)
self.commit_13(new_info, EVENT_KEY, self.event_map, note_handles) self.commit_13(new_info, EVENT_KEY, self.event_map, note_handles)
self.update() self.update()
# Source upgrade # Source upgrade
for handle in self.source_map.keys(): for handle, info in self.source_map.iteritems():
info = self.source_map[handle]
(new_info, note_handles) = self.convert_notes_13('Source', info) (new_info, note_handles) = self.convert_notes_13('Source', info)
self.commit_13(new_info, SOURCE_KEY, self.source_map, note_handles) self.commit_13(new_info, SOURCE_KEY, self.source_map, note_handles)
self.update() self.update()
# Place upgrade # Place upgrade
for handle in self.place_map.keys(): for handle, info in self.place_map.iteritems():
info = self.place_map[handle]
(new_info, note_handles) = self.convert_notes_13('Place', info) (new_info, note_handles) = self.convert_notes_13('Place', info)
self.commit_13(new_info, PLACE_KEY, self.place_map, note_handles) self.commit_13(new_info, PLACE_KEY, self.place_map, note_handles)
self.update() self.update()
# Media upgrade # Media upgrade
for handle in self.media_map.keys(): for handle, info in self.media_map.iteritems():
info = self.media_map[handle]
(new_info, note_handles) = self.convert_notes_13('MediaObject', info) (new_info, note_handles) = self.convert_notes_13('MediaObject', info)
self.commit_13(new_info, MEDIA_KEY, self.media_map, note_handles) self.commit_13(new_info, MEDIA_KEY, self.media_map, note_handles)
self.update() self.update()
# Repo upgrade # Repo upgrade
for handle in self.repository_map.keys(): for handle, info in self.repository_map.iteritems():
info = self.repository_map[handle]
(new_info, note_handles) = self.convert_notes_13('Repository', info) (new_info, note_handles) = self.convert_notes_13('Repository', info)
self.commit_13(new_info, REPOSITORY_KEY, self.commit_13(new_info, REPOSITORY_KEY,
self.repository_map, note_handles) self.repository_map, note_handles)
@ -2404,8 +2399,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Modify Notes # Modify Notes
# --------------------------------- # ---------------------------------
# replace clear text with StyledText in Notes # replace clear text with StyledText in Notes
for handle in self.note_map.keys(): for handle, note in self.note_map.iteritems():
note = self.note_map[handle]
(junk_handle, gramps_id, text, format, note_type, (junk_handle, gramps_id, text, format, note_type,
change, marker, private) = note change, marker, private) = note
styled_text = (text, []) styled_text = (text, [])
@ -2420,8 +2415,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Modify Event # Modify Event
# --------------------------------- # ---------------------------------
# update dates with newyear # update dates with newyear
for handle in self.event_map.keys(): for handle, event in self.event_map.iteritems():
event = self.event_map[handle]
(junk_handle, gramps_id, the_type, date, description, place, (junk_handle, gramps_id, the_type, date, description, place,
source_list, note_list, media_list, attribute_list, source_list, note_list, media_list, attribute_list,
change, marker, private) = event change, marker, private) = event
@ -2441,8 +2436,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Modify Person # Modify Person
# --------------------------------- # ---------------------------------
# update dates with newyear # update dates with newyear
for handle in self.person_map.keys(): for handle, person in self.person_map.iteritems():
person = self.person_map[handle]
(junk_handle, # 0 (junk_handle, # 0
gramps_id, # 1 gramps_id, # 1
gender, # 2 gender, # 2
@ -2523,8 +2518,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Modify Family # Modify Family
# --------------------------------- # ---------------------------------
# update dates with newyear # update dates with newyear
for handle in self.family_map.keys(): for handle, family in self.family_map.iteritems():
family = self.family_map[handle]
(junk_handle, gramps_id, father_handle, mother_handle, (junk_handle, gramps_id, father_handle, mother_handle,
child_ref_list, the_type, event_ref_list, media_list, child_ref_list, the_type, event_ref_list, media_list,
attribute_list, lds_seal_list, source_list, note_list, attribute_list, lds_seal_list, source_list, note_list,
@ -2554,8 +2549,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# Modify Repository # Modify Repository
# --------------------------------- # ---------------------------------
# update dates with newyear # update dates with newyear
for handle in self.repository_map.keys(): for handle, repository in self.repository_map.iteritems():
repository = self.repository_map[handle]
# address # address
(junk_handle, gramps_id, the_type, name, note_list, (junk_handle, gramps_id, the_type, name, note_list,
address_list, urls, change, marker, private) = repository address_list, urls, change, marker, private) = repository
@ -2579,8 +2574,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# --------------------------------- # ---------------------------------
# Modify Media # Modify Media
# --------------------------------- # ---------------------------------
for media_handle in self.media_map.keys(): for media_handle, media in self.media_map.iteritems():
media = self.media_map[media_handle]
(handle, gramps_id, path, mime, desc, (handle, gramps_id, path, mime, desc,
attribute_list, source_list, note_list, change, attribute_list, source_list, note_list, change,
date, marker, private) = media date, marker, private) = media
@ -2598,8 +2593,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# --------------------------------- # ---------------------------------
# Modify Place # Modify Place
# --------------------------------- # ---------------------------------
for place_handle in self.place_map.keys(): for place_handle, place in self.place_map.iteritems():
place = self.place_map[place_handle]
(handle, gramps_id, title, long, lat, (handle, gramps_id, title, long, lat,
main_loc, alt_loc, urls, media_list, source_list, note_list, main_loc, alt_loc, urls, media_list, source_list, note_list,
change, marker, private) = place change, marker, private) = place
@ -2617,8 +2612,8 @@ class GrampsBSDDB(GrampsDbBase, UpdateCallback):
# --------------------------------- # ---------------------------------
# Modify Source # Modify Source
# --------------------------------- # ---------------------------------
for source_handle in self.source_map.keys(): for source_handle, source in self.source_map.iteritems():
source = self.source_map[source_handle]
(handle, gramps_id, title, author, (handle, gramps_id, title, author,
pubinfo, note_list, media_list, pubinfo, note_list, media_list,
abbrev, change, datamap, reporef_list, abbrev, change, datamap, reporef_list,
@ -2871,13 +2866,13 @@ def importData(database, filename, callback=None, cl=0):
} }
uc = UpdateCallback(callback) uc = UpdateCallback(callback)
uc.set_total(len(tables.keys())) uc.set_total(len(tables))
the_len = 0 the_len = 0
# Check for duplicate handles. # Check for duplicate handles.
for key in tables: for key, table_dict in tables.iteritems():
table_dict = tables[key]
table = table_dict['table'] table = table_dict['table']
other_table = table_dict['other_table'] other_table = table_dict['other_table']
msg = '%s handles in two databases overlap.' % key msg = '%s handles in two databases overlap.' % key
@ -2954,7 +2949,7 @@ def check_common_handles(table, other_table, msg):
def import_table(id_table, add_obj, find_next_gramps_id, def import_table(id_table, add_obj, find_next_gramps_id,
other_table, other_get_from_handle, trans, uc): other_table, other_get_from_handle, trans, uc):
for handle in other_table.keys(): for handle in other_table:
obj = other_get_from_handle(handle) obj = other_get_from_handle(handle)
# Then we check gramps_id for conflicts and change it if needed # Then we check gramps_id for conflicts and change it if needed