On Fri, 2006-03-24 at 07:46 -0800, Linus Torvalds wrote: > > On Fri, 24 Mar 2006, David Mansfield wrote: > > > > Anyway, I'd like to nail down some of the other nagging ancestry/branch point > > problems if possible. > > What I considered doing was to just ignore the branch ancestry that cvsps > gives us, and instead use whatever branch that is closest (ie generates > the minimal diff). That's really wrong too (the data just _has_ to be in > CVS somehow), but I just don't know how CVS handles branches, and it's how > we'd have to do merges if we were to ever support them (since afaik, the > merge-back information simply doesn't exists in CVS). cvsps is more of a problem than cvs itself. Per-file branch information is readily available in the ,v files; each version has a list of branches from that version, and there are even tags marking the names of them. One issue that I've discovered is when files have differing branch structure in the same repository. That happens when a branch is created while files are checked out on different branches. I'm not quite sure what to do in this case; I've been trying several approaches and none seem optimal. One remaining plan is to just attach such branches by date, but that assumes that the first commit along a branch occurs shortly after the branch is created (which isn't required). Of course, this branch information is only created when a change is made to the file along said branch, so most of the repository will lack precise branch information for each branch. When you create a child branch, the files with no commits in the parent branch will never get branch information, so the child branch will be numbered as if it were a branch off of the grandparent. Globally, it is possible to reconstruct the entire branch structure. > Suddenly it was a perfectly reasonable system: the fact that you can only > merge once (between working tree and repo) is perfectly reasonable when > there is only one branch and checking in requires you to have updated > first. All the things I really hated about CVS just go away if you don't > do any branches at all. If you look at how deltas are stored in the file you get an even stronger argument -- CVS has always advertised that it stores deltas 'backwards' so that the current version is first in the file. That's true for the trunk, but for every other branch, you have to seek back from the tip of the trunk to the branch point and then walk forwards to the desired version along the branch. -- keith.packard@xxxxxxxxx
Attachment:
signature.asc
Description: This is a digitally signed message part