fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fixing regression
[redakcja.git]
/
apps
/
dvcs
/
models.py
diff --git
a/apps/dvcs/models.py
b/apps/dvcs/models.py
index
3991efc
..
f4cb519
100644
(file)
--- a/
apps/dvcs/models.py
+++ b/
apps/dvcs/models.py
@@
-45,7
+45,7
@@
class Tag(models.Model):
def listener_changed(sender, instance, **kwargs):
sender._object_cache = {}
def listener_changed(sender, instance, **kwargs):
sender._object_cache = {}
- def next(self):
+ def
get_
next(self):
"""
Returns the next tag - stage to work on.
Returns None for the last stage.
"""
Returns the next tag - stage to work on.
Returns None for the last stage.
@@
-280,7
+280,7
@@
class Document(models.Model):
tags = kwargs.get('tags', [])
if tags:
# set stage to next tag after the commited one
tags = kwargs.get('tags', [])
if tags:
# set stage to next tag after the commited one
- self.stage = max(tags, key=lambda t: t.ordering).next()
+ self.stage = max(tags, key=lambda t: t.ordering).
get_
next()
change = self.change_set.create(author=author,
author_name=author_name,
change = self.change_set.create(author=author,
author_name=author_name,
@@
-307,7
+307,7
@@
class Document(models.Model):
return self.head
def history(self):
return self.head
def history(self):
- return self.change_set.
filter(revision__gt=-1
)
+ return self.change_set.
all().order_by('revision'
)
def revision(self):
rev = self.change_set.aggregate(
def revision(self):
rev = self.change_set.aggregate(
@@
-319,9
+319,9
@@
class Document(models.Model):
return self.change_set.get(revision=rev)
def publishable(self):
return self.change_set.get(revision=rev)
def publishable(self):
- changes = self.
change_set
.filter(publishable=True)
+ changes = self.
history()
.filter(publishable=True)
if changes.exists():
if changes.exists():
- return changes.order_by('-
created_at
')[0]
+ return changes.order_by('-
revision
')[0]
else:
return None
else:
return None
@@
-331,7
+331,9
@@
class Document(models.Model):
assert self != other
other_revs = other.change_set.all().count()
assert self != other
other_revs = other.change_set.all().count()
- self.change_set.all().update(revision=models.F('revision') + other_revs)
+ # workaround for a non-atomic UPDATE in SQLITE
+ self.change_set.all().update(revision=0-models.F('revision'))
+ self.change_set.all().update(revision=other_revs - models.F('revision'))
other.change_set.all().update(tree=self)
assert not other.change_set.exists()
other.delete()
other.change_set.all().update(tree=self)
assert not other.change_set.exists()
other.delete()