Ok, over the last week or so, I've been having a lot more content conflicts than usual, mostly because of (a) just the fact that the way the merge window happens for the kernel these days, rather than have incremental small merges, we often end up having lots of big ones. and (b) I ended up merging a few trees that had lots of small changes all over, notably to header files having their <config.h> include removed, causing trivial conflicts. Now, the good news is that I have to say that our conflict resolution rocks. It's all been _very_ easy to do. In fact, it's been even more pleasant than BK was, because of one big issue: you could resolve the conflict in the tree, then _test_ it (perhaps just compile-test it), and commit the resolved result separately. With BK, you had to resolve and commit atomically, and you never had access to a "preliminary resolve" to test. However, I also notived one particular thing that I did that we make less than perfectly easy. One thing that is _very_ useful to do is to do when you have a conflict is this: git log -p HEAD MERGE_BASE..MERGE_HEAD -- conflicting-filename because this shows all the changes (with their explanations) for that filename since the MERGE_BASE in _both_ branches you're trying to merge. This simple command really makes conflict resolution a hell of a lot easier, because you can see what caused the conflict, and you get a real feel for what both branches were doing, making it a _lot_ more likely that you actually do the right thing. Now, the downside is that the above is both a pain to type, and we don't actually even save the MERGE_BASE as a head, so you actually have to compute it yourself. It's easy enough to do: git-merge-base HEAD MERGE_HEAD > .git/MERGE_BASE will do it, but the fact is, we should make this even easier. In fact, after writing the above a few times, I really think there's a case for making a helper function that does exactly the above for us. Including all the "conflicting-filename" thing. It would be nice if git log -p --merge [[--] filenames...] would basically expand to git log -p HEAD MERGE_HEAD ^$(git-merge-base HEAD MERGE_HEAD) -- $(git-ls-files -u [filenames...]) so that I wouldn't have to type that by hand ever again, and doing a git log -p --merge drivers/ would automatically give me exactly that for all the unmerged files in drivers/. Anybody want to try to make me happy, and learn some git internals at the same time? Linus - : 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