Am 18.10.2011 00:33, schrieb Junio C Hamano: > 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. Makes sense. > 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. It's not about never supporting anything else, but right now we are scratching our own itch ;-) > 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. If you configure diff.ignoreSubmodules=all and fetch.recurseSubmodules=false and write a script fetching and checking out the branch(es) of your choice in the submodule(s) you run each time you want to update the branch tip there, you should be almost there with current Git. But yes, we could do better. > 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. Yup. And the presence of the "branch" config could tell "git submodule update" to fetch and advance that branch to the tip every time it is run. And it could tell the diff machinery (which is also used by status) to ignore the differences between a submodule's HEAD and the SHA-1 in the superproject (while still allowing to silence the presence of untracked and/or modified files by using the diff.ignoreSubmodules option) and fetch would just stop doing any on-demand action for such submodules. Anything I missed? > 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. Me neither, e.g. the SHA-1 which was the submodules HEAD when it was added should do nicely. And that would avoid referencing a non-existing commit in case you later want to turn a floating submodule into an exact one. -- 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