Andreas Ericsson <ae@xxxxxx> writes: > You would then do > > $ git checkout -b for-linus linus > > followed by either multiple > > $ git cherry-pick <commit-ish> > > or, if the commits are all in series, an iteration of the following > > $ git format-patch --stdout <start-commit>..<end-commit> | git am -k With core git tools these two would be the idiom to use. It might be more pleasant to use a specialized tool (such as StGIT) designed to manage the changes meant for upstream. > If you have several topic branches, one for each series of commits, > you should be able to do an octopus, like so: > > $ git pull . <topic-branches-to-publish> Octopus is orthogonal to the issue at hand. Further, I suspect that the original repository by Anton is not that cleanly organized to have such topic branches -- otherwise the question would not have come up to begin with. > If you *don't* have several topic branches, or if some commits aren't > in topic-branches, you could try something like this (untested, > although it shouldn't break anything except the for-linus branch which > you can re-create fairly simply) > > $ for b in <topic-branches-for-linus>; do > git checkout $b > git rebase for-linus || (git reset --hard; echo $b >> to-merge) > done > # now merge what couldn't be rebased > $ git checkout for-linus > $ git pull . $(cat to-merge) Now you lost me here. When rebase refuses because of conflicting changes, you are doing "reset --hard" but I suspect you meant "reset --hard ORIG_HEAD" to recover the original head. Further, I would have expected you to be rebasing on top of linus, not for-linus, in case you may already have pulled other topic branches into it. Your merging those branches that have conflicting changes on top of for-linus (that starts out at Linus's tip) is sensible, but one word of caution is the history contained within the topic branch should be sane. What are you going to do with branches that cleanly rebase on top of for-linus? > ... If your vanilla tree is up-to-date and he pulls > from you before pulling from someone else or adding other commits this > isn't necessary, although you'll have to do > > $ git checkout linus; git pull . for-linus > > to get the vanilla branch up to speed with Linus' HEAD. I am not sure I follow you here. If Linus hasn't pulled from you, you can either just keep asking (you do not have to update for-linus), or rebuild it based on more recent Linus's tip. $ git fetch linus ;# to update to Linus's tip $ git checkout for-linus $ git reset --hard linus If Linus has pulled from you, there is nothing more than the above for you to do. If you want to rebuild for-linus branch, (maybe because you fixed things in some of your topic branches), after the above, you could: $ git pull . this-topic $ git pull . that-topic ... This is nicer to Linus _if_ your topics overlap with recent changes to the Linus's tree. Otherwise you do not necessarily have to rebuild for-linus branch. - : 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