Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Welcome! Let's resolve a conflict #1

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

github-learning-lab[bot]
Copy link

Welcome to Managing Merge Conflicts 🎉

Hello, and welcome! If you're here to learn about and practice resolving merge conflicts, you're in the right place.

In this course, you'll learn why merge conflicts happen and solve a few of them. The merge conflicts in this course are simple enough to solve from GitHub.com. But, if you'd prefer, you can solve them using the command line or other local tools.

As an added bonus, the project we are using for this course is a resume hosted on GitHub Pages! So, if you want to keep working after you complete this course, please feel free!

Before starting this course, we recommend completing the Introduction to GitHub Learning Lab first.

Note: You may notice that some branches and pull requests already exist. We'll be using them in later activities in this course.

How merge conflicts happen

A Merge conflict occurs when changes are made to the same part of the same file on two different branches. You usually find out about conflicts in a pull request.

This can be intimidating, but have no fear, Git knows how to handle this! It only needs a human to decide how to resolve the conflict.

Step 1: Resolve a simple conflict

You may merge a lot of pull requests before you encounter your first merge conflict. That’s because Git is smart when it comes to merging. Unless you're paying close attention to other branches, you won't know about conflicts until you create a pull request.

This branch is a great example. In this scenario, two of our friends have been working in this repository. They both created branches, made changes to the _config.yml file, and opened pull requests. One pull request was merged to main without problems, but now the other pull request has a conflict.

The history of main and this branch look something like this:

deviated branches

Because this pull request changes the same lines in the _config.yml file, there is a merge conflict.

Let's help our friends resolve this conflict.

⌨️ Activity: Resolving your first merge conflict

  1. Open your preferred command line interface, which we'll call your shell from now on.

  2. Clone this repository:

    git clone https://github.com/steep-ctds/merge-conflicts.git
  3. Navigate to the repository in your shell:

    cd merge-conflicts
  4. Checkout to the update-config branch and ensure it is up to date:

    git checkout update-config
    git pull
  5. Merge the main branch into the update-config branch. To ensure that you're working with an up to date copy of main, we'll use its remote tracking branch:

    git merge origin/main
  6. In Git's response, you'll see the file with the conflict. Open it in your text editor.

  7. Look for the marked hunks that begin with <<<<<<< update-config and ends with >>>>>>> main. These markers are added by Git to show you the content that is in conflict.

  8. Remove the changes made on the main branch by deleting all of the content below the ======= and above >>>>>>> main.

  9. Next, remove the merge conflict markers by deleting the following lines:

    <<<<<<< update-config
    =======
     >>>>>>> main
    
  10. Save and close the file. Stage and commit your changes:

    git add .
    git commit -m "merge main into update-config"
  11. Push your merged branches to GitHub:

    git push

Sometimes, the best way to resolve a merge conflict is to add content that's from both branches, or even something that isn't on either! This is why Git needs a human to look at the code and make the proper fixes.


Watch below for my response.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant