This series introduces a few new FAQ entries on various topics. Changes from v1: * Fix typos in commit messages. * Talk about case-insensitive file names, not files, to avoid ambiguity. * Warn people about rebases. * Switch from "long-running" to "long-lived" and explain the situation more clearly without relying on people understanding the meaning of the adjective. brian m. carlson (3): docs: explain why squash merges are broken with long-running branches docs: explain why reverts are not always applied on merge docs: explain how to deal with files that are always modified Documentation/gitfaq.txt | 86 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) Diff-intervalle contre v1 : 1: c4f3e6e19c ! 1: 9f8f348fa8 docs: explain why squash merges are broken with long-running branches @@ Commit message 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 + experienced developers may make this mistake, so let's add a FAQ entry explaining why this is problematic and explaining that regular merge commits should be used to merge two long-running branches. @@ Documentation/gitfaq.txt: How do I know if I want to do a fetch or a pull?:: +-------------------- + +[[long-running-squash-merge]] -+What kinds of problems can occur when merging long-running branches with squash merges?:: ++What kinds of problems can occur when merging long-lived 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. ++ merges to merge two branches multiple times. 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. ++ +When Git does a normal merge between two branches, it considers exactly three +points: the two branches and a third commit, called the _merge base_, which is +usually the common ancestor of the commits. The result of the merge is the sum +of the changes between the merge base and each head. When you merge two -+long-running branches with a regular merge commit, this results in a new commit -+which will end up as a merge base when they're merged again, because there is -+now a new common ancestor. Git doesn't have to consider changes that occurred -+before the merge base, so you don't have to re-resolve any conflicts you -+resolved before. ++branches with a regular merge commit, this results in a new commit which will ++end up as a merge base when they're merged again, because there is now a new ++common ancestor. Git doesn't have to consider changes that occurred before the ++merge base, so you don't have to re-resolve any conflicts you resolved before. ++ +When you perform a squash merge, a merge commit isn't created; instead, the +changes from one side are applied as a regular commit to the other side. This @@ Documentation/gitfaq.txt: How do I know if I want to do a fetch or a pull?:: +diff`, `git log`, or a GUI will result in showing all of the changes since the +original merge base. ++ -+As a consequence, if you want to merge two long-running branches, it's best to -+always use a regular merge commit. ++As a consequence, if you want to merge two long-lived branches repeatedly, it's ++best to always use a regular merge commit. + Hooks ----- 2: 645798d18b ! 2: 248d7e7b4b docs: explain why reverts are not always applied on merge @@ Commit message A common scenario is for a user to apply a change to one branch and cherry-pick it into another, then later revert it in the first branch. This results in the change being present when the two branches are - merge, which is confusing to many users. + merged, which is confusing to many users. We already have documentation for how this works in `git merge`, but it is clear from the frequency with which this is asked that it's hard to @@ Commit message ## Documentation/gitfaq.txt ## @@ Documentation/gitfaq.txt: original merge base. - As a consequence, if you want to merge two long-running branches, it's best to - always use a regular merge commit. + As a consequence, if you want to merge two long-lived branches repeatedly, it's + best to always use a regular merge commit. +[[merge-two-revert-one]] +If I make a change on two branches but revert it on one, why does the merge of those branches include the change?:: @@ Documentation/gitfaq.txt: original merge base. +If this is a problem for you, you can do a rebase instead, rebasing the branch +with the revert onto the other branch. A rebase in this scenario will revert +the change, because a rebase applies each individual commit, including the -+revert. ++revert. Note that rebases rewrite history, so you should avoid rebasing ++published branches unless you're sure you're comfortable with that. See the ++NOTES section in linkgit:git-rebase[1] for more details. + Hooks ----- 3: 10ad244b1e ! 3: e2495d4358 docs: explain how to deal with files that are always modified @@ Metadata ## Commit message ## docs: explain how to deal with files that are always modified - Users frequently have problems where two files differ only in case, + Users frequently have problems where two filenames differ only in case, causing one of those files to show up consistently as being modified. Let's add a FAQ entry that explains how to deal with that. @@ Documentation/gitfaq.txt: information about how to configure files as text or bi + Internally, Git always stores file names as sequences of bytes and doesn't + perform any encoding or case folding. However, Windows and macOS by default + both perform case folding on file names. As a result, it's possible to end up -+ with multiple files or directories that differ in case. Git can handle this -+ just fine, but the file system can store only one of these files, so when Git -+ reads the other file to see its contents, it looks modified. ++ with multiple files or directories whose names differ only in case. Git can ++ handle this just fine, but the file system can store only one of these files, ++ so when Git reads the other file to see its contents, it looks modified. ++ +It's best to remove one of the files such that you only have one file. You can +do this with commands like the following (assuming two files `AFile.txt` and