Discard a local branch in Mercurial before it is p

2020-02-09 07:28发布

问题:

Many times it happens that I have few commits on my local Hg repository which I don't want to push and sometimes I want to remove the local branch altogether. But I cannot rollback more than one commit which leaves me no choice than creating a new clone and download the whole repository again. This feels stupid, since if I could just delete my local branch which has not affected the remote repository in anyway, then I wouldn't have to create and setup a new clone. So, is it how it is in Mercurial or is there some way to discard a local branch?

Thanks!

回答1:

If you enable the mq extension (bundled with Mercurial), you can use hg strip. Be careful, though, as this will modify the history of your repository. The safe method is to clone your repository up to the revision preceding the creation of the branch you want to discard, then to pull the remaining changesets that you want to keep.



回答2:

I know its too late but it may be useful for any one:

If your branch is not pushed yet.

  • First rollback changes hg rollback only if you have done commit but not yet pushed
  • Second run hg update --clean
  • Third run hg branch any-existing-branch
  • Fourth run hg pull -u


回答3:

If you find yourself doing this often perhaps you should be using bookmarks instead of named branches. http://stevelosh.com/blog/2009/08/a-guide-to-branching-in-mercurial/