mirror of
https://github.com/facebook/sapling.git
synced 2024-10-16 19:57:18 +03:00
584656dff3
Summary: Turned on the auto formatter. Ran `arc lint --apply-patches --take BLACK **/*.py`. Then run `arc lint` again so some other autofixers like spellchecker etc. looked at the code base. Manually accept the changes whenever they make sense, or use a workaround (ex. changing "dict()" to "dict constructor") where autofix is false positive. Disabled linters on files that are hard (i18n/polib.py) to fix, or less interesting to fix (hgsubversion tests), or cannot be fixed without breaking OSS build (FBPYTHON4). Conflicted linters (test-check-module-imports.t, part of test-check-code.t, test-check-pyflakes.t) are removed or disabled. Duplicated linters (test-check-pyflakes.t, test-check-pylint.t) are removed. An issue of the auto-formatter is lines are no longer guarnateed to be <= 80 chars. But that seems less important comparing with the benefit auto-formatter provides. As we're here, also remove test-check-py3-compat.t, as it is currently broken if `PYTHON3=/bin/python3` is set. Reviewed By: wez, phillco, simpkins, pkaush, singhsrb Differential Revision: D8173629 fbshipit-source-id: 90e248ae0c5e6eaadbe25520a6ee42d32005621b
69 lines
2.2 KiB
Python
69 lines
2.2 KiB
Python
# dirstateguard.py - class to allow restoring dirstate after failure
|
|
#
|
|
# Copyright 2005-2007 Matt Mackall <mpm@selenic.com>
|
|
#
|
|
# This software may be used and distributed according to the terms of the
|
|
# GNU General Public License version 2 or any later version.
|
|
|
|
from __future__ import absolute_import
|
|
|
|
from . import error, util
|
|
from .i18n import _
|
|
|
|
|
|
class dirstateguard(util.transactional):
|
|
"""Restore dirstate at unexpected failure.
|
|
|
|
At the construction, this class does:
|
|
|
|
- write current ``repo.dirstate`` out, and
|
|
- save ``.hg/dirstate`` into the backup file
|
|
|
|
This restores ``.hg/dirstate`` from backup file, if ``release()``
|
|
is invoked before ``close()``.
|
|
|
|
This just removes the backup file at ``close()`` before ``release()``.
|
|
"""
|
|
|
|
def __init__(self, repo, name):
|
|
self._repo = repo
|
|
self._active = False
|
|
self._closed = False
|
|
self._backupname = "dirstate.backup.%s.%d" % (name, id(self))
|
|
repo.dirstate.savebackup(repo.currenttransaction(), self._backupname)
|
|
self._active = True
|
|
|
|
def __del__(self):
|
|
if self._active: # still active
|
|
# this may occur, even if this class is used correctly:
|
|
# for example, releasing other resources like transaction
|
|
# may raise exception before ``dirstateguard.release`` in
|
|
# ``release(tr, ....)``.
|
|
self._abort()
|
|
|
|
def close(self):
|
|
if not self._active: # already inactivated
|
|
msg = _("can't close already inactivated backup: %s") % self._backupname
|
|
raise error.Abort(msg)
|
|
|
|
self._repo.dirstate.clearbackup(
|
|
self._repo.currenttransaction(), self._backupname
|
|
)
|
|
self._active = False
|
|
self._closed = True
|
|
|
|
def _abort(self):
|
|
self._repo.dirstate.restorebackup(
|
|
self._repo.currenttransaction(), self._backupname
|
|
)
|
|
self._active = False
|
|
|
|
def release(self):
|
|
if not self._closed:
|
|
if not self._active: # already inactivated
|
|
msg = (
|
|
_("can't release already inactivated backup: %s") % self._backupname
|
|
)
|
|
raise error.Abort(msg)
|
|
self._abort()
|