# HG changeset patch # User Martin von Zweigbergk # Date 1572991930 28800 # Node ID c093fb81404f46c9da1ed0caaf2d4fb3bfbfa73a # Parent c470e699cd000bf441358617a3e7f56d4bf2c129 repoview: move changelog.__iter__() override to filteredchangelog Differential Revision: https://phab.mercurial-scm.org/D7239 diff -r c470e699cd00 -r c093fb81404f mercurial/changelog.py --- a/mercurial/changelog.py Tue Nov 05 14:11:30 2019 -0800 +++ b/mercurial/changelog.py Tue Nov 05 14:12:10 2019 -0800 @@ -405,18 +405,6 @@ self.filteredrevs = frozenset() self._copiesstorage = opener.options.get(b'copies-storage') - def __iter__(self): - """filtered version of revlog.__iter__""" - if len(self.filteredrevs) == 0: - return revlog.revlog.__iter__(self) - - def filterediter(): - for i in pycompat.xrange(len(self)): - if i not in self.filteredrevs: - yield i - - return filterediter() - def revs(self, start=0, stop=None): """filtered version of revlog.revs""" for i in super(changelog, self).revs(start, stop): diff -r c470e699cd00 -r c093fb81404f mercurial/repoview.py --- a/mercurial/repoview.py Tue Nov 05 14:11:30 2019 -0800 +++ b/mercurial/repoview.py Tue Nov 05 14:12:10 2019 -0800 @@ -21,6 +21,7 @@ obsolete, phases, pycompat, + revlog, tags as tagsmod, util, ) @@ -233,6 +234,19 @@ """filtered version of revlog.__contains__""" return 0 <= rev < len(self) and rev not in self.filteredrevs + def __iter__(self): + """filtered version of revlog.__iter__""" + if len(self.filteredrevs) == 0: + return revlog.revlog.__iter__(self) + + + def filterediter(): + for i in pycompat.xrange(len(self)): + if i not in self.filteredrevs: + yield i + + return filterediter() + cl.__class__ = filteredchangelog return cl