Heiko Voigt <hvoigt@xxxxxxxxxx> writes: > since we have not heard anything from Fredrik I will probably look into > cleaning this up. Should I do that with follow-up patches since this > patch is already in next? I thought we kicked it back to 'pu' after 1.7.7 cycle. I would personally want to put a freeze on "recursively do anything to submodule" topic (including but not limited to "checkout") for now, until we know how we would want to support "floating submodule" model. For existing code in-flight, I would like to see us at least have a warm and fuzzy feeling that we know which part of the code such a support would need to undo and how the update would look like before moving forward. There are two camps that use submodules in their large-ish projects. One is mostly happy with the traditional "submodule trees checked out must match what the superproject says, otherwise you have local changes and the build product cannot be called to have emerged from that particular superproject commit" model. Let's call this "exact submodules" model. The other prefers "submodule trees checked out are whatever submodule commits that happen to sit at the tips of the designated branches the superproject wants to use" model. The superproject tree does not exactly know or care what commit to use from each of its submodules, and I would imagine that it may be more convenient for developers. They do not have to care the entire build product while they commit---only the integration process that could be separate and perhaps automated needs to know. We haven't given any explicit support to the latter "floating submodules" model so far. There may be easy workarounds to many of the potential issues, (e.g. at "git diff/status" level, there may be some configuration variables to tell the tools to ignore differences between the commit the superproject records for the submodule path and the HEAD in the submodule), but with recent work on submodules such as "allow pushing superproject only after submodule commits are pushed out", I am afraid that we seem to be piling random new things with the assumption that we would never support anything but "exact submodules" model. Continuing the development that way would require retrofitting support for "floating submodules" model to largely undo the unwarranted assumptions existing code makes. That is the reason why I would like to see people think about the need to support the other "floating submodules" model, before making the existing mess even worse. The very first step for floating submodules support would be relatively simple. We could declare that an entry in the .gitmodules file in the superproject can optionally specify which branch needs to be checked out with something like: [submodule "libfoo"] branch = master path = include/foo url = git://foo.com/git/lib.git and when such an entry is defined, a command at the superproject level would largely ignore what is at include/foo in the tree object recorded in the superproject commit and in the index. When we show "git status" in the superproject, instead of using the commit bound to the superproject, we would use include/foo/.git/HEAD as the basis for detecting "local" changes to the submodule. We could even declare that the gitlink for such a submodule should record 0{40} SHA-1 in the superproject, but I do not think that is necessary. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html