让git忽略vim在所有目录中生成的临时文件的正确方法是什么(无论是跨系统全局的还是单个项目的本地的)?


当前回答

在“git commit”之前退出vim。

要使vim使用其他文件夹作为备份文件(例如/tmp):

set bdir-=.
set bdir+=/tmp

要使vim停止使用当前文件夹的。swp文件:

set dir-=.
set dir+=/tmp

使用-=,+=通常会很好,因为vim对bdir, dir有其他默认值,我们不想全部清除。查看vim帮助以获得更多关于bdir, dir的信息:

:h bdir
:h dir

其他回答

或者,您可以配置vim以将交换文件保存到单独的位置, 例如,在你的.vimrc文件中添加如下代码行:

set backupdir=$TEMP//
set directory=$TEMP//

有关更多信息,请参阅这个vim技巧。

如果您正在使用源代码控制。Vim临时文件非常无用。 因此,您可能希望配置vim不创建它们。

只需编辑您的~/。Vimrc并添加这些行:

set nobackup
set noswapfile

肯定的是,

只需要创建一个“。Gitignore”在项目的主目录上 并且必须控制

*.swp

就是这样

在一个命令中

project-home-directory$ echo '*.swp' >> .gitignore

正如Alex Moore-Niemi所指出的,这适用于Mac:

set backupdir=$TMPDIR//
set directory=$TMPDIR//

确保使用TMPDIR而不是TEMPDIR。

在我的情况下,临时文件已经被之前的操作提交了,所以修改.gitignore不会影响那些提交的文件…,你必须git rm files_to_be_ignored——先缓存,然后提交,然后DONE。