我在本地机器上做了一些更新,将它们推送到远程存储库,现在我试图将更改拉到服务器上,我得到了消息;
error: Your local changes to the following files would be overwritten by merge:
wp-content/w3tc-config/master.php
Please, commit your changes or stash them before you can merge.
所以我跑了,
git checkout -- wp-content/w3tc-config/master.php
再试一次,我得到了同样的信息。我假设w3tc更改了服务器上配置文件中的一些内容。我不关心本地副本或远程副本是否在服务器上(我认为远程副本是最好的),我只是希望能够合并我的其余更改(插件更新)。
什么好主意吗?
我遇到的情况是这样的:
错误:您对以下文件的本地更改将被merge覆盖:
wp-content / w3tc-config / master.php
请在合并之前提交您的更改或隐藏它们。
除了,在那之前,是遥远的:
实际上是这样的:
您对以下文件的本地更改将被merge覆盖:
一些/ file.ext
请在合并之前提交您的更改或隐藏它们。
发生的事情是(我认为,不是100%肯定)git post receive钩子开始运行,由于远程服务器存储库中的移动变化而搞砸了,理论上,不应该触及。
So what I ended up doing by tracing through the post-receive hook and finding this, was having to go to the remote repository on the server, and there was the change (which wasn't on my local repository, which, in fact, said that it matched, no changes, nothing to commit, up to date, etc.) So while on the local, there were no changes, on the server, I then did a git checkout -- some/file.ext and then the local and remote repositories actually matched and I could continue to work, and deploy. Not entirely sure how this situation occurred, though a couple dozen developers plus IT changes may had something to do with it.
要在解决此问题时记录新创建的文件:
如果你有新创建的文件,你可以创建一个本地更改的补丁,拉入远程合并,并在远程合并完成后应用你的本地补丁,如下所示:
进行本地更改。(不要承诺)。为新创建的文件创建补丁需要分段(因为它们仍然无法跟踪)
转到添加 。
创建一个补丁来保存记录
Git diff——缓存> myppatch .patch
丢弃本地更改并删除新的本地文件
Git重置——很难
把变化
git pull
应用补丁
去应用mypatch.patch
Git将合并更改,并为未合并的更改创建.rej文件。
根据Anu的建议,如果你在应用补丁时有问题,试试:
Git apply——reject——whitespace=fix myppatch .patch
本回答git: patch does not apply详细讨论了这个问题
享受您在特性上的持续工作,完成后提交您的局部更改。