我在Rails项目中使用Rubymine。通常情况下,Rubymine在.idea/*文件中做了一些我并不关心的更改。但它一直阻止我查看新的分支,并使我的.idea版本与我的同事不同。

我们已经向.gitignore添加了.idea/,但它会跟踪.idea中的变化。我该怎么做才对呢?

下面是我得到的一个典型的错误消息:

error: Your local changes to the following files would be overwritten by checkout:
    .idea/workspace.xml

将.idea/*添加到排除列表中,以防止跟踪所有.idea文件、目录和子资源。


.idea/*怎么样?没有测试,但应该可以


只是.idea/对我来说很好


在rubymine gui中,有一个忽略列表(设置/版本控制)。也许可以试着在那里禁用它。我从他们的后勤人员那里得到了暗示。


将.idea添加到~/。Gitignore_global并按照这里的说明让.gitignore_global工作:

Git全局忽略不工作

这样你就不必把它添加到一个单独的.gitignore文件中。


对我来说,只有一个解决方案,删除。idea文件夹,而不是提交文件。gitignore“。然后再次使用IDE


如果Git已经在跟踪某个文件,那么将该文件添加到.gitignore不会阻止Git跟踪它。你需要先对有问题的文件进行git管理,然后添加到你的.gitignore中。

加上。idea/应该有用


在你的终端试试git rm -r——cached .idea。它禁用更改跟踪。


注意,JetBrains建议“如果你决定与其他开发人员共享IDE项目文件……”,跟踪所有的。idea/*文件,除了以下文件:

workspace.xml usage.statistics.xml tasks.xml 货架/目录

因此,为了遵循他们的建议,你可以将这些添加到你的。gitignore中。


来源:

如果您决定与其他开发人员共享IDE项目文件,请遵循以下原则: … 以下是你需要分享的内容: 除了workspace.xml、usage.statistics.xml和tasks.xml文件以及存储用户特定设置的shelf目录外,项目根目录。idea目录下的所有文件 …

如何管理版本控制系统下的项目(存档)

那一页上有一些额外的注释和讨论,如果你考虑继续做这个,你应该读一下, 包括你可能想要gitignore的额外文件,即使你决定要共享IDE文件(例如。iml文件,.idea/modules.xml, gradle.xml,用户字典文件夹,从gradle或maven生成的额外文件)。


我建议阅读git手册页,以充分理解忽略是如何工作的,将来你会感谢我的;)

与你的问题相关的:

Two consecutive asterisks ("**") in patterns matched against full pathname may have special meaning:

A leading "**" followed by a slash means match in all directories. For example, "**/foo" matches file or directory "foo" anywhere, the same     as pattern "foo". "**/foo/bar" matches file or directory "bar" anywhere that is directly under directory "foo".

A trailing "/**" matches everything inside. For example, "abc/**" matches all files inside directory "abc", relative to the location of the .    gitignore file, with infinite depth.

A slash followed by two consecutive asterisks then a slash matches zero or more directories. For example, "a/**/b" matches "a/b", "a/x/b",     "a/x/y/b" and so on.

Other consecutive asterisks are considered invalid.

JetBrains在GitHub上有一个.gitignore_global。


您可以使用gitignore进行高级gitignore文件生成。它是快速,简单和前沿标签自动生成为您。

使用这个链接的大多数jetbrains软件(intelij, phpstorm…) Jetbrains .gitignore文件

(编辑)

下面是为Jetbrains软件生成的gitignore文件,这将防止您共享任何Jetbrains软件用于管理项目的敏感信息(密码,密钥库,数据库密码…)

# Created by https://www.gitignore.io

### Intellij ###
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm

*.iml

## Directory-based project format:
.idea/
# if you remove the above rule, at least ignore the following:

# User-specific stuff:
# .idea/workspace.xml
# .idea/tasks.xml
# .idea/dictionaries

# Sensitive or high-churn files:
# .idea/dataSources.ids
# .idea/dataSources.xml
# .idea/sqlDataSources.xml
# .idea/dynamic.xml
# .idea/uiDesigner.xml

# Gradle:
# .idea/gradle.xml
# .idea/libraries

# Mongo Explorer plugin:
# .idea/mongoSettings.xml

## File-based project format:
*.ipr
*.iws

## Plugin-specific files:

