使用PHPStorm,我试图忽略workspace.xml,每次我尝试进行git提交时,它都会弹出。
我的。gitignore看起来像:
/.idea/
.idea/workspace.xml
因为在提交文件时,我还执行了:
Git rm——缓存。idea/workspace.xml,然后提交删除,推到一个裸repo。
但是当我在项目中进行更改时,该文件一直弹出。
你知道我错过了什么吗?
使用PHPStorm,我试图忽略workspace.xml,每次我尝试进行git提交时,它都会弹出。
我的。gitignore看起来像:
/.idea/
.idea/workspace.xml
因为在提交文件时,我还执行了:
Git rm——缓存。idea/workspace.xml,然后提交删除,推到一个裸repo。
但是当我在项目中进行更改时,该文件一直弹出。
你知道我错过了什么吗?
当前回答
要在不影响IDE配置的情况下从git中完全删除.idea/,你可以这样做:
git rm -r --cached '.idea/'
echo .idea >> .gitignore
git commit -am "removed .idea/ directory"
其他回答
要在不影响IDE配置的情况下从git中完全删除.idea/,你可以这样做:
git rm -r --cached '.idea/'
echo .idea >> .gitignore
git commit -am "removed .idea/ directory"
在你看到文件出现的同一个目录下:
rm .idea / workspace.xml Git rm -f .idea/workspace.xml(由Chris vdp建议) vi .gitignore i(要编辑),在其中一行中添加.idea/workspace.xml, Esc,:wq
你现在应该没事了
只是想分享一下我的经验。
无论我尝试什么,我都有同样的问题,但我正在进行的回收如你所期望的那样在顶层生成了一个.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
我用PHPStorm也遇到了同样的问题
最后我解决了以下问题:
删除.idea/ directory 移动.gitignore到同一层将是新生成的.idea/ 写你需要被忽略的文件,和。idea/ too。为了确保它会被忽略,我写了以下内容: .idea / .idea .idea / *
我不知道为什么这样工作,也许.gitignore需要在同一级别的。idea可以忽略这个目录。
不太直观,但一旦我弄清楚就很容易修复:我将文件添加到.gitignore,然后在Commit选项卡的更改列表中恢复该文件。它不再出现了。
(我猜一旦IntelliJ自动将更改添加到git中,它将不再与.gitignore进行比较。一旦恢复,IntelliJ将在添加文件之前开始与.gitignore进行比较。)