Junio C Hamano wrote: > Raman Gupta <rocketraman@xxxxxxxxxxx> writes: > >> Nanako Shiraishi wrote: >>> Quoting rocketraman@xxxxxxxxxxx: >>> >>>> + - The 'maint' branch is updated to the new release. >>>> + >>>> + $ git checkout maint >>>> + $ git merge master >>>> + >>>> + This is equivalent to deleting maint and recreating it from >>>> + master, but it preserves the maint reflog. >>> After giving a recipe that is better than an alternative, what's >>> the point of describing an inferior alternative as "equivalent", >>> when it is obviously not "equivalent"? >> Is this better: >> >> The resulting maint tree is equivalent to deleting maint and >> recreating it from the tip of master, but merging from master >> preserves the maint reflog. > > It is unclear what you are trying to explain with these two (in your > original) or three (your rewrite) lines. As an explanation for the two > command sequence, I would expect to see: > > "This merges the tip of the master into maint". > > But that is literally what the command sequence does, so it goes without > saying. Let me see if I can explain why I think the extra verbiage, at least in some form, is useful... It is my understanding that the _goal_ in this case is for the maint tree to match the master tree (so that the maint tree matches the new feature release). The "obvious" way to do that, at least for less experienced folks, is to delete maint, and recreate it from the tip of master (or from the feature release tag which should be the same commit). In this particular case, because and only because of the semantics of the maint and master branch i.e. we know that master already contains everything that maint does, merging from master to maint makes the trees equivalent, while *also* maintaining the reflog. However, someone less familiar with the semantics of the maint and master branches may not draw this conclusion automatically. BTW, would: git branch -f maint master be another way of doing this? > If there is anything that needs to be said further, I think it is not how > delete-then-recreate is inappropriate (I do not think it is even worth > teaching). But you may want to explain the reason _why_ maint gets this > update from master. I thought the explanation "... is updated to the new > release" already covers that motivation, but if you want to make the > description really novice-friendly, you _could_ say something like: > > Now a new release X.Y.Z is out, the 'maint' branch will be used to > manage the fixes to it. The branch used to be used for managing the > fixes to X.Y.(Z-1), and does not have any feature development that > happened between X.Y.(Z-1) and X.Y.Z. Because these changes are > contained in the 'master' branch, we can merge 'master' to 'maint' to > have the latter have them, which prepares it to be used for managing > the fixes to X.Y.Z. > > I personally would not want to see somebody who needs the above to be > explained to take over git maintenance after I get hit by a wayward bus, > by the way ;-) :) Very true, but there are lots of people out there who are trying to understand and use git, and when they come across documentation like this they rightfully think "hey if this works for the git.git guys, it would probably be a pretty good starting point for me as well!". I know I did. So a bit of explanation may be appropriate, even though its not relevant for your intended audience. On the other hand, maybe the newbie-level explanation can be skipped here, and instead be put into gitworkflows(7). For my next patch iteration, I'll assume that's what you want unless you tell me otherwise. Cheers, Raman -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html