Open In App

How Delete a Git Branch Locally and Remotely?

Last Updated : 02 Jul, 2024
Comments
Improve
Suggest changes
Like Article
Like
Report

In Git, branches are an important part of the workflow, allowing developers to work on different features, bug fixes etc. without affecting the main codebase. However, once a branch has served its purpose, it is a good practice to delete it to keep the repository clean and organized. This article will guide you through the steps to delete a Git branch both locally and remotely.

Delete a Git Branch Locally 

Git won’t allow you to delete a Git branch you are currently working on. So you must make sure to checkout to a branch that you are NOT deleting. For this use the command:

Syntax

git checkout <branch-name>

Here we will check out our main branch from my test branch.

Checkout

Now in order to delete the test branch locally, we use the command :

Syntax

git branch -d <branch-name>

We will delete my test branch as an example.

Delete Branch Locally

Note: The -d option will delete the branch only if it has already been pushed and merged with the remote branch. If you want to forcefully delete a branch you will have to use the -D option instead. The -D flag is synonymous with –delete –force. This will forcefully delete the branch even if it hasn’t been pushed or merged with the remote. the full command is:

Syntax

git branch -D <branch-name>

With this, we can successfully delete a local branch.

Delete a Git Branch Remotely

You can’t use the git branch command to delete a remote branch. Instead, you have to use the git push command with the –delete flag, followed by the name of the branch that you want to delete. You also need to specify the remote name (origin in this case) after “git push”. The command is as follows:

Syntax

git push <remote-name> --delete <branch-name>

Here I will delete my test branch in my remote repository as shown below.

Delete Branch Remotely

This command will delete the branch remotely. You can also use the shorthand:

Syntax

git push <remote-name> :<branch-name>

As you can see my remote branch is no more in my GitHub repo:

Deleted From GitHub

With this, we have successfully deleted our remote branch. A common error faced by many in this step is:

error: unable to push to unqualified destination: remoteBranchName The destination refspec neither matches an existing ref on the remote nor begins with refs/, and we are unable to guess a prefix based on the source ref. error: failed to push some refs to ‘git@repository_name’

This means that someone has already deleted the branch that you want to delete. If this happens you can use the following command to synchronize your branch list in the local environment:

Syntax

git fetch -p

The -p flag here means “prune”. After fetching the branches which no longer exist remotely will be deleted in your local working environment. 

Local Deletion vs Remote Deletion

Action Local Deletion Remote Deletion
Command git branch -d branch-name git push origin --delete branch-name
Force Deletion git branch -D branch-name git push origin :branch-name
Purpose Removes branch from local repository Removes branch from remote repository
Safety -d flag is safer, prevents unintentional deletion Must ensure the branch is not needed anymore

Conclusion

Removing the branches which are not important keeps the repository organized, improves collaboration, and makes sure a better development workflow. However, it’s important to exercise caution when deleting branches, especially remote branches, as it may impact ongoing work by other team members. Therefore, always communicate with your team and verify that the branch is no longer required before proceeding with deletion.



Next Article
Article Tags :

Similar Reads