Git:我可以在status,diff等中禁止列出'modified content'/ dirty submodule条目吗?

问题描述 投票:114回答:9

有些人(我认为在1.6.x版本附近)git意识到了子模块内部的变化。那只会让我烦恼:

$ git status vendor | grep modified:
#       modified:   vendor/rails (modified content)
$ git diff vendor/
diff --git a/vendor/rails b/vendor/rails
--- a/vendor/rails
+++ b/vendor/rails
@@ -1 +1 @@
-Subproject commit 046c900df27994d454b7f906caa0e4226bb42b6f
+Subproject commit 046c900df27994d454b7f906caa0e4226bb42b6f-dirty

请停止?

Edit:

好的,我有答案。现在我有另一个问题:

我可以把它放在~/.gitconfig吗?从我最初看起来我不能,并且我没有看到任何有希望通过略读补丁。 (我想我仍然可以做别名。)

git git-submodules git-config
9个回答
161
投票

甚至可以为.gitmodules文件中的每个添加的子模块设置忽略模式。

就在今天,我遇到了这个问题,并在找到解决方案后立即在我的博客中写了一篇关于它的文章:How to ignore changes in git submodules

它的要点:

添加子模块后,存储库的根目录中会有一个名为.gitmodules的文件

只需在该.gitmodules文件中添加一行:

[submodule "bundle/fugitive"]
    path = bundle/fugitive
    url = git://github.com/tpope/vim-fugitive.git
    ignore = dirty

55
投票

您可以抑制两种更改通知。

第一个是untracked content,当您对子模块进行更改但尚未提交时,会发生这种情况。父存储库注意到这些,并且git status相应地报告它:

modified: modules/media (untracked content)

您可以使用以下方法来抑制

[submodule "modules/media"]
   path = modules/media
   url = [email protected]:user/media.git
   ignore = dirty

但是,一旦您提交了这些更改,父存储库将再次注意并相应地报告它们:

modified:   modules/media (new commits)

如果你想抑制这些,你需要忽略all的变化

[submodule "modules/media"]
   path = modules/media
   url = [email protected]:user/media.git
   ignore = all

49
投票

更新:请参阅(和upvote)nilshaldenwanganswer,了解是否可以在.gitmodules文件中添加一个用于忽略给定子模块的脏状态的配置参数。

ignore = dirty

所以git 1.7.2已经出来并包含了--ignore-submodulesstatus选项。

来自git help status

--ignore-submodules[=<when>]
    Ignore changes to submodules when looking for changes.
    <when> can be either "untracked", "dirty" or "all", which
    is the default. When "untracked" is used submodules are
    not considered dirty when they only contain untracked
    content (but they are still scanned for modified content).
    Using "dirty" ignores all changes to the work tree of
    submodules, only changes to the commits stored in the
    superproject are shown (this was the behavior before
    1.7.0). Using "all" hides all changes to submodules (and
    suppresses the output of submodule summaries when the
    config option status.submodulesummary is set).

我想要的价值是dirty

git status --ignore-submodules=dirty

我使用别名因为我很懒:

alias gst='git status --ignore-submodules=dirty'

11
投票

正如你所提到的,补丁git submodule: ignore dirty submodules for summary and status正在制作中。

也在Git 1.7.2-rc2发布中宣布:

Git v1.7.2 Release Notes (draft)
================================

Updates since v1.7.1
--------------------

git status”学会了“--ignore-submodules”选项。

含义:

git config --global diff.ignoreSubmodules dirty

关于这个选项并不完全是approach chosen for now

在本系列之后,我计划在ignore中添加一个配置选项'.gitmodules',可以为每个子模块设置为“all”,“dirty”,“untracked”或“none”(默认值)。

git diff”和“git status”将为每个子模块使用该配置值。 使用“--ignore-submodule”会覆盖此默认值(并且将添加新参数“none”以覆盖配置设置)。

并且为了避免每次选项更改时都必须执行“git submdule sync”,我想首先在.git/config中搜索它。 如果在那里找不到它,它将从.gitmodules中获取,如果存在的话。

因此,用户可以覆盖设置,但如果他们不这样做,上游可以轻松更改它(例如,当子模块.gitignore已更新,以便不再需要“ignore=untracked”时,可以将其删除)。 如果ignore中的'.gitmodules'条目在分支之间不同,那么切换分支也会立即生效。


git 2.13(2017年第2季度)提供了另一种使git状态(或任何git命令)忽略特定子模块的方法:

git config submodule.<name>.active false

在“Ignore new commits for git submodule”上查看更多信息。


10
投票

你也可以使用

% git config [--global] submodule.ignore dirty

在你的submodule.ignore = dirty文件中设置.git/config--global将在您的~/.gitconfig中设置ignore标志并应用于您的所有存储库。如果没有它,它应该在.git/config中设置你当前的回购。

我能找到的唯一文件是submodule.<name>.ignoregit-config docs。我把它从一个.gitmodules文件移到我的〜/ .gitconfig中,它仍然适用于我。


6
投票

你需要添加

ignore = dirty

到.gitmodules


2
投票

So git v1.7.2-rc2 has what I want:

$ git diff --ignore-submodules=dirty vendor
# no output
$ git status --ignore-submodules=dirty vendor
# On branch …
nothing to commit (working directory clean)

Building your own git howto:

# get git
git clone git://git.kernel.org/pub/scm/git/git.git git
cd git
git checkout v1.7.2-rc2

# make git. beware of setting prefix
make configure
./configure --prefix=/usr/local
make
sudo make install

# you REALLY don't want to `make doc`, use this instead
sudo make quick-install-man
sudo make quick-install-html

1
投票

您可能不想将ignore = dirty添加到.gitmodules,您可能希望对您希望忽略的更改更具选择性。

为此,将模式添加到.git/submodule_foo/bar/info/exclude,其中submodule_foo/bar/是子模块的路径。

模式类似于您将添加到.gitignore的模式,其中根是子模块目录。例如,此模式忽略子模块build中的submodule_foo/bar/目录:

# in .git/submodule_foo/bar/info/exclude:
/build/

1
投票

我已经更详细地回答了这个问题here

赶紧跑

git config --global diff.ignoreSubmodules dirty

添加本地配置选项以忽略这些更改。

© www.soinside.com 2019 - 2024. All rights reserved.