# HG changeset patch # User Martin von Zweigbergk # Date 1515609861 28800 # Node ID dda3cae3c9c5dddcddc2c24d49d40325a982a1d8 # Parent 09285733ad719d49fa4643e2d51eba46c8a73c8d phase: use context managers for lock and transaction Differential Revision: https://phab.mercurial-scm.org/D1838 diff -r 09285733ad71 -r dda3cae3c9c5 mercurial/commands.py --- a/mercurial/commands.py Wed Jan 10 10:33:11 2018 -0800 +++ b/mercurial/commands.py Wed Jan 10 10:44:21 2018 -0800 @@ -3854,7 +3854,6 @@ revs = scmutil.revrange(repo, revs) - lock = None ret = 0 if targetphase is None: # display @@ -3862,10 +3861,7 @@ ctx = repo[r] ui.write('%i: %s\n' % (ctx.rev(), ctx.phasestr())) else: - tr = None - lock = repo.lock() - try: - tr = repo.transaction("phase") + with repo.lock(), repo.transaction("phase") as tr: # set phase if not revs: raise error.Abort(_('empty revision set')) @@ -3878,11 +3874,6 @@ phases.advanceboundary(repo, tr, targetphase, nodes) if opts['force']: phases.retractboundary(repo, tr, targetphase, nodes) - tr.close() - finally: - if tr is not None: - tr.release() - lock.release() getphase = unfi._phasecache.phase newdata = [getphase(unfi, r) for r in unfi] changes = sum(newdata[r] != olddata[r] for r in unfi)