有些人(我认为在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
请停止?
好的,我有答案。现在我有另一个问题:
我可以把它放在~/.gitconfig
吗?从我最初看起来我不能,并且我没有看到任何有希望通过略读补丁。 (我想我仍然可以做别名。)
甚至可以为.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
您可以抑制两种更改通知。
第一个是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
更新:请参阅(和upvote)nilshaldenwang的answer,了解是否可以在.gitmodules
文件中添加一个用于忽略给定子模块的脏状态的配置参数。
ignore = dirty
所以git 1.7.2已经出来并包含了--ignore-submodules
的status
选项。
来自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'
正如你所提到的,补丁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”上查看更多信息。
你也可以使用
% git config [--global] submodule.ignore dirty
在你的submodule.ignore = dirty
文件中设置.git/config
。 --global
将在您的~/.gitconfig
中设置ignore标志并应用于您的所有存储库。如果没有它,它应该在.git/config
中设置你当前的回购。
我能找到的唯一文件是submodule.<name>.ignore
的git-config docs。我把它从一个.gitmodules文件移到我的〜/ .gitconfig中,它仍然适用于我。
你需要添加
ignore = dirty
到.gitmodules
$ git diff --ignore-submodules=dirty vendor # no output
$ git status --ignore-submodules=dirty vendor # On branch … nothing to commit (working directory clean)
# 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
您可能不想将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/