刚才我提交并推送了一些东西(是的,我在推送时犯了错误),我决定我应该“恢复”或“撤消”。所以我被告知在我这边发出 git reset --soft HEAD^ ,我认为这会以某种方式创建一个“还原”提交,一旦提交就会使它就像从未发生过更改一样。我不介意变化的历史是否存在,这正是我想象中会发生的事情。
无论如何,完成后我再次提交,然后当我尝试推送时我得到了非快进错误。现在,我知道我在重置时搞砸了一些事情,我的树和原始树现在“不匹配”,但我想知道如何解决这个问题。现在我只想回到发出重置之前的时间,这样我就可以通过手动取出更改然后提交来手动恢复更改,除非其他人可以推荐恢复推送提交的正确方法,并且通过这并不是说历史必须从日志或任何东西中消失。
最佳答案
虽然我的回答超出了你的要求,但我认为这实际上是你打算做的。
您使用 git reset --soft HEAD^ 撤消了您所做的提交。这会将工作副本返回到您提交之前的状态(因为 HEAD 指向您当前的提交,而 HEAD^ 指向它之前的那个(假设只有一个父级).
但是现在当你 git push 时,你会被告知类似这样的事情:
! [rejected] <branch> -> <branch>e (non-fast-forward)
error: failed to push some refs to 'ssh://<remote server>/<remote path>'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
这就是说提交没有对齐,这是为了防止您犯错。错误消息有点误导,你不想按照它的建议去做( pull 你的分支同步)。由于您的意图,您只能知道不这样做。
您可以简单地使用 --force(或 -f)(*) 来解决这个问题:
git push --force
您可能需要重新设置上游:
git push --force --set-upstream origin <branch>
请注意,如果其他人已经撤回了您的工作,这将产生影响,因为会有不同的提交(可能)进行相同的更改。参见 https://www.kernel.org/pub/software/scm/git/docs/user-manual.html#problems-With-rewriting-history .
为了防止出现任何问题,只推送到您的分支(而不是一些公共(public)分支 - 例如 development 分支,开发人员将其所有功能分支 merge 到其中)并确保有 在您的团队中开放沟通。
开发人员通常将这种模式用于我所说的星期五下午提交,您希望在周末之前保存您的工作以防硬件故障(但返回到周一的预提交状态)。
*Friday*
git add --all # To add all files whether they are tracked or not
git commit -m "Friday afternoon commit"
git --set-upstream push # --set-upstream is for if the branch doesn't exist on the remote server
*Monday*
git reset --soft HEAD^
git push -f --set-upstream origin <branch>
与另一个答案中讨论的 git revert 相比,这样做的好处是避免了额外的提交。重置将有 2 次提交,而这种方式将没有(没有额外的)。 git reset 的优点是它不会重写历史,因此更安全,尤其是当您不确定自己在做什么时。
(*) 通常,存储库被配置为不允许您这样做来掌握 - 修复一个分支并创建一个 pull 请求。因为如果您已经阅读了上面的链接,那么在 master 上重写历史将产生严重的后果(除非您是唯一克隆该代码的人)。
关于git - git reset 后无法推送 --soft HEAD^,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2016543/
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
我在pry中定义了一个函数:to_s,但我无法调用它。这个方法去哪里了,怎么调用?pry(main)>defto_spry(main)*'hello'pry(main)*endpry(main)>to_s=>"main"我的ruby版本是2.1.2看了一些答案和搜索后,我认为我得到了正确的答案:这个方法用在什么地方?在irb或pry中定义方法时,会转到Object.instance_methods[1]pry(main)>defto_s[1]pry(main)*'hello'[1]pry(main)*end=>:to_s[2]pry(main)>defhello[2]pry(main)
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
GivenIamadumbprogrammerandIamusingrspecandIamusingsporkandIwanttodebug...mmm...let'ssaaay,aspecforPhone.那么,我应该把“require'ruby-debug'”行放在哪里,以便在phone_spec.rb的特定点停止处理?(我所要求的只是一个大而粗的箭头,即使是一个有挑战性的程序员也能看到:-3)我已经尝试了很多位置,除非我没有正确测试它们,否则会发生一些奇怪的事情:在spec_helper.rb中的以下位置:require'rubygems'require'spork'
我正在学习http://ruby.railstutorial.org/chapters/static-pages上的RubyonRails教程并遇到以下错误StaticPagesHomepageshouldhavethecontent'SampleApp'Failure/Error:page.shouldhave_content('SampleApp')Capybara::ElementNotFound:Unabletofindxpath"/html"#(eval):2:in`text'#./spec/requests/static_pages_spec.rb:7:in`(root)'