A simple but useful tool to manage multiple git repositories.
Be similar to repo, git submodule.
Node.js v0.12.0+
npm install @snowdream/gitm -g
- use "git pull --rebase" instead of "git pull" as the default option.
If you have a project A on the left.
Now, you want to modularize it to the project A on the right.
For the project A on the left, It is a git repository.
For the project A on the right, project A is not a git repository, project Main and project Module ** are all git repositories.
Browse the example at repositories
If you have a project B on the left.
Now, you want to modularize it to the project B on the right.
For the project B on the left, It is a git repository.
For the project B on the right, project B, project Main and project Module ** are all git repositories.
Browse the example at repository
Usually, gitm needs two config files. repo.gitm and branch.gitm
- repository, required,represent the outermost project is a git repository.
- url, required,represent url for the git repository.
- branches, optional,represent local branches for the git repository. the first branch will be the default branch.
- name, optional,represent local name for the git repository. if this is not provided, then try to guess it from the url.
- repositories, optional,represent the git repository has sub git repositories.
- new/develop/master, required,represent the group name of the branches.
- gitmA, required,represent local name for the git repository.
- new:develop, new is required,develop is optional,new represent local branch for the git repository. develop represent the local branch new may be created from the branch develop or the branch origin/develop.
Warning: All the commands as follows should be executed in the root path. For Scene One, the root path is Project A. For Scene Two, the root path is Project B.
- If repo.gitm does not exist in the root path, try to create it.
- If branch.gitm does not exist in the root path, try to create it.
- If .gitignore does not exist in every git repository, try to create it. If sub git repository exist, try to add them name into the file .gitignore.
gitm clone
Read the file repo.gitm in the current directory, and clone every git repository.
If the property branches exist, every branch will be checkout. The fisrt branch will be the default branch.
gitm clone https://raw.githubusercontent.com/snowdream/gitm/master/examples/repository/repo.gitm
Read the file repo.gitm from the url, other operation is the same as the command gitm clone
Check the file branch.gitm,if the name does not exist in the names of group, then git checkout [name]
will be executed in every git repository.else deal it with the following rules.
gitm checkout new
git checkout new
will be executed in every git repository. such as gitmA.
- if the branch new exist, excute
git checkout new
- if the branch origin/new exist, excute
git checkout –b new origin/new
- if the branch develop exist, excute
git checkout –b new develop
- if the branch origin/develop exist, excute
git checkout –b new origin/develop
- if all the branch up does not exist, excute
git checkout –b new
All the steps will be taken in order. once a step has been taken, then the command is finished, and the rest steps will not be taken.
gitm fetch
Check the file repo.gitm,execute the following command in every git repository.
git fetch --all --progress -v
If gitm fetch
has any other parameters, such as gitm fetch origin master
Then git fetch origin master
will be executed in every git repository.
gitm pull
Check the file repo.gitm,execute the following command in every git repository.
git pull origin branch --progress -v
branch is the current branch of the git repository.
If gitm pull
has any other parameters, such as gitm pull origin master
Then git pull origin master
will be executed in every git repository.
gitm push
Check the file repo.gitm,execute the following command in every git repository.
git push origin branch:branch --progress -v
branch is the current branch of the git repository.
If gitm push
has any other parameters, such as gitm push origin master
Then git push origin master
will be executed in every git repository.
Such as gitm help clone
. It will execute the following command only once.
git help clone
show helps for gitm
show version for gitm
Use git in place of gitm, then execute the command in every git repository.
Copyright (C) 2015 Snowdream Mobile <[email protected]>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.