Script to manage Git projects with multiple submodules and multiple environment branches per repository.
If you have several initialized submodules in your project, and you handle several environment branches both in the project as in the related submodules, then you have a Git-Matrix case:
 -------------------------------------
 | B | B | B | B | | B |
 | R | R | R | R | | R |
 | A | A | A | A | | A |
 | N | N | N | N | ... | N |
 | C | C | C | C | | C |
 | H | H | H | H | | H |
 | 1 | 2 | 3 | 4 | | X |
------------------------|-----|-----|-----|-----|-----|-----|
| S U B M O D U L E 1 | | | | | | X |
|-----------------------|-----|-----|-----|-----|-----|-----|
| S U B M O D U L E 2 | G | | | | I | |
|-----------------------|-----|-----|-----|-----|-----|-----|
| S U B M O D U L E 3 | | I | | R | | |
|-----------------------|-----|-----|-----|-----|-----|-----|
| S U B M O D U L E 4 | | | T | | | |
|-----------------------|-----|-----|-----|-----|-----|-----|
| . . . | | A | | | | |
|-----------------------|-----|-----|-----|-----|-----|-----|
| S U B M O D U L E Y | M | | | | | |
-------------------------------------------------------------
You directly move across the project environment branches using the usual Git commands such as git checkout <branch> or any other similar.
Being positioned at the branch you want to update, you can directly run the git_matrix.sh script from the project root folder, which performs the following tasks:
- Updates the active local branch (git pull) and submodules status (git submodule init&git submodule update).
- Updates all environment branches of each submodule.
- If the active branch is the first environment branch (the branch defined in the first position, that is usually 'develop'), the script directly positions each submodule in the last commit (HEAD) of its first environment branch.
- If the active branch is any other different from the first, the script merges the previous environment branch in order to propagate the commited and pushed changes made in the previous environment/s of the project, and then perfoms the following execution alternatives:
- If the script has been executed with [-k|--keep]optional parameter, it keeps for each submodule the current commit versioned in the active branch, discarding the new submodules versions (commits) that may have been updated due to merge process.
- If the script has been executed with <submodule>optional parameter, it updates only the submodule specified as input param, and keeps the rest of submodules in the current commit versioned in the active branch, discarding the new submodules versions (commits) that may have been updated due to merge process.
- If the script has been executed without any parameter, it shows for each submodule the current commit versioned in the active branch, and interactively asks to select the environment branch in which you want to position the submodule, offering an additional option to keep the current commit.
 
- If the script has been executed with 
- Commits the changes made by the previous action, in the event that there are, including as commit message the list of updates made by the script.
- 
cURL tool to execute the configuration command. Installation: # From Red Hat OS family $ sudo yum install curl # From Debian OS family $ sudo apt-get install curl # From Suse OS family $ sudo zypper install curl
To configure the git_matrix.sh script within your project, just run the following command from the project root folder:
$ bash <(curl -s https://raw.githubusercontent.com/rubenmromero/git-matrix/master/install.sh)
As a result of this execution, the git_matrix.sh script is configured to manage the environment branches set by you, in the bin directory located in your project root folder.
Finally, you can add the script to your project repository executing the following commands from the project root folder:
$ git commit -m "Add the Git-Matrix script to the project structure" ./bin/git_matrix.sh
$ git push
Here you are the message you will get if you request help to the git_matrix.sh script:
$ ./bin/git_matrix.sh --help
	EXECUTION MODE =>	./bin/git_matrix.sh [-h|--help] [-k|--keep] [<submodule>]
	Options:
		-h, --help	Show this help message and exit
		-k, --keep	Keep the current commit of each submodule
		<submodule>	Name of submodule to update only this, and keep the rest of submodules in the current commit
	[-k|--keep] and <submodule> options have not effect on the first environment branch of the project