【发布时间】:2010-10-14 12:22:48
【问题描述】:
通常,当我在 git 中切换分支时,如果文件在 emacs 中打开,那么即使内容相同,emacs 也会询问我是否要还原它们(因为它认为它们在磁盘上已更改)。
首先,如果磁盘上的内容与缓冲区中的内容相同,我想找到一种方法让 emacs 根本不询问我。
其次,我想要一个命令,它可以还原(不进行查询)我所有没有未保存更改的打开缓冲区,并询问我那些确实有未保存更改的缓冲区。
或者,我愿意接受有关我可以尝试的其他解决方案、工作方式等的建议。如果人们可以指点我从哪里开始,我会非常乐意编写 emacs-lisp。
PS 如果这很重要,我会在 OSX 上使用 Aquamacs。
编辑:
嗯,我发现 revbuffs 包正是我所需要的。当然足以阻止我想尝试自己写任何新东西。 (我将 revbuffs 映射到 Cmd-R,效果非常好。有点类似于其他 Mac 应用程序中的 Cmd-R)。
全局自动恢复模式本来是一个完美的解决方案,我希望我可以选择两个答案。我更喜欢 revbuffs 仅仅是因为一种可能是非理性的想要控制所发生的事情的感觉。
我猜想如果我从 emacs 中访问 git,那么它可能会更容易处理,但我目前更喜欢通过命令行访问 git。 (我使用 emacs 的时间还不够长,无法将其作为我的操作系统)。不过我会更彻底地调查一下 magit。
编辑2:
我已经使用 magit 一年了,强烈推荐它在 emacs 中处理 git。但是,每当我在 emacs 之外进行 rebase 时,我仍然使用 revbuffs。
【问题讨论】:
-
我知道这很古老,但我喜欢 Singletoned 的推理,并且在 github github.com/capitaomorte/revbufs 上有一点 revbufs 的 fork