Mercurial > hg
view mercurial/admin_commands.py @ 52178:bcd4962e0df9
rust-revlog: don't create an in-memory nodemap for filelogs from Python
Explanations inline.
Benchmarks from this change affect positively the only repo that showed this
being a problem:
```
### data-env-vars.name = mozilla-try-2024-03-26-ds2-pnm
# benchmark.name = hg.command.cat
# bin-env-vars.hg.flavor = rust
# bin-env-vars.hg.py-re2-module = default
# benchmark.variants.files = all-root
# benchmark.variants.output = plain
# benchmark.variants.rev = tip
default: 62.848869 ~~~~~
before-this-patch: 58.113051 (-7.54%, -4.74)
this-patch: 57.407533 (-8.66%, -5.44)
### data-env-vars.name = mozilla-try-2024-03-26-ds2-pnm
# benchmark.name = hg.command.log
# bin-env-vars.hg.flavor = rust
# bin-env-vars.hg.py-re2-module = default
# benchmark.variants.limit-rev = 10
# benchmark.variants.patch = yes
# benchmark.variants.rev = none
default: 3.173532 ~~~~~
before-this-patch: 3.543591 (+11.66%, +0.37)
this-patch: 3.297235 (+3.90%, +0.12)
```
author | Raphaël Gomès <rgomes@octobus.net> |
---|---|
date | Wed, 31 Jul 2024 13:35:54 +0200 |
parents | 1c5810ce737e |
children |
line wrap: on
line source
# admin_commands.py - command processing for admin* commands # # Copyright 2022 Mercurial Developers # # 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 annotations from .i18n import _ from .admin import chainsaw, verify from . import error, registrar, transaction table = {} table.update(chainsaw.command._table) command = registrar.command(table) @command( b'admin::verify', [ (b'c', b'check', [], _(b'add a check'), _(b'CHECK')), (b'o', b'option', [], _(b'pass an option to a check'), _(b'OPTION')), ], helpcategory=command.CATEGORY_MAINTENANCE, ) def admin_verify(ui, repo, **opts): """verify the integrity of the repository Alternative UI to `hg verify` with a lot more control over the verification process and better error reporting. """ if not repo.url().startswith(b'file:'): raise error.Abort(_(b"cannot verify bundle or remote repos")) if transaction.has_abandoned_transaction(repo): ui.warn(_(b"abandoned transaction found - run hg recover\n")) checks = opts.get("check", []) options = opts.get("option", []) funcs = verify.get_checks(repo, ui, names=checks, options=options) ui.status(_(b"running %d checks\n") % len(funcs)) # Done in two times so the execution is separated from the resolving step for name, func in sorted(funcs.items(), key=lambda x: x[0]): ui.status(_(b"running %s\n") % name) errors = func() if errors: ui.warn(_(b"found %d errors\n") % errors)