> On Apr 16, 2018, at 8:34 AM, Yuya Nishihara <y...@tcha.org> wrote: > >> On Mon, 16 Apr 2018 08:25:07 -0400, Matt Harbison wrote: >> >>>> On Apr 16, 2018, at 7:35 AM, Yuya Nishihara <y...@tcha.org> wrote: >>>> >>>> On Sun, 15 Apr 2018 02:44:08 -0400, Matt Harbison wrote: >>>> # HG changeset patch >>>> # User Matt Harbison <matt_harbi...@yahoo.com> >>>> # Date 1523752111 14400 >>>> # Sat Apr 14 20:28:31 2018 -0400 >>>> # Node ID 3b0c3d4939b56ca038dbbba17da424699a6b339d >>>> # Parent 691a7d3f2df80908e52a170897a4492a528c3533 >>>> verify: invoke the file prefetch hook >>>> >>>> It's unfortunate that verify wants to download everything. Maybe we can >>>> create >>>> a custom transfer handler for LFS. But it shouldn't be painful in the >>>> meantime, >>>> and it's likely that blobs will be served up from more than just hgweb. >>>> >>>> diff --git a/mercurial/verify.py b/mercurial/verify.py >>>> --- a/mercurial/verify.py >>>> +++ b/mercurial/verify.py >>>> @@ -25,6 +25,7 @@ from . import ( >>>> >>>> def verify(repo): >>>> with repo.lock(): >>>> + scmutil.fileprefetchhooks(repo, repo.set('all()')) >>>> return verifier(repo).verify() >>> >>> I don't think "hg verify" should go that abstraction level because the >>> repository might be inconsistent state. >> >> Do you mean using a revset, or prefetching at all? Grabbing one file at a >> time will likely be painfully slow. >> >> If the revset bit is the bad part, what is the alternative with a corrupt >> repo? > > I think we should avoid any write operation on damaged repo. Is there any way > to disable fetching at all?
Maybe we could wrap hg.verify() to stuff a flag is svfs? But I think then the revlog flag processor will flag each revision as corrupt anyway, hiding the real error. Avoiding writes on a corrupt repo makes sense, but in this case I think it is safe. The storage is external, so nothing gets more corrupt, and the blobs are checksummed on their own before adding them to the store. As a point of reference, largefiles will verify the external files (by asking the server to do it IIRC). I’d like to do something like that here, but obviously that extension won’t be supported anywhere else. So from a UX point of view, IDK how we can sanely do that if it doesn’t fallback to fetching them. _______________________________________________ Mercurial-devel mailing list Mercurialemail@example.com https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel