On Fri, Apr 10, 2020 at 1:38 PM Junio C Hamano <gitster@xxxxxxxxx> wrote: > > "Elijah Newren via GitGitGadget" <gitgitgadget@xxxxxxxxx> writes: > > > That commit viewed this, though as > > turning that flag into a no-op. > > Sorry, but I do not understand this sentence. Hmm...it wouldn't hurt to just drop the two sentences with "no-op" in them. > > Provide users a way to drop commits which start empty using a flag that > > existed for years: --no-keep-empty. Interpret --keep-empty as > > countermanding any previous --no-keep-empty, but otherwise leaving > > --keep-empty as the default. > > But everything after that sentence down to here was very clear. :-) > > This might lead to some slight weirdness since commands like > > git rebase --empty=drop --keep-empty > > git rebase --empty=keep --no-keep-empty > > look really weird despite making perfect sense (the first will drop > > commits which become empty, but keep commits that started empty; the > > second will keep commits which become empty, but drop commits which > > started empty). > > That is true. Do we leave it to others (or our later selves) to > think about the UI further? That is fine by me, but in that case we > may want to add " We may want to rethink the option names later", > perhaps? The names might not be great, but since --no-keep-empty and --keep-empty already existed for years and prior to 2.16 and were about how to handle commits which started empty, it seemed reasonable to (re)use them. My personal preference would be that for commits whose keep/drop state can be determined solely by looking at its contents of the commit before the rebase (whether that's because they start empty or for whatever other reasons), I'd rather recommend that people just fire up an interactive rebase and pick out the commits they don't want to keep. So, my own bias would be that I wouldn't recommend that new people use either --keep-empty or --no-keep-empty. In my mind, the --[no-]keep-empty flags are just for backward compatibility, so going through effort to rename or alias doesn't seem like it makes a lot of sense. I don't have a strongly held position here and I'm happy to hear alternate viewpoints, but that's the thought process I went through when creating this change. > > +--no-keep-empty:: > > --keep-empty:: > > + Do not keep commits that start empty before the rebase > > + (i.e. that do not change anything from its parent) in the > > + result. For commits which become empty after rebasing, see > > + the --empty and --keep-cherry-pick flags. > > keep-cherry-pick will appear later, not here, right? --keep-cherry-pick is the new flag added by jt/rebase-allow-duplicate. I guess I should technically probably wait until I create a commit on top of that series and this one to mention it. Or rebase Jonathan's commit, and combine the two series (adding his second since mine might be viewed as a bugfix).