# IntelliJ
/out/

# mpeltonen/sbt-idea plugin
.idea_modules/

# JIRA plugin
atlassian-ide-plugin.xml

# Crashlytics plugin (for Android Studio and IntelliJ)
com_crashlytics_export_strings.xml
crashlytics.properties
crashlytics-build.properties

生成的代码也有很好的注释。 希望能有所帮助。


我试着把这些文件添加到我的。gitignore,它是无用的…

然而,正如Petr Syrov所说,你可以使用git rm -r——cached .idea到你的终端,这些文件将不再是一个问题!


关闭PHP Storm 在终端转到项目文件夹 类型

git rm -rf .idea; git commit -m "delete .idea"; git push;

然后进入项目文件夹,删除文件夹。idea

sudo rm -r .idea/

启动PhpStorm,你就完成了


在你的终端上使用git rm -r——cached .idea非常适合我。它禁用了更改跟踪,并取消了rubymine文件夹(idea/)下的许多文件的设置,然后我可以添加并提交给git,从而消除了比较,并允许.idea/的gitignore设置工作。


使用.ignore plugin: https://plugins.jetbrains.com/plugin/7495--ignore

它为你自动管理许多路径/模式,也有许多有用的额外功能。它兼容:

IntelliJ IDEA PhpStorm WebStorm PyCharm RubyMine 本地 CLion GoLand DataGrip 骑手 国会议员 Android工作室


虽然我切换到Rubymine的时间并不长,但我发现忽略Rubymine的.idea文件并将其提交给git是一件很有挑战性的事情。

以下是我的解决方法

如果你根本没有做过任何分期/提交,或者你刚刚在我的Ruby中启动了一个新项目,那么就简单地这样做

选项1

将下面的代码行添加到.gitignore文件中,该文件通常位于存储库的根目录。

# Ignore .idea files
.idea/

这将确保git忽略所有的。idea文件,尽管它们仍然保留在本地的项目文件夹中。

选项2

如果你已经做了一些分期/提交,或者你刚刚在Ruby我的开发中打开了一个现有的项目,那么就简单地这样做

在终端/命令行中运行代码

git rm -r --cached .idea

这将删除git中已经跟踪的。idea文件

接下来,将.idea/包含到.gitignore文件中,该文件通常位于存储库的根目录。

# Ignore .idea files
.idea/

这将确保git忽略所有的。idea文件,尽管它们仍然保留在本地的项目文件夹中。

选项3

如果你已经做了一些staging/commit,或者你刚刚在Ruby mine中打开了一个现有的项目,并且想在本地和git中完全删除.idea文件,那么就简单地这样做

在终端/命令行中运行代码

git rm -r --cached .idea

这将删除git中已经跟踪的。idea文件

在终端/命令行中运行代码

rm -r .idea

这将删除包括本地文件夹在内的所有。idea文件

接下来,将.idea/包含到.gitignore文件中,该文件通常位于存储库的根目录。

# Ignore .idea files
.idea/

这将确保git忽略所有的。idea文件,并从本地项目文件夹中删除。

这是所有

我希望这对你们有帮助


如果您已经进行了初始提交,并且您的.idea文件在git中显示为新文件,那么您需要先删除这些文件,然后再提交它们。以下步骤将达到目的

 1. git rm --cached -r .idea/
 2. Add .idea/ to **.git/info/exclude** or **.gitignore**
 3. git commit -m 'ignore .idea/ files'

在这个链接中有详细的解释: https://devconnected.com/how-to-clear-git-cache/


.gitignore,该文件用于显式指定Git应该忽略哪些文件或文件夹

在$HOME/中指定的忽略规则。gitignore_global、$ HOME /。config/git/ignore, $GIT_DIR/info/exclude, .gitignore在git存储库中都有效

.gitignore文件显式指定了哪些文件不应该被Git跟踪,即被Git忽略。在gitignore之前已经被Git跟踪的文件不受gitignore规则的影响。要停止跟踪Git已经跟踪的文件,请使用Git rm——cached .idea/命令


对于所有的JetBrains ide:

设置>编辑器>文件类型>被忽略的文件和文件夹,按+号添加。idea到被忽略列表。

或者,添加到.gitignore(用于提交)或.git/info/exclude(用于本地)行。idea/。