Hi Duy, On Tue, Aug 21, 2018 at 7:52 AM Duy Nguyen <pclouds@xxxxxxxxx> wrote: > > On Mon, Aug 20, 2018 at 8:16 PM Elijah Newren <newren@xxxxxxxxx> wrote: > > Playing with sparse-checkout, it feels to me like a half-baked > > feature. It seems like it required too much manual work, and it was > > sometimes hard to tell if I was misunderstanding configuration rules > > or I was just running into bugs in the code. I think I hit both but I > > didn't really want to get side-tracked further, yet. (I do want to > > eventually come back to it.) The only reason someone would go through > > that pain is if it provided massive performance benefits. > > In my defense it was one of my first contribution when I was naiver > and basically an evolution of "git update-index --assume-unchanged". I > have something in the queue to improve/complement sparse-checkout but > my last update on that branch was 2.5 years ago, so it's not coming > soon. > > I'd love to year how sparse checkout could be improved, or even > replaced. I think we still have to have some configuration rules, and > yes the flexibility of sparse checkout (or gitignore to be precise) > rules is a double-edged sword. Sorry for taking a while to respond, and if what I said came across harshly. I agree that the flexibility of the rules makes it more complicated, though I think a bigger issue may be that the feature is hard to make smooth unless coupled to something like partial clones. Work on that is ongoing. Anyway, in an attempt to be helpful, here were some of the pain points I ran across: - The fact that documentation could only be found in a low-level plumbing command like read-tree made discoverability hard. Why would folks think to look there? (I can't remember if I had to google it or just grepped around the git source code to find it.) - Needing to use read-tree, which isn't something most users are familiar with, makes for a learning curve. I may know what some of the flags in read-tree do, but users will puzzle over which things on the page happen to be relevant to them -- especially since the section on sparse checkouts don't specify how read-tree should be invoked after .git/info/sparse-checkout is populated. Even I couldn't guess what I was supposed to ran and just googled for hints. Here's some possible failures, as users guess which flags to pass: $ git read-tree warning: read-tree: emptying the index with no arguments is deprecated; use --empty $ git read-tree HEAD # Oops, doesn't update the working directory $ git read-tree -u HEAD # Doesn't do any updates either $ git read-tree -mu HEAD # Works...but make user think "Why/what am I merging?!?" - I actually misunderstood or misread the documentation about undoing sparse checkouts and failed multiple times. I think I nuked the index then did a 'git reset --hard HEAD'. Re-reading, it looks like you did explain it, and I don't remember why/how I missed it the first time around, but I did. - I either failed to grasp how to specify negative refs or botched something else up. I tried digging for a while to figure out how to exclude my massive directory, but was always met with: error: Sparse checkout leaves no entry on working directory I spent a while trying to figure out what I did wrong, but gave up after half an hour or so since I wasn't trying to use the feature for real and just specified the files I wanted to keep instead. Re-reading the docs, it looks like you specified how to do this, and re-trying now it works, but I repeatedly passed over the '/*' in the docs and read it as either bad formatting or a highlight of the next line rather than as important literal text. So, maybe part of my problem is that I just can't read. :-)