使用PHPStorm,我试图忽略workspace.xml,每次我尝试进行git提交时,它都会弹出。

我的。gitignore看起来像:

/.idea/
.idea/workspace.xml

因为在提交文件时,我还执行了:

Git rm——缓存。idea/workspace.xml,然后提交删除,推到一个裸repo。

但是当我在项目中进行更改时,该文件一直弹出。

你知道我错过了什么吗?


当前回答

我也面临着同样的问题,它把我逼疯了。问题最终是.idea文件夹之前已经提交到repo中,所以不管你是否忽略它们,git都会跟踪它们。在关闭RubyMine/IntelliJ或任何你正在使用的IDE后,我推荐以下:

mv .idea ../.idea_backup
rm .idea # in case you forgot to close your IDE
git rm -r .idea 
git commit -m "Remove .idea from repo"
mv ../.idea_backup .idea

之后一定要忽略你的。gitignore中的。idea

尽管在存储库的.gitignore中忽略它就足够了,但我建议您全局地忽略IDE的dotfiles。

否则,您必须将它添加到您所从事的每个项目的每个.gitgnore中。此外,如果您与其他人合作,那么最好的做法是不要使用不特定于项目源代码的私有配置来污染项目的.gitignore。

其他回答

我刚才遇到了这个问题,我必须做git rm -f .idea/workspace.xml 现在它似乎不见了(我也不得不把它放进。gitignore)

我用PHPStorm也遇到了同样的问题

最后我解决了以下问题:

删除.idea/ directory 移动.gitignore到同一层将是新生成的.idea/ 写你需要被忽略的文件,和。idea/ too。为了确保它会被忽略,我写了以下内容: .idea / .idea .idea / *

我不知道为什么这样工作,也许.gitignore需要在同一级别的。idea可以忽略这个目录。

我在基于IntelliJ的Android Studio中所做的是这样的。在提交对话框中,我恢复了对workspace.xml的更改,然后将其移动到未版本控制的文件。之后,我从提交对话框中删除了这个。现在它不会出现在更改列表中。注意,我的gitignore已经包含了.idea/workspace.xml

只是想分享一下我的经验。

无论我尝试什么,我都有同样的问题,但我正在进行的回收如你所期望的那样在顶层生成了一个.idea,但.gitignore被放置在目录树下的一个文件夹中。

So:

.idea // On the level above the .gitignore file
application/
- .gitignore // too low to include .idea
- otherfile.js

所以我的解决方案是,我需要在repo的顶层创建一个.gitignore文件,然后我可以像预期的那样删除/ .idea文件夹,就像这样:

.gitignore // Now this can successfully target .idea below
.idea
application/
- .gitignore
- otherfile.js

忽略以.iws结尾的文件,以及.gitignore中的workspace.xml和tasks.xml文件 参考