Git Conflict Management
Scenario: You have a merge conflict
Unfortunately github can’t handle this in browser.
It is up to the lord of the repository (you) to handle this.
Say you have a pull request from the branch problemBranch
with a merge conflict to master:
data:image/s3,"s3://crabby-images/7ef60/7ef60485ac696561e7d8647d9fe52e745c7905ea" alt="conflict message"
Steps to handle:
1) Go to the command line and enter your repo’s directory:
cd path/to/project/
2) Make sure everything is up to date with the github hosted repo:
git pull
3) Make a branch to handle the merge conflict:
git checkout -b HR_Department origin/problemBranch
4) Merge with the master to see problems:
git merge master
Git ever so kindly automatically modifies the files with conflicts in them to point out where they overlap. (If you want to see a list of the files that have this problem simply run the command git diff --name-only --diff-filter=U
.)
Now head to the file (or files) in question to see the conflict.
data:image/s3,"s3://crabby-images/9e679/9e679168dc691f747c6ba389025e8022a7f1d6d0" alt="conflict"
Starting at the <<<<<<<
we have the line as it is in the new branch and after the =======
we have the line as it is in the branch we are attempting to merge into, the whole conflict is ended by >>>>>>>
.
At this point you must decide which line to keep (, or include both of them) and edit the text manually.
data:image/s3,"s3://crabby-images/6a1dc/6a1dc3ae76bf7f1fb9258b5343624e845370fbb9" alt="conflict"
5) Now merge the conflict free branch to master. You can do this in either the github interface (see previous) or the command line:
git checkout master
git merge --no-ff HR_Department
git push origin master
6) Revel in the seamlessly modified code.