[cvsnt] Mergepoint issues on 2.5.0.3 b2382

Harrison, Andy andy.harrison at anite.com
Wed Jan 10 17:50:23 GMT 2007


> Your problem seems to be that you merge this code back into the trunk,
when
> there is no need for a merge. The code on the branch as it is after
the
> last merge from the trunk is what you want to have on the trunk -- if
you
> have done the merges from the trunk to the branch correctly. (If not,
you
> need to find these problems either way.) So a move of the code on the
> branch to the trunk should do it; there's no need for a merge. 
> 
> AFAIK this code move is not directly supported by cvsnt, but the
earlier
> thread Tony E mentioned showed some solutions for this close to its
end.

You are correct that if the dev branch has been re-based right up to the
HEAD that this final merge back to the trunk is effectively a direct
copy. My problem is that this functionality *used* to be supported by
CVSNT and we have been using it successfully for quite some time and
wish to continue to use it. Having to manually copy files introduces a
manual element which increases the window for possible errors.

Also, our process is of course not as strict as I have described. It
allows for the engineers professional judgement in deciding if the very
latest HEAD needs to be merged into the dev branch. If the only changes
to the trunk since the last rebase are not significant or in a
completely unrelated area, if may be worth skipping that step and
merging directly to the trunk. 

With the old version of CVSNT the final merge into the trunk was
performed exactly the same in either of the two scenarios. This
simplified the process a lot and was a significant deciding factor in
the choice to use CVS.

> If you look at merging in terms of deltas between revisions and try to
> write down the delta handling for a simple case of back-and-forth
merging
> like you described (don't forget to include some manual conflict
> resolution), you see that this is non-trivial even for simple cases.
That's
> basically the reason why it's better to merge in one direction, end up
with
> the final code in the branch you are merging to, and then move this
code to
> where it belongs. Can you describe in how this would be different from
your
> current process (result-wise)?

I know I'm not as clued up on the internals of merging as the folks who
wrote CVS, but as long as you can generate the delta between any two
revisions (not necessarily two revisions that are in the same
development branch) and can apply that delta to any other revision
(allowing for the possibility of conflicts) it should all hang together.
The difficult bit is deciding the Root revision for any merge. That is
what mergepoints are for.

Using the example in my original mail:

1. Start with Trunk, Branch1 and Branch2 all at revision 1.1

2. Modify on Branch1 to create revision 1.1.2.1

3. Merge Branch1 to Trunk
   Target = 1.1
   Source = 1.1.2.1
   Common Ancestor = 1.1
   No mergepoints between Target and Common Ancestor
   No mergepoints between Source and Common Ancestor
   Root = Common Ancestor = 1.1
   Delta is Root -> Source = 1.1 -> 1.1.2.1
   Apply to Target = 1.1
   Target = Root, so no conflicts will be generated.
   Create revision 1.2, with mergepoint = Source = 1.1.2.1

4. Modify on Branch2 to create revision 1.1.4.1

5. Merge Trunk to Branch2
   Target = 1.1.4.1
   Source = 1.2
   Common Ancestor = 1.1
   No mergepoints between Target and Common Ancestor
   Mergepoints exist between Source and Common Ancestor
     1.2 has mergepoint 1.1.2.1
     1.1.2.1 is not ancestor of Target, ignored  
   Root = Common Ancestor = 1.1
   Delta is Root -> Source = 1.1 -> 1.2
   Apply to Target = 1.1.4.1
   Target != Source, so conflicts may be generated and will need to be
manually resolved.
   Create revision 1.1.4.1, with mergepoint = Source = 1.2

6. Merge Branch2 to Trunk
   Target = 1.2
   Source = 1.1.4.2
   Common Ancestor = 1.1
   Mergepoints exist between Target and Common Ancestor
     1.2 has mergepoint 1.1.2.1
     1.1.2.1 is not ancestor of Source, ignored  
   Mergepoints exist between Source and Common Ancestor
     1.1.4.2 has mergepoint 1.2
     1.2 is ancestor of Target, becomes new Common Ancestor
   Root = Common Ancestor = 1.2
   Delta is Root -> Source = 1.2 -> 1.1.4.2
   Apply to Target = 1.2
   Target = Root, so no conflicts will be generated.
   Create revision 1.3, with mergepoint = Source = 1.1.4.2

I realise I have probably over-trivialised it, but that seems to work
for me. This is how the old version of CVS seemed to work (based on the
results of my using it, not looking at the code). Please can you show me
the scenario which results in loss of data?

Rgds,
Andy


--
Andy Harrison - Platform Software Engineer 
Anite Telecoms Ltd. Ancells Business Park, Fleet, Hampshire, GU51 2UZ,
UK
"No matter how bad things seem... 
...nothing could be worse than being used as a towel rail." - A.A. Milne


A member of the Anite Group of companies. Please refer to www.anite.com for individual Anite company details. The contents of this e-mail and any attachments are for the intended recipient only. If you are not the intended recipient, you are not authorised to and must not disclose, copy, distribute, or retain this message or any part of it. It may contain information which is confidential and/or covered by legal professional or other privilege. Contracts cannot be concluded with us nor legal service effected by email.  

Anite Group plc
Registered in England No.1798114
Registered Office: 353 Buckingham Avenue Slough Berks SL1 4PF United Kingdom
VAT Registration No. GB 787 418187

Scanned for viruses by BlackSpider MailControl.


More information about the cvsnt mailing list