Commit 61500616 authored by Kirill Smelkov's avatar Kirill Smelkov

X Notes on loadBefore returning serial_next & None

parent 22df1fd1
...@@ -225,6 +225,14 @@ class DemoStorage(ConflictResolvingStorage): ...@@ -225,6 +225,14 @@ class DemoStorage(ConflictResolvingStorage):
return self.base.loadBefore(oid, tid) return self.base.loadBefore(oid, tid)
if result is None: if result is None:
# FIXME wrong: oid could be *deleted* in changes - in this case we
# must not look into base. Fix is: result = (data, serial)
#
# data = None if oid exists but there is no data (created later or deleted)
# serial = 0 (if created later) or serial of delete transaction.
#
# -> then look at serial and decide whether to go to base.
# The oid *was* in the changes, but there aren't any # The oid *was* in the changes, but there aren't any
# earlier records. Maybe there are in the base. # earlier records. Maybe there are in the base.
try: try:
...@@ -233,6 +241,7 @@ class DemoStorage(ConflictResolvingStorage): ...@@ -233,6 +241,7 @@ class DemoStorage(ConflictResolvingStorage):
# The oid isn't in the base, so None will be the right result # The oid isn't in the base, so None will be the right result
pass pass
else: else:
# XXX vvv simply not needed if we don't need to return end_tid
if result and not result[-1]: if result and not result[-1]:
# The oid is current in the base. We need to find # The oid is current in the base. We need to find
# the end tid in the base by fining the first tid # the end tid in the base by fining the first tid
......
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