On 10/6/22 3:10 AM, Elijah Newren wrote: > On Wed, Sep 28, 2022 at 6:22 AM Derrick Stolee <derrickstolee@xxxxxxxxxx> wrote: >> >> On 9/28/22 1:38 AM, Elijah Newren wrote: >>> On Tue, Sep 27, 2022 at 9:36 AM Derrick Stolee <derrickstolee@xxxxxxxxxx> wrote: >>>> >>>> On 9/24/2022 8:09 PM, Elijah Newren via GitGitGadget wrote: >>>>> From: Elijah Newren <newren@xxxxxxxxx> >>>> > [...] >>>>> + * Commands whose default for --restrict vs. --no-restrict should vary depending >>>>> + on Behavior A or Behavior B >>>>> + * diff (with --cached or REVISION arguments) >>>>> + * grep (with --cached or REVISION arguments) >>>>> + * show (when given commit arguments) >>>>> + * bisect >>>>> + * blame >>>>> + * and annotate >>>>> + * log >>>>> + * and variants: shortlog, gitk, show-branch, whatchanged >>>>> + >>>>> + For now, we default to behavior B for these, which want a default of >>>>> + --no-restrict. >>>> >>>> I do feel pretty strongly that we'll want a --no-restrict default here >>>> because otherwise we will present confusion. I'm not even sure if we would >>>> want to make this available via a config setting, but likely a config >>>> setting makes sense in the long term. >>> >>> You've got me slightly confused. You did say the same thing a long time ago: >>> >>> "But I also want to avoid doing this as a default or even behind a >>> config setting."[A] >>> >>> BUT, when Shaoxuan proposed making --restrict/--focus the default for >>> one of these commands, you seemed to be on board[B]. >> >> I'm specifically talking about 'git log'. I think that having that be >> in a restricted mode is extremely dangerous and will only confuse users. >> This includes 'git show' (with commit arguments) and 'git bisect', I >> think. > > Thanks, that helps me understand your position better. > > I'm curious if, due to the length of the document and this thread, > you're just skimming past the idea I mentioned of showing a warning at > the beginning of `diff`, `log`, or `show` output when restricting > based on config or defaults. Without such a warning, I agree that > restricting might be confusing at times, but I think such a warning > may be sufficient to address the concerns around partial/incomplete > results. The one command that this warning idea doesn't help with is > `grep` since it cannot safely be applied there, which potentially > leaves `grep` giving confusing results when users pass either > `--cached` or revisions, but you seem to not be concerned about that. I'm not convinced that warnings are enough for some cases, especially for output that is fed to a pager. Do the warnings stick around in the pager? I'm not sure. > I'm also curious if the problem partially stems from the fact that > with `git log` there is no way to control revision limiting and diff > generation paths independently. If there was a way to make `git log > -p` continue showing the regular list of commits but restrict which > paths were shown in the diffs, and we made the --scope-sparse handling > do this so that only diffs were limited but not the revisions > traversed/printed, would that help address your concerns? My biggest issue is with the idea of simplifying the commit history based on the sparse-checkout path definitions. The '-p' option having a diff scoped to the sparse-checkout paths would be fine. >> The rest, (diff, grep, blame) are worktree-focused, so having a restrict >> mode by default makes sense to me. > > I was specifically calling out diff & grep when passed revision > arguments, which are definitely *not* worktree-focused operations. You're right. I'm not using the right terminology. They _are_ operations on a single tree, where path scopes make sense. > Also, blame incorporates a component of changes from the worktree, but > it's mostly about history (and one or more -C's make it check other > paths as well). Since each input is a specific file path, I'm not sure we need anything here except perhaps a warning that they are requesting a file outside the sparse-checkout definition (if even that). >>> Anyway...I will note that without a configurable option to give these >>> commands a behavior of `--restrict`, I think you make working in >>> disconnected partial clones practically impossible. I want to be able >>> to do "git log -p", "git diff REV1 REV2", and "git grep TERM REV" in >>> disconnected partial clones, and I've wanted that kind of capability >>> for well over a decade[H]. So, don't be surprised if I keep bringing >>> up a config option of some sort for these commands. :-) >> >> Now, if we're talking about "don't download extra objects" as a goal, >> then we're thinking about things not just related to sparse-checkout >> but even history within the sparse-checkout. Even if we make the >> 'backfill' command something that users could run, there isn't a >> guarantee that users will want to have even that much data downloaded. >> We would need a way to say "yes, I ran 'git blame' on this path in my >> sparse-checkout, but please don't just fail if you can't get new objects, >> instead inform me that the results are incomplete." >> >> I think the sparse-checkout boundary is a good way to minimize the >> number of objects downloaded by these commands, but to actually >> remove the need for downloads at all we need a way to gracefully >> return partial results. > > There may be some merits to a partial clone with shallow blob history, > but I've never really been all that interested in it. ...... > But you've got me curious. You seem to be suggesting that partial > results are okay if the user is informed. I have suggested making > diff-with-revisions, log -p, etc. show a warning that results may be > incomplete when restricting them to the sparse checkout based on > config. So, aren't you suggesting that my proposal is safe after all? I think the following things are true: 1. It's really important to keep the current partial clone default of only downloading blobs on-demand. Even with a limited sparse-checkout, it's rare that users will need every version of every file in that sparse-checkout, and they may not want that tax on their local storage. 2. Adding an opt-in backfill for a sparse-checkout definition will prevent most on-demand downloads (although it might want to be integrated into 'git fetch' behind an option to be really sure that state continues in the future). 3. Updating Git features to scope down to sparse-checkout will prevent many of the remaining on-demand downloads. 4. To be _absolutely sure_ that on-demand downloads don't happen, we need an extra mode for Git and new ways of reporting partial results. Without this mode, Git commands fail when triggering an on-demand download and the network is unavailable. So, I'm saying that (4) is a direction that we could go. It also seems extremely difficult to do, so we should do (2) & (3) first, which will get us 99% of the way there. Thanks, -Stolee