I am working with git submodules for the first time. Struggling with understanding how to create branches across the board and adding them to all the remote repos.
Currently my file structure resembles the following:
-parent_repo
  |
  |_ submodule_1
  |_ submodule_2
  |_ submodule_3
  |_ submodule_4
  |_ submodule_5
  |_ submodule_6
  |_ submodule_7
If I create a branch on parent repo:
(master) $ git checkout -b feature/my_feature
(feature/my_feature) $ git commit -m "created my_feature"
(feature/my_feature) $ git push -u origin feature/my_feature
I would like to create a branch across all submodules including the parent. After which all branches are pushed remote to each submodules and their respected repos.
Tried the following steps:
$ git submodule foreach -b branch_name
$ git push --recurse-submodules=on-demand
$ git submodule foreach "(git checkout branch_name; git pull)&"
..just fails. First command not found.
..and if I do:
$ git config -f .gitmodules submodule.submodule_1.branch branch_name
$ git submodule update --remote
git returns:
fatal: Needed a single revision
Unable to find current origin/branch_name revision in submodule path 'submodule_1'
I would like to create a branch across all submodules including the parent
This will be officially supported (in an experimental mode at first) with Git 2.36 (Q2 2022).
"git branch"(man) learned the --recurse-submodules option.
See commit 09e0be1 (31 Jan 2022) by Junio C Hamano (gitster).
See commit 679e369, commit 961b130, commit 6e0a2ca, commit 3f3e760, commit bc0893c, commit e89f151 (28 Jan 2022) by Glen Choo (chooglen).
(Merged by Junio C Hamano -- gitster -- in commit 5cc9522, 18 Feb 2022)
branch: add--recurse-submodulesoption for branch creationHelped-by: Jonathan Tan
Signed-off-by: Glen Choo
Reviewed-by: Jonathan Tan
To improve the submodules UX, we would like to teach Git to handle branches in submodules.
Start this process by teaching "git branch"(man) the--recurse-submodulesoption so thatgit branch --recurse-submodules(man) topic will create thetopicbranch in the superproject and its submodules.Although this commit does not introduce breaking changes, it does not work well with existing
--recurse-submodulescommands becausegit branch --recurse-submodules" writes to the submodule ref store, but most commands only consider the superprojectgitlinkand ignore the submodule ref store.For example, "
git checkout --recurse-submodules"(man) will check out the commits in the superprojectgitlinks(and put the submodules in detached HEAD) instead of checking out the submodule branches.Because of this, this commit introduces a new configuration value,
submodule.propagateBranches.
The plan is for Git commands to prioritize submodule ref store information over superprojectgitlinksif this value is true.Because "
git branch --recurse-submodules" writes to submodule ref stores, for the sake of clarity, it will not function unless this configuration value is set.This commit also includes changes that support working with submodules from a superproject commit because "
branch --recurse-submodules" (and future commands) need to read.gitmodulesandgitlinksfrom the superproject commit, but submodules are typically read from the filesystem's.gitmodulesand the index's gitlinks.These changes are:
- add a
submodules_of_tree()helper that gives the relevant information of an in-tree submodule (e.g. path and oid) and initializes the repository- add
is_tree_submodule_active()by adding atreeish_nameparameter tois_submodule_active()- add the "submoduleNotUpdated" advice to advise users to update the submodules in their trees
Incidentally, fix an incorrect usage string that combined the 'list' usage of
git branch(-l) with the 'create' usage; this string has been incorrect since its inception, a8dfd5e ("Makebuiltin-branch.cuseparse_options.", 2007-10-07, Git v1.5.4-rc0 -- merge).
git config now includes in its man page:
submodulesNotUpdatedAdvice shown when a user runs a submodule command that fails because
git submodule update --initwas not run.
git config now includes in its man page:
submodule.recurse:A boolean indicating if commands should enable the
--recurse-submodulesoption by default.
Defaults to false.When set to true, it can be deactivated via the
--no-recurse-submodulesoption. Note that some Git commands lacking this option may call some of the above commands affected bysubmodule.recurse; for instancegit remote updatewill callgit fetchbut does not have a--no-recurse-submodulesoption. For these commands a workaround is to temporarily change the configuration value by usinggit -c submodule.recurse=0.The following list shows the commands that accept
--recurse-submodulesand whether they are supported by this setting.
checkout,fetch,grep,pull,push,read-tree,reset,restoreandswitchare always supported.
cloneandls-filesare not supported.
branchis supported only ifsubmodule.propagateBranchesis enabled
submodule.propagateBranches[EXPERIMENTAL] A boolean that enables branching support when using
--recurse-submodulesorsubmodule.recurse=true. Enabling this will allow certain commands to accept--recurse-submodulesand certain commands that already accept--recurse-submoduleswill now consider branches.
git branch now includes in its man page:
'git branch' [--track[=(direct|inherit)] | --no-track] [-f]
[--recurse-submodules] <branchname> [<start-point>]
git branch now includes in its man page:
--recurse-submodulesTHIS OPTION IS EXPERIMENTAL! Causes the current command to recurse into submodules if
submodule.propagateBranchesis enabled. Seesubmodule.propagateBranchesingit config.
Currently, only branch creation is supported.When used in branch creation, a new branch
<branchname>will be created in the superproject and all of the submodules in the superproject's .In submodules, the branch will point to the submodule commit in the superproject's
<start-point>but the branch's tracking information will be set up based on the submodule's branches and remotes e.g.git branch --recurse-submodules topic origin/mainwill create the submodule branch "topic" that points to the submodule commit in the superproject's "origin/main", but tracks the submodule's "origin/main".
With Git 2.40 (Q1 2023), the advice message given when "git branch --recurse-submodules"(man) fails is improved.
See commit 97cf0c7 (16 Jan 2023) by Philippe Blain (phil-blain).
(Merged by Junio C Hamano -- gitster -- in commit 7d4d34f, 27 Jan 2023)
branch: improve advice when --recurse-submodules failsSigned-off-by: Philippe Blain
Reviewed-by: Glen Choo
'
git branch --recurse-submodules'(man) start from-here fails if any submodule present in 'from-here' is not yet cloned (under submodule.propagateBranches=true).
We then give this advice:
You may try updating the submodules using 'git checkout from-here && git submodule update --init'If '
submodule.recurse' is set, 'git checkout'(man) from-here will also fail since it will try to recursively checkout the submodules.Improve the advice by adding '
--no-recurse-submodules' to the checkout command.
You may try updating the submodules using 'git checkout --no-recurse-submodules %s && git submodule update --init
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With