(GrampsBSDDB._delete_primary_from_reference_map): Accept txn
argument; pass it on to self._remove_reference(). * src/GrampsDb/_GrampsBSDDB.py (GrampsBSDDB._do_remove_object): Work out both regular and batch transactions. svn: r6296
This commit is contained in:
parent
3360368431
commit
1ca64386fb
@ -1,4 +1,9 @@
|
||||
2006-04-09 Alex Roitman <shura@gramps-project.org>
|
||||
(GrampsBSDDB._delete_primary_from_reference_map): Accept txn
|
||||
argument; pass it on to self._remove_reference().
|
||||
* src/GrampsDb/_GrampsBSDDB.py (GrampsBSDDB._do_remove_object):
|
||||
Work out both regular and batch transactions.
|
||||
|
||||
* src/Makefile.am: Clean byte-compiled files.
|
||||
* src/DataViews/Makefile.am: Clean byte-compiled files.
|
||||
* src/GrampsDb/Makefile.am: Clean byte-compiled files.
|
||||
|
@ -587,7 +587,7 @@ class GrampsBSDDB(GrampsDbBase):
|
||||
|
||||
return
|
||||
|
||||
def _delete_primary_from_reference_map(self, handle, transaction):
|
||||
def _delete_primary_from_reference_map(self,handle,transaction,txn=None):
|
||||
"""Remove all references to the primary object from the reference_map"""
|
||||
|
||||
primary_cur = self.get_reference_map_primary_cursor()
|
||||
@ -609,7 +609,7 @@ class GrampsBSDDB(GrampsDbBase):
|
||||
|
||||
main_key = (handle, cPickle.loads(data)[1][1])
|
||||
|
||||
self._remove_reference(main_key,transaction)
|
||||
self._remove_reference(main_key,transaction,txn)
|
||||
|
||||
ret = primary_cur.next_dup()
|
||||
|
||||
@ -855,13 +855,27 @@ class GrampsBSDDB(GrampsDbBase):
|
||||
self.metadata = None
|
||||
self.db_is_open = False
|
||||
|
||||
def _do_remove_object(self,handle,trans,dmap,key,del_list):
|
||||
self._delete_primary_from_reference_map(handle,trans)
|
||||
if not self.readonly:
|
||||
handle = str(handle)
|
||||
if not trans.batch:
|
||||
old_data = dmap.get(handle,txn=self.txn)
|
||||
trans.add(key,handle,old_data,None)
|
||||
def _do_remove_object(self,handle,transaction,data_map,key,del_list):
|
||||
if self.readonly or not handle:
|
||||
return
|
||||
|
||||
handle = str(handle)
|
||||
if transaction.batch:
|
||||
if self.UseTXN:
|
||||
the_txn = self.env.txn_begin()
|
||||
else:
|
||||
the_txn = None
|
||||
self._delete_primary_from_reference_map(handle,transaction,
|
||||
txn=the_txn)
|
||||
data_map.delete(handle,txn=the_txn)
|
||||
if not self.UseTXN:
|
||||
data_map.sync()
|
||||
if the_txn:
|
||||
the_txn.commit()
|
||||
else:
|
||||
self._delete_primary_from_reference_map(handle,transaction)
|
||||
old_data = data_map.get(handle,txn=self.txn)
|
||||
transaction.add(key,handle,old_data,None)
|
||||
del_list.append(handle)
|
||||
|
||||
def _del_person(self,handle):
|
||||
|
Loading…
x
Reference in New Issue
Block a user