bisect: replace try:/finally: by a "restore_state" context manager
This should help pytype to not consider "bgood" variable as NameError.
See https://phab.mercurial-scm.org/D7384 for context.
Differential Revision: https://phab.mercurial-scm.org/D7430
--- a/mercurial/commands.py Wed Oct 30 19:19:57 2019 -0400
+++ b/mercurial/commands.py Thu Nov 14 10:47:04 2019 +0100
@@ -1073,7 +1073,7 @@
raise error.Abort(_(b'current bisect revision is a merge'))
if rev:
node = repo[scmutil.revsingle(repo, rev, node)].node()
- try:
+ with hbisect.restore_state(repo, state, node):
while changesets:
# update state
state[b'current'] = [node]
@@ -1105,9 +1105,6 @@
# update to next check
node = nodes[0]
mayupdate(repo, node, show_stats=False)
- finally:
- state[b'current'] = [node]
- hbisect.save_state(repo, state)
hbisect.printresult(ui, repo, state, displayer, nodes, bgood)
return
--- a/mercurial/hbisect.py Wed Oct 30 19:19:57 2019 -0400
+++ b/mercurial/hbisect.py Thu Nov 14 10:47:04 2019 +0100
@@ -11,6 +11,7 @@
from __future__ import absolute_import
import collections
+import contextlib
from .i18n import _
from .node import (
@@ -180,6 +181,15 @@
raise error.Abort(_(b'cannot bisect (no known bad revisions)'))
+@contextlib.contextmanager
+def restore_state(repo, state, node):
+ try:
+ yield
+ finally:
+ state[b'current'] = [node]
+ save_state(repo, state)
+
+
def get(repo, status):
"""
Return a list of revision(s) that match the given status: