nosarthur / gita
- вторник, 5 февраля 2019 г. в 00:15:42
Python
Manage multiple git repos side by side for sanity
This tool does two things
If several repos need to be compiled against each other, it helps to see their status together. I also hated to change directories for the execution of simple git commands.
Here the colors denote the 5 situations between local and remote branches:
The choice of purple for ahead and yellow for behind is motivated by blueshift and redshift, using green as baseline.
The additional status symbols denote
+
: staged changes*
: unstaged changes_
: untracked files/foldersThe bookkeeping sub-commands are
gita add <repo-path(s)>
: add repo(s) to gita
gita rm <repo-name>
: remove repo from gita
(won't remove repo from disk)gita ls
: display the status of all reposgita ls <repo-name>
: display the absolute path of one repogita --version
: display gita versionRepo paths are saved in ~/.gita/repo_path
.
The delegated git sub-commands are
gita branch <repo-name(s)>
: show local branches for the specified repo(s)gita clean <repo-name(s)>
: remove untracked files/folders for the specified repo(s)gita difftool <repo-name(s)>
: show differences for the specified repo(s)gita fetch
: fetch remote updates for all reposgita fetch <repo-name(s)>
: fetch remote updates for the specified repo(s)gita log <repo-name(s)>
: show log of the specified repo(s)gita merge <repo-name(s)>
: merge remote updates for the specified repo(s)gita patch <repo-name(s)>
: make a patch for the specified repo(s)gita pull <repo-name(s)>
: pull remote updates for the specified repo(s)gita push <repo-name(s)>
: push local updates of the specified repo(s) to remotegita remote <repo-name(s)>
: show remote settings of the specified repo(s)gita reflog <repo-name(s)>
: show ref logs of the specified repo(s)gita stat <repo-name(s)>
: show repo(s) edit statisticsgita status <repo-name(s)>
: show repo(s) statusDelegation details are specified in
cmds.yml.
For example, gita stat <repo-name(s)>
is registered as
stat:
cmd: diff --stat
help: show edit statistics
and the delegated command is git diff --stat
.
Custom git command aliases can be placed in ~/.gita/cmds.yml
.
And they shadow the default ones in the case of name clashes.
Gita requires Python 3.6 or higher.
To install the latest version, run
pip3 install -U gita
If development mode is preferred,
download the source code and run pip3 install -e <gita-source-folder>
.
In either case, calling gita
in terminal may not work,
then you can put the following line in the .bashrc
file.
alias gita="python3 -m gita"