Commit 1146656d authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 9d00163b
...@@ -202,7 +202,7 @@ class tDB: ...@@ -202,7 +202,7 @@ class tDB:
tf.close() tf.close()
for tw in t._wlinks.copy(): for tw in t._wlinks.copy():
tw.close() tw.close()
assert len(t._files) == 0 assert len(t._files) == 0
assert len(t._wlinks) == 0 assert len(t._wlinks) == 0
t._wc_zheadfh.close() t._wc_zheadfh.close()
t.wc.close() t.wc.close()
...@@ -220,7 +220,7 @@ class tDB: ...@@ -220,7 +220,7 @@ class tDB:
# change schedules zf to be changed according changeDelta at commit. # change schedules zf to be changed according changeDelta at commit.
# #
# changeDelta is {} blk -> data. # changeDelta: {} blk -> data.
# data can be both bytes and unicode. # data can be both bytes and unicode.
def change(t, zf, changeDelta): def change(t, zf, changeDelta):
assert isinstance(zf, ZBigFile) assert isinstance(zf, ZBigFile)
...@@ -233,7 +233,7 @@ class tDB: ...@@ -233,7 +233,7 @@ class tDB:
# commit commits transaction and makes sure wcfs is synchronized to it. # commit commits transaction and makes sure wcfs is synchronized to it.
# #
# It remembers/returns committed transaction ID. # It updates .dFtail and returns committed transaction ID.
def commit(t): def commit(t):
# perform modifications scheduled by change. # perform modifications scheduled by change.
# use !wcfs mode so that we prepare data independently of wcfs code paths. # use !wcfs mode so that we prepare data independently of wcfs code paths.
...@@ -248,11 +248,10 @@ class tDB: ...@@ -248,11 +248,10 @@ class tDB:
memcpy(vma, data) memcpy(vma, data)
dF.byfile[zf] = dfile dF.byfile[zf] = dfile
# NOTE there is no clean way to retrieve tid of just committed transaction # perform the commit. NOTE there is no clean way to retrieve tid of
# we use last._p_serial as workaround. # just committed transaction - we use last._p_serial as workaround.
t.root['_last'] = last = Persistent() t.root['_last'] = last = Persistent()
last._p_changed = 1 last._p_changed = 1
transaction.commit() transaction.commit()
head = last._p_serial head = last._p_serial
...@@ -260,15 +259,15 @@ class tDB: ...@@ -260,15 +259,15 @@ class tDB:
for dfile in dF.byfile.values(): for dfile in dF.byfile.values():
dfile.rev = head dfile.rev = head
t.dFtail.append(dF) t.dFtail.append(dF)
assert t.head == head # self-check
print('\nM: commit -> %s' % t.hat(head)) print('\nM: commit -> %s' % t.hat(head))
for zf, zfDelta in t._changed.items(): for zf, zfDelta in t._changed.items():
print('M: f<%s>\t%s' % (h(zf._p_oid), sorted(zfDelta.keys()))) print('M: f<%s>\t%s' % (h(zf._p_oid), sorted(zfDelta.keys())))
t._changed = {} t._changed = {}
# synchronize wcfs to db # synchronize wcfs to db, and we are done
t._wcsync() t._wcsync()
return head return head
# _blkaccess marks head/zf[blk] accessed. # _blkaccess marks head/zf[blk] accessed.
...@@ -1140,7 +1139,7 @@ def test_wcfs(): ...@@ -1140,7 +1139,7 @@ def test_wcfs():
t.root['!file'] = nonfile = Persistent() t.root['!file'] = nonfile = Persistent()
t.root['zfile'] = zf = ZBigFile(blksize) t.root['zfile'] = zf = ZBigFile(blksize)
at0 = t.commit() at0 = t.commit()
# >>> lookup non-BigFile -> must be rejected # >>> lookup non-BigFile -> must be rejected
with raises(OSError) as exc: with raises(OSError) as exc:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment