From: Patrick Steinhardt <ps@pks.im>
To: Junio C Hamano <gitster@pobox.com>
Cc: Sam Bostock via GitGitGadget <gitgitgadget@gmail.com>,
git@vger.kernel.org, Sam Bostock <sam.bostock@shopify.com>
Subject: Re: [PATCH] refs: support migration with worktrees
Date: Wed, 29 Oct 2025 11:10:49 +0100 [thread overview]
Message-ID: <aQHoKXtrbDx6eNpH@pks.im> (raw)
In-Reply-To: <xmqqfrb3dnis.fsf@gitster.g>
On Tue, Oct 28, 2025 at 09:00:43AM -0700, Junio C Hamano wrote:
> Patrick Steinhardt <ps@pks.im> writes:
>
> >> `migrate`::
> >> - Migrate ref store between different formats.
> >> + Migrate ref store between different formats. Supports repositories
> >> + with worktrees; migration must be run from the main worktree.
> >
> > It feels a bit weird to single our worktrees specifically. We don't say
> > that the tool supports bare and non-bare repositories, either, so the
> > only reason why we'd have the note about worktrees is historic legacy.
> > How about this instead:
> >
> > Migrate ref storage between different formats. Must be run from the
> > main worktree in case the repository uses worktrees.
>
> Two thoughts.
>
> * Would it be unacceptable if the primary repository and refstore
> uses reftable backend, and a newly attached worktree to the
> repository uses ref-files only for its per-worktree refs? If we
> should allow it, then "if the ref store you are migrating is in a
> repository with multiple worktrees, you must migrate from the
> primary and migrate _all_ ref store for all worktrees at once,
> into the same backend", which the design of this patch seems to
> aim at, would contradict with it, no?
The problem we have here is backwards compatibility. Right now we assume
that `extensions.refStorage` applies to all worktrees, so if we wanted
to change it like you propose then we'd have to introduce a backwards
incompatible change.
I agree though that it would've been great if we would have said from
the beginning that the worktree-specific configuration is allowed to
override the ref storage format for a worktree. If so, we could easily
convert any of the worktrees (including the main one) by without having
any impact on all the other worktrees.
But we do not live in such a world right now, and getting there would
require some significant reworking of how we handle per-worktree
references. Unfortunate, but I also don't think there's a strong enough
reason to change this.
> * If "you must do so from the primary worktree and we convert all
> the worktrees attached to the same repository" is the only mode
> of operation we support (which by the way I have no problem
> with---the first bullet point above was asking question, not
> suggesting change of design), then would it be easier for the
> user to use if the command noticed that it is not in the primary
> worktree and switched to it for the user, instead of complaining
> and failing?
I'm not sure. The question is whether the user recognizes that migrating
references in the worktree would also migrate references in the main
repository. It might be surprising behaviour if we did that without
asking.
It might of course also be surprising if you do that from the main
working tree. But I think there's an argument to be made that it's at
least _less_ surprising.
> >> @@ -95,7 +96,7 @@ KNOWN LIMITATIONS
> >>
> >> The ref format migration has several known limitations in its current form:
> >>
> >> -* It is not possible to migrate repositories that have worktrees.
> >> +* Migration must be run from the main worktree.
> >>
> >
> > I'd drop this bullet point entirely, as I don't really see this as a
> > limitation anymore.
>
> I agree that such a limitation should be lifted, but if we have to
> say "you must do it this way, not that way", that is still a
> limitation ;-).
So with the above reasoning I'm not sure I'd call this a limitation.
It's rather a mechanism to protect users from unexpected consequences.
Patrick
next prev parent reply other threads:[~2025-10-29 10:11 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-27 18:26 [PATCH] refs: support migration with worktrees Sam Bostock via GitGitGadget
2025-10-28 7:28 ` Patrick Steinhardt
2025-10-28 16:00 ` Junio C Hamano
2025-10-29 10:10 ` Patrick Steinhardt [this message]
2025-10-29 11:33 ` Kristoffer Haugsbakk
2025-10-29 16:22 ` Ben Knoble
2025-10-30 6:37 ` Patrick Steinhardt
2025-10-29 14:47 ` Junio C Hamano
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aQHoKXtrbDx6eNpH@pks.im \
--to=ps@pks.im \
--cc=git@vger.kernel.org \
--cc=gitgitgadget@gmail.com \
--cc=gitster@pobox.com \
--cc=sam.bostock@shopify.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).