On Wed, Oct 05, 2016 at 09:13:53AM -0700, Junio C Hamano wrote: > Heiko Voigt <hvoigt@xxxxxxxxxx> writes: > > >> It IS a hack, but having this information in .git<something> would > >> mean that it can be forced to be in machine readable form, unlike a > >> mention in README. I do not know if the .gitmodules/.gitignore > >> combination is a sensible thing to use, but it does smell like a > >> potentially useful hack. > > > > IIRC the tree entries are the reference for submodules in the code. We > > are iterating over the tree entries in many places so that change does > > not seem so easy to me. > > > > But you are right maybe we should stop arguing against this workflow and > > just let people use it until they find out whats wrong with it ;) > > I didn't say that, though. I am fairly firm on _not_ changing what > the superproject records in its tree for the submodule, i.e. it must > record the exact commit, not "a branch name", for reproducibility. I was not talking about changing what the superproject records in its tree. I was just talking about changing where we look for submodules (e.g. for updating and such). I.e. in .git* instead of just the tree as it is at the moment. Thats what I understood from the discussion above. Sorry that might have been ambiguous. I agree that there should always be a commit as a reference for a submodule. But as far as I understand for some projects its to much overhead to record every change of a submodule but still they want to use the latest code during development. Those projects might only want to record the actual commit when they release something. At least thats what I imagine. > I am OK if people ignored the unmatch between the recorded commit > from a submodule and what they had in the submodule directory while > they developed and tested the superproject commit. After all, it is > not an error to make a commit while having a local uncommitted > changes to tracked files, and it is equally valid to have a commit > checked out in a submodule directory that is different from what > goes in the superproject commit. But we do show "modified but not > committed" in the status output. In that light, submodule.*.ignore > may have been a mistake. The original intend for submodule.*.ignore was to help people not showing submodules as dirty when they had untracked files in them. That was after status learned to look into submodules. 'untracked' to avoid the performance overhead and 'dirty' for the people that accidentally worked with dirty submodules. I agree 'all' might have been to much. For the above workflow what user might actually want is something that ignores all changes as long as they are part of the remote branch. But I am just guessing here. My gut feeling is still that most people that request this feature come from svn. Thats why I asked whether the options I described provide the behavior that Jeremy wants. Cheers Heiko