From: Erez Zilber <erezzi.list@gmail.com>
To: Jon Seymour <jon.seymour@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: How to handle a git repository with multiple branches
Date: Tue, 31 Aug 2010 10:21:01 +0300 [thread overview]
Message-ID: <AANLkTi=eVuRenSOut2stYfdUpFRPbiOaUynrg6DPxQ9t@mail.gmail.com> (raw)
In-Reply-To: <AANLkTi=fn1YmK8WW-wfx2Eba8x8RQv3gZ56PU=T7=fLW@mail.gmail.com>
On Fri, Aug 27, 2010 at 2:03 AM, Jon Seymour <jon.seymour@gmail.com> wrote:
> On Thu, Aug 26, 2010 at 9:53 PM, Erez Zilber <erezzi.list@gmail.com> wrote:
>> Hi,
>>
>> My repository has several branches. Each branch is for a separate code
>> release. Let's assume that I have a branch for V1.0 (branch_1) and a
>> branch for V2.0 (branch_2).
>>
>> Some commits are relevant only for branch_1, some are relevant only
>> for branch_2 and some are relevant for both. For the commits that are
>> relevant for both branches, I thought about the following solutions:
>> 1. Put these common commits in branch_1 and merge branch_1 into
>> branch_2. This is bad because it will also merge commits that are
>> relevant only for branch_1.
>> 2. Cherry-pick the common commits from branch_1 to branch_2. This is
>> also bad because the commit ID changes, and in case of conflicts, git
>> is unable to tell that these 2 commits are actually the same commit.
>> This makes it very difficult to track the changes between branches.
>>
>> Since there are several other developers and sub-maintainers in this
>> project which are rebased on both these branches, I don't want to
>> change the git history of my branches because when I do that,
>> sub-maintainers and developers lose the reference to their base.
>>
>> I'm looking for a better solution. Is there any best-practice solution?
>>
>
> As Josh pointed out in another post, the key to sharing commits across
> branches is to ensure that the commits that you intend to share
> between branches should always be based on a commit that both branches
> have in common. That way, when you eventually merge the commit into
> the branch the only history it drags in is the history associated with
> the patch itself.
>
> This requires a slight shift in mind set - don't automatically assume
> the right thing to do is develop a patch is on the tip of branch_1. If
> the branch_1 does contain other stuff that you are not intending to
> merge into branch_2, this is probably the wrong thing to do.
>
> What I tend to do (as described here
> http://permalink.gmane.org/gmane.comp.version-control.git/153168), is
> to
> develop my fixes on the tip of private integration branch (which I
> never share), then rebase them onto a suitable base common to all
> potential delivery targets later. This works for me, because there
> isn't typically much divergence in the files I touch between branches.
> It might not work so well in cases where there is significant
> divergence.
>
> jon.
>
Thanks for the answers.
Erez
prev parent reply other threads:[~2010-08-31 7:21 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-08-26 11:53 How to handle a git repository with multiple branches Erez Zilber
2010-08-26 13:09 ` Joshua Juran
2010-08-26 21:17 ` David Ripton
2010-08-26 23:03 ` Jon Seymour
2010-08-31 7:21 ` Erez Zilber [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='AANLkTi=eVuRenSOut2stYfdUpFRPbiOaUynrg6DPxQ9t@mail.gmail.com' \
--to=erezzi.list@gmail.com \
--cc=git@vger.kernel.org \
--cc=jon.seymour@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).