On Wed, Jul 05 2017, Stefan Beller jotted: > On Tue, Jul 4, 2017 at 6:56 PM, Junio C Hamano <gitster@xxxxxxxxx> wrote: >> Stefan Beller <sbeller@xxxxxxxxxx> writes: >> >>> On Tue, Jul 4, 2017 at 3:50 PM, Ævar Arnfjörð Bjarmason >>> <avarab@xxxxxxxxx> wrote: >>> >>>> >>>> I think some invocation of "git submodule update ???" will do the same, >>>> but I can't from the docs see what that is right now. >>> >>> '--remote' is what you are looking for. >>> >>> When we have the branch field configured, the workflow for *creating* >>> the patch sent >>> to Junio might be different than it currently is. Currently, you would >>> send a patch that is >>> produced as: >>> >>> git -C sha1collisiondetection pull origin master >>> git add sha1collisiondetection >>> git commit -m "serious reasoning in the commit message" >>> >>> This could be 'simplified' to >>> >>> git submodule update --remote >>> git add sha1collisiondetection >>> git commit -m "serious reasoning in the commit message" >>> >>> but as we had different branches in the submodule field, >>> I wonder how much of an ease this is. >>> >>> For Junio the workflow stays the same, as he would just >>> apply the patch, so I understand why he might see the >>> branch field as pollution. >> >> My reaction was more about "the rest of us", not me or those who >> choose to bind a new/different commit in the submodule to the >> superproject. > > Currently the rest of us would not care IMHO, as there is no > difference with the field recorded or not. (I just checked if it > would provide slight benefits for shallow clones, but not so) > >> I was recalling a wish by submodule users in a distant past that >> lets "submodule update" to detach to the tip of the named branch in >> the submodule, regardless of what commit the superproject points at >> with its gitlink. > > Yes, I heard that a couple times when poking around for opinions > and I think the issue has 2 facets: > * They actually want to be on a branch, such that the workflow > is 'normal'. (Whatever that means, "detached HEAD" sounds > scary, but workflow-wise it is not. It just requires an additional > "checkout -b" once the work done seems worth preserving) > * None of the people I talked to wanted to get rid of exact-tracking, > solely. But they always came in trade off with the first point > outweighing the benefits of exact tracking. > Although for this purpose the "update --remote" also doesn't > quite fit as it does not re-attach the HEAD to a branch at > the same commit as the remote tracking branch. For my submodule use, I'd like to have it checkout the branchname recorded in the .gitmodules with tracking info set to upstream, and then "git reset --hard" to the commit that's recorded in the commit info. This would exactly mirror the state the repo was in when I initally ran "git submodule add" on it, and make it easy to start making new commits on my local branch, submit a PR of those to upstream, and have things like "git fetch && git log @{u}.." work. >> When those merely following along with this project did "pull && >> submodule update", I do not want the submodule directory to check >> out the commit that happens to be at the tip of their 'master' >> branch. If "submodule update" requires an explicit "--remote" >> option to work in that way, then my worry is allayed, greatly. >> >> Thanks.