# HG changeset patch # User Matt Mackall # Date 1155669493 18000 # Node ID 5df3e5cf16bce8a2c24de94d4aa6ef521840d372 # Parent 20b95aef3fe08dcc90b191c39426792a9286e671 Move cmp bits from filelog to revlog diff -r 20b95aef3fe0 -r 5df3e5cf16bc mercurial/filelog.py --- a/mercurial/filelog.py Tue Aug 15 14:06:50 2006 -0500 +++ b/mercurial/filelog.py Tue Aug 15 14:18:13 2006 -0500 @@ -73,18 +73,7 @@ t2 = self.read(node) return t2 == text - p1, p2 = self.parents(node) - h = hash(text, p1, p2) - - return h != node - - def makenode(self, node, text): - """calculate a file nodeid for text, descended or possibly - unchanged from node""" - - if self.cmp(node, text): - return hash(text, node, nullid) - return node + return revlog.cmp(self, node, text) def annotate(self, node): diff -r 20b95aef3fe0 -r 5df3e5cf16bc mercurial/revlog.py --- a/mercurial/revlog.py Tue Aug 15 14:06:50 2006 -0500 +++ b/mercurial/revlog.py Tue Aug 15 14:18:13 2006 -0500 @@ -766,6 +766,19 @@ raise RevlogError(_("No match found")) + def cmp(self, node, text): + """compare text with a given file revision""" + p1, p2 = self.parents(node) + return hash(text, p1, p2) != node + + def makenode(self, node, text): + """calculate a file nodeid for text, descended or possibly + unchanged from node""" + + if self.cmp(node, text): + return hash(text, node, nullid) + return node + def diff(self, a, b): """return a delta between two revisions""" return mdiff.textdiff(a, b)