On Sat, 12 Sep 2020 at 22:52, brian m. carlson <sandals@xxxxxxxxxxxxxxxxxxxx> wrote: > > In many projects, squash merges are commonly used, primarily to keep a > tidy history in the face of developers who do not use logically > independent, bisectable commits. As common as this is, this tends to > cause significant problems when squash merges are used to merge > long-running branches due to the lack of any new merge bases. Even very > experienced developers may make this mistakes, so let's add a FAQ entry s/mistakes/mistake/ > explaining why this is problematic and explaining that regular merge > commits should be used to merge two long-running branches. > +What kinds of problems can occur when merging long-running branches with squash merges?:: > + In general, there are a variety of problems that can occur when using squash > + merges with long-running branches. These can include seeing extra commits in > + `git log` output, with a GUI, or when using the `...` notation to express a > + range, as well as the possibility of needing to re-resolve conflicts again and > + again. Very well-written, as always. I grepped around a little and couldn't find that we're using this "long- running branch" notion anywhere. I think it might make sense to define/explain that somewhere early, e.g., with something like "... merged repeatedly ... more development...". So in particular, a "long-running" branch is not something like I branched off a long time ago, I've been hacking on this feature for a long time and the branch has run quite long with lots of commits. Now it's time to merge it and be done with it! Once that piece of background is in place, what you have here reads very well to me. It was only somewhere halfway through the second paragraph that I got what you meant by "long-running branch". Martin