2006-08-15 Alex Roitman <shura@gramps-project.org>
* src/GrampsDb/_GrampsBSDDB.py: Cleanup on upgrades. svn: r7181
This commit is contained in:
parent
45d0d40c2b
commit
bd18b2f976
@ -1,3 +1,6 @@
|
|||||||
|
2006-08-15 Alex Roitman <shura@gramps-project.org>
|
||||||
|
* src/GrampsDb/_GrampsBSDDB.py: Cleanup on upgrades.
|
||||||
|
|
||||||
2006-08-14 Alex Roitman <shura@gramps-project.org>
|
2006-08-14 Alex Roitman <shura@gramps-project.org>
|
||||||
* src/GrampsDb/_GrampsBSDDB.py (gramps_upgrade_10): Add an upgrade
|
* src/GrampsDb/_GrampsBSDDB.py (gramps_upgrade_10): Add an upgrade
|
||||||
path from 2.1.91.
|
path from 2.1.91.
|
||||||
|
@ -1403,7 +1403,7 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
self.gramps_upgrade_8()
|
self.gramps_upgrade_8()
|
||||||
if version < 9:
|
if version < 9:
|
||||||
self.gramps_upgrade_9()
|
self.gramps_upgrade_9()
|
||||||
if version < 10:
|
elif version < 10:
|
||||||
self.gramps_upgrade_10()
|
self.gramps_upgrade_10()
|
||||||
print "Upgrade time:", int(time.time()-t), "seconds"
|
print "Upgrade time:", int(time.time()-t), "seconds"
|
||||||
|
|
||||||
@ -1487,11 +1487,12 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
self.metadata.sync()
|
self.metadata.sync()
|
||||||
|
|
||||||
def gramps_upgrade_9(self):
|
def gramps_upgrade_9(self):
|
||||||
print "Upgrading to DB version 9 -- this may take a while"
|
print "Upgrading to DB version 10 -- this may take a while"
|
||||||
# The very very first thing is to check for duplicates in the
|
# The very very first thing is to check for duplicates in the
|
||||||
# primary tables and remove them.
|
# primary tables and remove them.
|
||||||
self.set_total(7)
|
self.set_total(7)
|
||||||
status,length = low_level_9(self,self.update)
|
status,length = low_level_9(self,self.update)
|
||||||
|
self.reset()
|
||||||
|
|
||||||
self.set_total(length)
|
self.set_total(length)
|
||||||
|
|
||||||
@ -1760,10 +1761,13 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
event = Event()
|
event = Event()
|
||||||
event.handle = handle
|
event.handle = handle
|
||||||
(junk_handle, event.gramps_id, old_type, event.date,
|
(junk_handle, event.gramps_id, old_type, event.date,
|
||||||
event.description, event.place, event.cause, event.private,
|
event.description, event.place, cause, event.private,
|
||||||
event.source_list, event.note, witness_list,
|
event.source_list, event.note, witness_list,
|
||||||
event.media_list, event.change) = info
|
event.media_list, event.change) = info
|
||||||
|
|
||||||
|
if event.source_list != []:
|
||||||
|
print [sr.serialize() for sr in event.source_list]
|
||||||
|
|
||||||
# Change ID if it is non-unique
|
# Change ID if it is non-unique
|
||||||
if event.gramps_id in dup_ids:
|
if event.gramps_id in dup_ids:
|
||||||
max_id_number += 1
|
max_id_number += 1
|
||||||
@ -1810,6 +1814,13 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
"while upgrading database to version 9.")
|
"while upgrading database to version 9.")
|
||||||
event.set_note(note_text)
|
event.set_note(note_text)
|
||||||
|
|
||||||
|
# This is an upgrade_10 step
|
||||||
|
if cause.strip():
|
||||||
|
attr = Attribute()
|
||||||
|
attr.set_type(AttributeType.CAUSE)
|
||||||
|
attr.set_value(cause)
|
||||||
|
event.add_attribute(attr)
|
||||||
|
|
||||||
self.commit_event(event,trans)
|
self.commit_event(event,trans)
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
@ -1859,13 +1870,13 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
the_txn = self.env.txn_begin()
|
the_txn = self.env.txn_begin()
|
||||||
else:
|
else:
|
||||||
the_txn = None
|
the_txn = None
|
||||||
self.metadata.put('version',9,txn=the_txn)
|
self.metadata.put('version',10,txn=the_txn)
|
||||||
if self.UseTXN:
|
if self.UseTXN:
|
||||||
the_txn.commit()
|
the_txn.commit()
|
||||||
else:
|
else:
|
||||||
self.metadata.sync()
|
self.metadata.sync()
|
||||||
|
|
||||||
print "Done upgrading to DB version 9"
|
print "Done upgrading to DB version 10"
|
||||||
|
|
||||||
def gramps_upgrade_10(self):
|
def gramps_upgrade_10(self):
|
||||||
print "Upgrading to DB version 10 -- this may take a while"
|
print "Upgrading to DB version 10 -- this may take a while"
|
||||||
@ -1885,37 +1896,26 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
# so starting (batch) transaction here.
|
# so starting (batch) transaction here.
|
||||||
trans = self.transaction_begin("",True)
|
trans = self.transaction_begin("",True)
|
||||||
|
|
||||||
# Import secondary modules from RelLib
|
|
||||||
from RelLib._DateBase import DateBase
|
|
||||||
from RelLib._MediaBase import MediaBase
|
|
||||||
from RelLib._SourceBase import SourceBase
|
|
||||||
from RelLib._NoteBase import NoteBase
|
|
||||||
from RelLib._LdsOrdBase import LdsOrdBase
|
|
||||||
from RelLib._AddressBase import AddressBase
|
|
||||||
from RelLib._AttributeBase import AttributeBase
|
|
||||||
from RelLib._UrlBase import UrlBase
|
|
||||||
from RelLib._PrivacyBase import PrivacyBase
|
|
||||||
from RelLib._RefBase import RefBase
|
|
||||||
|
|
||||||
# This upgrade adds attribute lists to Event and EventRef objects
|
# This upgrade adds attribute lists to Event and EventRef objects
|
||||||
self.set_total(self.get_number_of_events())
|
length = self.get_number_of_events() + len(self.person_map) \
|
||||||
|
+ self.get_number_of_families()
|
||||||
|
self.set_total(length)
|
||||||
|
|
||||||
for handle in self.event_map.keys():
|
for handle in self.event_map.keys():
|
||||||
info = self.event_map[handle]
|
info = self.event_map[handle]
|
||||||
|
|
||||||
|
(junk_handle, gramps_id, the_type, date,description,
|
||||||
|
place, cause,source_list, note, media_list,
|
||||||
|
change, marker, private) = info
|
||||||
|
|
||||||
|
new_info = (handle, gramps_id, the_type, date,
|
||||||
|
description, place, source_list, note, media_list,
|
||||||
|
[], change, marker, private)
|
||||||
|
|
||||||
event = Event()
|
event = Event()
|
||||||
event.handle = handle
|
event.unserialize(new_info)
|
||||||
(junk_handle, event.gramps_id, the_type, date,
|
|
||||||
event.description, event.place, cause,
|
|
||||||
source_list, note, media_list,
|
|
||||||
event.change, marker, event.private) = info
|
|
||||||
|
|
||||||
event.marker.unserialize(marker)
|
|
||||||
event.type.unserialize(the_type)
|
|
||||||
DateBase.unserialize(event,date)
|
|
||||||
MediaBase.unserialize(event,media_list)
|
|
||||||
SourceBase.unserialize(event,source_list)
|
|
||||||
NoteBase.unserialize(event,note)
|
|
||||||
|
|
||||||
|
# Cause is removed, so we're converting it into an attribute
|
||||||
if cause.strip():
|
if cause.strip():
|
||||||
attr = Attribute()
|
attr = Attribute()
|
||||||
attr.set_type(AttributeType.CAUSE)
|
attr.set_type(AttributeType.CAUSE)
|
||||||
@ -1924,75 +1924,57 @@ class GrampsBSDDB(GrampsDbBase,UpdateCallback):
|
|||||||
|
|
||||||
self.commit_event(event,trans)
|
self.commit_event(event,trans)
|
||||||
self.update()
|
self.update()
|
||||||
self.reset()
|
|
||||||
|
|
||||||
# Personal event references
|
# Personal event references
|
||||||
self.set_total(len(self.person_map))
|
|
||||||
for handle in self.person_map.keys():
|
for handle in self.person_map.keys():
|
||||||
info = self.person_map[handle]
|
info = self.person_map[handle]
|
||||||
person = Person()
|
|
||||||
person.handle = handle
|
|
||||||
(junk_handle,person.gramps_id,person.gender,
|
|
||||||
primary_name,alternate_names,person.death_ref_index,
|
|
||||||
person.birth_ref_index,event_ref_list,person.family_list,
|
|
||||||
person.parent_family_list,media_list,address_list,attribute_list,
|
|
||||||
urls,lds_ord_list,source_list,note,person.change,marker,
|
|
||||||
person.private,person_ref_list,) = info
|
|
||||||
|
|
||||||
person.marker.unserialize(marker)
|
(junk_handle,gramps_id,gender,
|
||||||
person.primary_name.unserialize(primary_name)
|
primary_name,alternate_names,death_ref_index,
|
||||||
person.alternate_names = [Name().unserialize(name)
|
birth_ref_index,event_ref_list,family_list,
|
||||||
for name in alternate_names]
|
parent_family_list,media_list,address_list,attribute_list,
|
||||||
person.person_ref_list = [PersonRef().unserialize(pr)
|
urls,lds_ord_list,source_list,note,change,marker,
|
||||||
for pr in person_ref_list]
|
private,person_ref_list,) = info
|
||||||
MediaBase.unserialize(person, media_list)
|
|
||||||
LdsOrdBase.unserialize(person, lds_ord_list)
|
new_info = (handle,gramps_id,gender,primary_name,alternate_names,
|
||||||
AddressBase.unserialize(person, address_list)
|
death_ref_index,birth_ref_index,[],
|
||||||
AttributeBase.unserialize(person, attribute_list)
|
family_list,parent_family_list,media_list,address_list,
|
||||||
UrlBase.unserialize(person, urls)
|
attribute_list,urls,lds_ord_list,source_list,note,
|
||||||
SourceBase.unserialize(person, source_list)
|
change,marker,private,person_ref_list,)
|
||||||
NoteBase.unserialize(person, note)
|
|
||||||
|
person = Person()
|
||||||
|
person.unserialize(new_info)
|
||||||
|
|
||||||
for (privacy,note,ref,role) in event_ref_list:
|
for (privacy,note,ref,role) in event_ref_list:
|
||||||
event_ref = EventRef()
|
event_ref = EventRef()
|
||||||
PrivacyBase.unserialize(event_ref,privacy)
|
new_event_ref_data = (privacy,note,[],ref,role)
|
||||||
NoteBase.unserialize(event_ref,note)
|
event_ref.unserialize(new_event_ref_data)
|
||||||
RefBase.unserialize(event_ref,ref)
|
|
||||||
event_ref.role.unserialize(role)
|
|
||||||
person.add_event_ref(event_ref)
|
person.add_event_ref(event_ref)
|
||||||
|
|
||||||
self.commit_person(person,trans)
|
self.commit_person(person,trans)
|
||||||
self.update()
|
self.update()
|
||||||
self.reset()
|
|
||||||
|
|
||||||
# Family event references
|
# Family event references
|
||||||
self.set_total(self.get_number_of_families())
|
|
||||||
for handle in self.family_map.keys():
|
for handle in self.family_map.keys():
|
||||||
info = self.family_map[handle]
|
info = self.family_map[handle]
|
||||||
family = Family()
|
|
||||||
family.handle = handle
|
|
||||||
|
|
||||||
(junk_handle,family.gramps_id,family.father_handle,
|
(junk_handle,gramps_id,father_handle,
|
||||||
family.mother_handle,child_ref_list,the_type,event_ref_list,
|
mother_handle,child_ref_list,the_type,event_ref_list,
|
||||||
media_list,attribute_list,lds_seal_list,source_list,note,
|
media_list,attribute_list,lds_seal_list,source_list,note,
|
||||||
family.change, marker, family.private) = info
|
change, marker, private) = info
|
||||||
|
|
||||||
family.marker.unserialize(marker)
|
new_info = (handle,gramps_id,father_handle,
|
||||||
family.type.unserialize(the_type)
|
mother_handle,child_ref_list,the_type,[],
|
||||||
family.child_ref_list = [ChildRef().unserialize(cr)
|
media_list,attribute_list,lds_seal_list,
|
||||||
for cr in child_ref_list]
|
source_list,note,change, marker, private)
|
||||||
MediaBase.unserialize(family,media_list)
|
|
||||||
AttributeBase.unserialize(family,attribute_list)
|
|
||||||
SourceBase.unserialize(family,source_list)
|
|
||||||
NoteBase.unserialize(family,note)
|
|
||||||
LdsOrdBase.unserialize(family,lds_seal_list)
|
|
||||||
|
|
||||||
for (privacy,note,ref,role) in event_ref_list:
|
family = Family()
|
||||||
|
family.unserialize(new_info)
|
||||||
|
|
||||||
|
for (privacy,note,ref,role) in event_ref_list:
|
||||||
event_ref = EventRef()
|
event_ref = EventRef()
|
||||||
PrivacyBase.unserialize(event_ref,privacy)
|
new_event_ref_data = (privacy,note,[],ref,role)
|
||||||
NoteBase.unserialize(event_ref,note)
|
event_ref.unserialize(new_event_ref_data)
|
||||||
RefBase.unserialize(event_ref,ref)
|
|
||||||
event_ref.role.unserialize(role)
|
|
||||||
family.add_event_ref(event_ref)
|
family.add_event_ref(event_ref)
|
||||||
|
|
||||||
self.commit_family(family,trans)
|
self.commit_family(family,trans)
|
||||||
|
Loading…
Reference in New Issue
Block a user