我有两个分支:
当地分公司(和我一起工作的那家) 远程分支(公共的,只有经过良好测试的提交才会去那里)
最近我把我当地的分公司搞得一团糟。
如何将本地分支完全替换为远程分支,以便从远程分支现在所在的位置继续工作?
我已经搜索了SO,在本地签出到远程分支没有任何影响。
我有两个分支:
当地分公司(和我一起工作的那家) 远程分支(公共的,只有经过良好测试的提交才会去那里)
最近我把我当地的分公司搞得一团糟。
如何将本地分支完全替换为远程分支,以便从远程分支现在所在的位置继续工作?
我已经搜索了SO,在本地签出到远程分支没有任何影响。
当前回答
确保您已经签出了要替换的分支(来自Zoltán的评论)。 假设master是你要替换的本地分支,而“origin/master”是你想重置到的远程分支: Git重置-硬源/主
这会将您的本地HEAD分支更新为与origin/master相同的版本,并且——hard也会将此更改同步到索引和工作区中。
其他回答
选择的答案是绝对正确的,但它没有离开我与最新的提交/推送…
所以对我来说:
git reset --hard dev/jobmanager-tools
git pull ( did not work as git was not sure what branch i wanted)
因为我知道我想暂时将我的上游分支设置几个星期到一个特定的分支(与我之前切换到/签出并进行了硬重置的分支相同)
所以是AFTER reset
git branch --set-upstream-to=origin/dev/jobmanager-tools
git pull
git status ( says--> on branch dev/jobmanager-tools
转到结帐。
我总是使用这个命令将本地更改替换为存储库更改。 Git签出空间。
我有点惊讶居然没有人提到这一点;我几乎每天都用它:
git reset --hard @{u}
基本上,@{u}只是当前分支正在跟踪的上游分支的简写。例如,这通常等同于origin/[my-current-branch-name]。它很好,因为它是分支不可知的。
确保git首先获取远程分支的最新副本。
附注:在大多数shell中,命令会像写的那样工作,但如果你在PowerShell或csh中使用Git,你需要先转义特殊字符,尽管我也确认了它在这两种情况下都是作为字符串工作的,例如:
git reset --hard '@{u}'
它可以通过多种方式完成,继续编辑这个答案,以传播更好的知识视角。
1)硬复位
如果你从远程开发分支工作,你可以重置HEAD到远程分支上的最后一次提交,如下所示:
git reset --hard origin/develop
2)删除当前分支,并从远程存储库再次签出
考虑到,你正在本地回购中开发分支,这与远程/开发分支同步,你可以这样做:
git branch -D develop
git checkout -b develop origin/develop
3) 中止合并
如果你正处于一个糟糕的合并(错误地使用了错误的分支)之间,并且想要避免合并以返回到最新的分支,如下所示:
git merge --abort
4)取消重置
如果你处于一个糟糕的重基之间,你可以中止重基请求,如下所示:
git rebase --abort
丑陋但更简单的方法:删除本地文件夹,并再次克隆远程存储库。