Git Basics - Branching

Branching in Git streamlines development by allowing parallel lines of work, facilitating experimentation without risking the main codebase. It enhances collaboration, simplifies feature and fix management, and minimizes merge conflicts, leading to faster, more efficient project progress and higher code quality through isolated testing and review.

To create a new branch off of your main branch and ensure it stays up-to-date with main, you can follow these steps. This involves creating the branch, switching to it, and then periodically updating it with changes from main.

 

1. Create and Switch to the New Branch

First, make sure your local main branch is up-to-date with the remote main branch. Then, create your new branch off of main.

git

# Switch to your main branch

git checkout main 

# Update your local main branch

git pullorigin main 

# Create and switch to a new branch off of main

git checkout -b new-feature-branch 

2. Keep Your Branch Up-to-date with Main

Whenever you want to update your new branch with the latest changes from main, you'll need to first pull the changes into main and then rebase or merge those changes into your branch. Here are the steps for both methods:


Using Merge

git

# Switch to the main branch

git checkout main  

# Pull the latest changes

git pull origin main

# Switch back to your branch

git checkout new-feature-branch

# Merge changes from main into your branch

git merge main 
    

Using Rebase

Using rebase is an alternative approach that can keep your project history cleaner by applying your branch's commits on top of the main branch's current state. However, be cautious with rebasing if your branch is shared with others, as it rewrites commit history.

git
        
# Switch to the main branch

git checkout main

# Pull the latest changes

git pull origin main

# Switch back to your branch 

git checkout new-feature-branch

# Rebase your branch on top of main

git rebase main 
        
    

 

After merging or rebasing, if there are any conflicts, you'll need to resolve them. Once resolved and if you used rebase, continue the rebase process with git rebase --continue. If you've merged, simply commit the changes as you normally would.


Pushing Your Branch

After you've made changes to your new branch and you're ready to share or save them remotely, push your branch to the remote repository:

git

git push origin new-feature-branch

Keeping Your Branch Up-to-date

Repeat the process of merging or rebasing regularly as main gets updated. This practice reduces the potential for conflicts and ensures your feature branch works with the latest code.

Note

  • Merge vs. Rebase: Merge keeps the history of the main branch's changes in your branch, while rebase makes it as if you've just branched off the latest version of main, applying your changes on top of it. Choose based on your project's workflow preferences.
  • Shared Branches: If your branch is shared with others, prefer merging over rebasing to avoid rewriting history others may rely on.

Author: Richard Ford February 3, 2024, 8:55 PM