aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--using-git.texinfo58
1 files changed, 58 insertions, 0 deletions
diff --git a/using-git.texinfo b/using-git.texinfo
index 2a952e8..a62fb0c 100644
--- a/using-git.texinfo
+++ b/using-git.texinfo
@@ -325,6 +325,7 @@ to the blessed repository.
@menu
* Workflow::
* Creating branches::
+* Merging branches::
@end menu
@@ -390,6 +391,63 @@ git checkout BRANCH_NAME
+@node Merging branches
+@section Merging branches
+
+The merge a branch into another, switch
+to one of them and pull the other:
+
+@example
+git checkout MERGER
+git pull . MERGEE
+@end example
+
+In the default mode, @command{git pull . MERGEE}
+is a short and fore a fetch and merge:
+
+@example
+git fetch MERGEE &&
+git merge MERGEE
+@end example
+
+If you two cannot be automatically merged,
+you will you get a merge conflict. A case
+where you will get merge conflicts is when
+one of the branches as made a modification
+where the other has change the indention,
+so keep to a coding style from the start;
+or both has edited the same lines.
+
+If you get a merge conflict, git will tell
+you so, in which files there are conflicts,
+and exit with the return code 1 to indicated
+that the merge was not successful and human
+intervention is required. If the merger
+branch as a file with the line
+@code{Hello world} and the mergee branch
+as the line @code{hello world!}, the
+file will contain:
+
+@example
+<<<<<<< HEAD
+Hello world
+=======
+wello world!
+>>>>>>> xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
+@end example
+
+Where
+@code{xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx}
+is the lower case hexadecimnal represention of
+the commit ID at the tip of the mergee branch,
+which is a SHA-1 hash sum of the commit.
+
+After a merge conflict you will need to stage
+the files and make a new commit.
+
+
+
+
@node GNU Free Documentation License
@appendix GNU Free Documentation License