# HG changeset patch # User Yuya Nishihara # Date 1498575022 -32400 # Node ID 247bae545061374a683d8d9369a4869aa6ae4537 # Parent 208de1534ebd7e4130cc609f222ced645e6fafa6 smartset: fix generatorset.last() to not return the first element (issue5609) diff -r 208de1534ebd -r 247bae545061 mercurial/smartset.py --- a/mercurial/smartset.py Mon Jun 26 21:11:02 2017 -0700 +++ b/mercurial/smartset.py Tue Jun 27 23:50:22 2017 +0900 @@ -766,6 +766,11 @@ be iterated more than once. When asked for membership it generates values until either it finds the requested one or has gone through all the elements in the generator + + >>> xs = generatorset([0, 1, 4], iterasc=True) + >>> assert xs.last() == xs.last() + >>> xs.last() # cached + 4 """ def __init__(self, gen, iterasc=None): """ @@ -937,7 +942,7 @@ # we need to consume all and try again for x in self._consumegen(): pass - return self.first() + return self.last() return next(it(), None) def __repr__(self): diff -r 208de1534ebd -r 247bae545061 tests/test-revset.t --- a/tests/test-revset.t Mon Jun 26 21:11:02 2017 -0700 +++ b/tests/test-revset.t Tue Jun 27 23:50:22 2017 +0900 @@ -1337,6 +1337,16 @@ 0 1 +Test scmutil.revsingle() should return the last revision + + $ hg debugrevspec -s 'last(0::)' + * set: + > + 9 + $ hg identify -r '0::' --num + 9 + Test matching $ log 'matching(6)'