Re: [spf:guess,iffy] Re: [spf:guess,iffy] [PATCH] git-svn: teach git-svn to populate svn:mergeinfo

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

 



On 9/2/11 11:49 AM, Bryan Jacobs wrote:
I could do a pass through all the commits which are about to be sent
out to SVN to check if this is going to happen, yes. But I think a
better solution would be to change how the changes are replayed by
git-svn dcommit: right now, all changes are applied to the WC, then it
sequentially does an add+dcommit for each patch? Right? I think it might
be better to reset --hard to the parent, then pick each change into the
WC+index before committing. That way if you abort early, cleaning up
just consists of rebasing the stack onto the last change you sent
upstream.

That's one way to do it; in fact, if the trees match you don't need to do anything complicated like cherry-pick.

ie, say you're committing

   r1---A---B---C---D

and it blows up at

   r1--r2--r3--C---D

So long as the tree from the fetched r3 == the tree from B, then you can just go ahead and write out new commits for C and D without doing any merging (ie cherry-pick or rebase). You could also put merge commits back the way they were, too.

If they don't match, then something went wrong with the push really, or there is something weird going on. I'd try to avoid using cherry pick automatically in situations like this. There are too many error modes, and if it only happens when you don't know what's going on, it's not a good idea to try to fix that. If it /is/ a sufficiently unlikely error (ie, the trees not matching as above), then it would be better to simply bomb out and provide two commands:

* a 'git reset' command to restore to previous state (ie, before the dcommit) * a 'git rebase' command to attempt to put the new history on top of the new upstream. Rebase doesn't work with merges of course but it still should help the user figure out what to do.

Another benefit of this approach is that you don't need to muck with the WC + index at all, no matter what happens.

Sam

--
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]