On Sun, 17 Apr 2005, Junio C Hamano wrote: > > LT> What do you think? I can whip up a "merge-cache" program like that in > five > LT> minutes, and it _seems_ like the right interface.. > > Yes. I think that is the right thing to do. In fact the idea > is quite similar to what I've been working on, which is a > rewrite of that perl thing to use "read-tree -m O A B".
I pushed the thing out. It was indeed pretty trivial. Just as an example, on your merge-test, I can then do merge-cache echo -a and the output is .merge_file_Raanu4 .merge_file_q7ZoLY AA .merge_file_zMXLAW .merge_file_SOugrU AN .merge_file_tWf5zS DD .merge_file_YmGzgR DM .merge_file_N1M8oO DN .merge_file_eAC5WL .merge_file_ROg7mM MD .merge_file_G1AWSM .merge_file_LMCruN .merge_file_ucVx7N MM .merge_file_3YxD2O NA .merge_file_2SJa6P .merge_file_3V5g6Q ND .merge_file_SIo4nQ S/DD .merge_file_dO8AOP S/DM .merge_file_wOO6iP S/DN .merge_file_RrgnYR .merge_file_KQxqHU S/MD .merge_file_F0sQRX .merge_file_E4DC00 .merge_file_HQkyn2 S/MM .merge_file_od0mf4 .merge_file_Xvv035 S/ND .merge_file_oEtq17 .merge_file_TwkT5c .merge_file_aqx58h Trivial (Note that the spaces signify an empty argument in those places, since the file in question didn't always exist). It executed the "echo" thing 16 times (once for each object that your script-from-hell had caused a clash with). In all cases you have $1 being "original", $2 being "branch 1", $3 being "branch 2", and $4 being "name in cache". ALERT ALERT ALERT! The git "merge object order" is different from the "merge" program merge object order. In the above ordering, the original is first. But the argument order to the 3-way merge program "merge" is to have the original in the middle. Don't ask me why. Anyway, another example: [EMAIL PROTECTED]:~/merge-test> merge-cache cat MM This is MM from the original tree. # original This is modified MM in the branch A. # merge1 This is modified MM in the branch B. # merge2 This is modified MM in the branch B. # current contents or [EMAIL PROTECTED]:~/merge-test> merge-cache cat AA MM cat: : No such file or directory This is added AA in the branch A. This is added AA in the branch B. This is added AA in the branch B. fatal: merge program failed where the latter example shows how "merge-cache" will stop trying to merge once anything has returned an error (ie "cat" returned an error for the AA file, because it didn't exist in the original, and thus "merge-cache" didn't even try to merge the MM thing). Linus - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html