On Tue, Jun 19, 2018 at 05:16:17PM +0200, Duy Nguyen wrote: > No actually, we could do better. Let me see if I can come up with a > patch or something... OK. What we currently do is, when we search for potential untracked paths for adding to the index, we unconditionally ignore anything inside ".git". For example, if "foo" is a submodule, "git add ." will visit "foo/.git" then ignore its content completely. We could do something very similar: when we visit "foo", if "foo/.git" exists, we ignore it as well. In other words, we extend from "ignore anything inside a git repository" to "ignore anything inside any other git worktree". The following patch basically does that. If you specify "git add foo/bar". It will still visit "foo" first, realize that it's a submodule and drop it. At the end, it will not report foo/bar as an untracked (i.e. add-able) entry, so you can't add it. I didn't test it extensively to see if it breaks anything though. And I might need to check how it affects untracked cache... -- 8< -- diff --git a/dir.c b/dir.c index fe9bf58e4c..8a1a5d8dd5 100644 --- a/dir.c +++ b/dir.c @@ -1672,6 +1672,17 @@ static enum path_treatment treat_one_path(struct dir_struct *dir, if (dtype != DT_DIR && has_path_in_index) return path_none; + if (dtype == DT_DIR) { + int path_len = path->len; + int is_submodule; + + strbuf_addstr(path, "/.git"); + is_submodule = is_directory(path->buf); + strbuf_setlen(path, path_len); + if (is_submodule) + return path_none; + } + /* * When we are looking at a directory P in the working tree, * there are three cases: -- 8< --