Re: Trying to sync two svn repositories with git-svn (repost)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, May 06, 2009 at 03:23:40PM -0400, Avery Pennarun wrote:
> On Wed, May 6, 2009 at 2:52 PM, Josef Wolf <jw@xxxxxxxxxxxxx> wrote:
> > Here's what I have at this point:
> >
> >             ------------------S1TRUNK
> >            /                 /
> >   --hs1--O1--c2...c2-------S1
> >            \              /
> >             `+++++++.    /
> >                      \  /
> >   --hs2--O2--c1...c1--S2
> >            \            \
> >             -------------S2TRUNK
> >
> >   hs1, hs2:         history imported from svn-1 and svn2, respectively
> >   O1, O2:           the svn-1-orig and svn-2-orig tags
> >   c1, c2:           cherries picked from hs1 and hs2, respectively
> >   S1, S2:           svn-1 and svn-2, the local tracking branches
> >   S1TRUNK, S2TRUNK: the remotes/svn-X/trunk branches
> >
> > I would have expected a symmetrical diagram.  But it turns out that the
> > connection marked with plusses is still at O1 instead of S1.  So it takes
> > no wonder that the c2 cherries get re-applied to the s2 branch on the
> > next merge.
> 
> That's a well-drawn diagram, but unfortunately I'm still confused.
> What is the "connection marked with plusses" and does it have a name?

Well, the whole history (including this connection) was created by the
commands I posted.  The only exception are hs1 and hs2, which were
imported from the svn repositories (but they are linear).

AFAICS, this connection was created by the very first merge after the
cherry-picking from hs1 (the cherries marked as c1..c1).  After importing
the svn repositories, I've done this:

  git checkout svn-2                # S2 in the diagram above, but used
                                    #    to be identical to O2 at that time
  [ cherry-picking c1...c1 ]        # S2 now moved to its place in diagram
  git merge --no-ff -s ours svn-1   # S1 in the diagram above, but used
                                    #    to be identical to O1 at the
                                    #    time of that merge, This merge
                                    #    creates the mystical
                                    #    "connection marked with plusses"

Then we've done the "detached head" merge, that created the S2TRUNK

  git checkout svn-2/trunk    # S2TRUNK was at O2 at that time
  git merge --no-ff svn-2
  git svn dcommit             # moves S2TRUNK to the place in the diagram

Now take care of the other direction:

  git checkout svn-1                # S1 in the diagram above, but still
                                    #    identical to O1 at that time
  [ cherry-picking c2...c2 ]        # S1 now moved to its place in diagram
  git merge --no-ff -s ours svn-2   # S2 in the diagram above.  Unlike S1,
                                    #    S2 already _is_ at the place where
                                    #    it is drawn in the diagram.  So
                                    #    this merge creates the connection
                                    #    S2->S1

Now we do the "detached head" merge, that creates the S1TRUNK

  git checkout svn-1/trunk    # S1TRUNK was at O1 at that time
  git merge --no-ff svn-1
  git svn dcommit             # moves S1TRUNK to the place in the diagram

So the "connection marked with plusses" is basically the counterpart of
the "S2->S1" connection.  But while "S2->S1" got its proper position at
the time it was created, the plus-connection was created before the c2
cherries.  And it was never adjusted.  AFAICS, those two connections
should be symmetrical: "S1->S2" and "S2->S1".

> It *looks* to me like both S1TRUNK and S2TRUNK should be okay, but
> it's hard to tell what has actually happened here.

Yes, the trunks (and the svn repositories) look pretty good at _that_
point in time.  But the next merge on S2TRUNK moves all the modifications
done by the c2 cherries down to S2TRUNK.

> If you could post a screenshot of 'gitk --all' it might help.

IMHO, Screenshots are not of much help here.  That's why I posted

  http://www.spinics.net/lists/git/msg102609.html

The svn histories are about 1250 commits each.  The cherry-pickings are
about 350 commits each.  This gives histories running in parallel for
long distances.  Add to this gitk's tendency to change lanes at every
occasion:  There's no chance to get multiple screen shots (the interesting
branch/merge-points, as I described in the thread referenced above) in
sync.  There's many opportunities to get confused.  At least for me, as a
newbie to git.
--
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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]