简体   繁体   中英

Git push with or without force

Deleting a remote branch is done with:

git push origin :master

If the local is behind the remote it needs to be done with:

git push --force origin :master

But what does it mean to force a delete of eg master based on where the local master is pointing at? You will not be deleting where master is pointing to in the remote.

The :branch refspec is the syntax for pushing a branch deletion , also written as:

git push origin --delete <branchName>

This isn't to be mixed up with git push : , where the ' : ' stand for "matching branch" .

The --force is used for the case where a local branch has a different history than its remote counterpart ( upstream branch ).

For example, if you rebase master , its history would change and you would need --force to push it.


You will not be deleting where master is pointing to in the remote.

No, you will be deleting the branch itself (in the remote repo), not the commits of that branch in the remote repo.
if those commits are no longer referenced by any branch, they will become "invisible" (soft delete), but will still be accessible through a git reflog executed in that remote repo (on the remote server).

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM