在ruby脚本中,如何让git打开它的消息编辑器
我目前正在开发一个命令行ruby gem,它可以自动化https://gist.github.com/jbenet/ee6c9ac48068889b0912中讨论的“rebase + no-ff merge”工作流程。 您可以在https://github.com/gsmendoza/git_pretty_accept/tree/git_pretty_accept找到此gem的WIP代码。 gem会做这样的事情:
git co master git pull git co pull_request git rebase master git co master git merge --edit --no-ff pull_request git push git branch -d pull_request git push origin:pull_request
当我尝试通过ruby运行这些git命令时, git merge --edit --no-ff pull_request
不会像我希望的那样打开git commit消息编辑器。 相反,我认为git只是从编辑器收到一个空白的合并消息,而ruby继续使用脚本的其余部分。
有任何想法吗?
只需阅读您的代码 。
`git merge --no-ff --message "#{merge_message}" #{branch}`
在Ruby中,这种反引号语法重定向STDIN和STDOUT。
只需尝试这样做:
system("git merge --edit --no-ff #{branch}")
system
函数只是分叉一个进程并等待子进程完成,而不触及STDIN / STDOUT。 我测试过它的确有效。