# localgit
Command line tool for managing all local git repository clones simultaneously. It includes `status`, `pull`, `push`, `log`, and `list` commands which have similar functionalities as their `git` counterparts but affect all/specified local repositories.
To always ignore specific repositories or whole directories when using localgits, you can add them to environmental variables `LOCALGIT_EXCLUDE_REPO` and `LOCALGIT_EXCLUDE_DIR`. These environmental variables are `;` separated strings. Any local repository clone with a name matching one found in `LOCALGIT_EXCLUDE_REPO` and any local repository clone found within any of the directories in `LOCALGIT_EXCLUDE_DIR` will not be affected/checked by `localgit`.
## Installing
If using a Linux Distro, use [`pipx`](https://github.com/pypa/pipx) to install globally. Then:
```bash
pipx install localgit
```
Otherwise, install globally like usual for Windows and Mac.
## Common arguments
For all commands in localgit, the following CL optional arguments are available:
1. `repo_names`: The names of the folders with git repos to check/affect.
1. `--repo-directories`, `-r`: Directories with git repos to affect. Their validity is checked by the parser.
1. `--exclude`, `-x`: The names of the git repo folders you don't want to check/affect.
1. `--verbose`, `-v`: Print summary for all repos (including those that are already uptodate). \* \~
1. `--silent`, `-s`: Do not details of the command (including which files are modified/untracked for `status`, pulled for `pull`, and pushed for `push`.
_\* These flags are not available for `localgit log`._
_\~ The only flag used by `localgit list`._
## `localgit status`
Calls `git status` in each git repository clone.
Has the following arguments:
1. `--modified`: Only check for modified files. \~
1. `--untracked`: Only check for untracked files. \~
1. `--deleted`: Only check for deleted files. \~
1. `--commit-diffs`: Check how many commits ahead and behind the origin the local repo clone is. \*
_\~ Arguments are mutually exclusive._
_\* Uses `git rev-list --left-right --count <branch>...origin/<branch>`._
## `localgit pull`
Calls `git pull` in each git repository clone. It reports cases where there are merge conflicts, successful merges, and any errors that occur when pulling from the origin.
Has only the common arguments.
## `localgit push`
Calls `git commit -am "new updates" ; git push` in each git repository clone (therefore only commits and pushes modified files). Ensures that the local clone is not behind the origin.
Has the following arguments:
1. `--push-all`, `-A`: Push all the changes including untracked ones.
1. `--message`, `-m`: The commit message. Default is 'modified \<comma separated list of modified files>. added \<comma separated list of untracked files>.
## `localgit log`
Calls `git log --oneline` in each git reposotiry clone and reports the last 3 commit logs or less (if there are fewer) by default.
Has the following argument:
1. `--num-logs`, `-n`: The number of logs to show for each local repo. Default if 3.
## `localgit list`
Prints all the local repo clones found on the device. Formatted to show which will be excluded by the other commands with the `-A` flag.
Has the following argument:
1. `--exclude`, `-x`: The names of the git repo folders you don't want to check/affect.
1. `--all`, `-A`: List all the local git repo folders including those that would be excluded.
Raw data
{
"_id": null,
"home_page": "https://github.com/natibek/localgit/tree/main",
"name": "localgit",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.11.0",
"maintainer_email": null,
"keywords": null,
"author": "Nathnael Bekele",
"author_email": "nwtbekele@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/21/c3/ea8c6a3b9c6d60255f9eeb24ecaa50074bcba63feedd67899224c27ee1ae/localgit-1.1.1.tar.gz",
"platform": null,
"description": "# localgit\n\nCommand line tool for managing all local git repository clones simultaneously. It includes `status`, `pull`, `push`, `log`, and `list` commands which have similar functionalities as their `git` counterparts but affect all/specified local repositories.\n\nTo always ignore specific repositories or whole directories when using localgits, you can add them to environmental variables `LOCALGIT_EXCLUDE_REPO` and `LOCALGIT_EXCLUDE_DIR`. These environmental variables are `;` separated strings. Any local repository clone with a name matching one found in `LOCALGIT_EXCLUDE_REPO` and any local repository clone found within any of the directories in `LOCALGIT_EXCLUDE_DIR` will not be affected/checked by `localgit`.\n\n## Installing\n\nIf using a Linux Distro, use [`pipx`](https://github.com/pypa/pipx) to install globally. Then:\n\n```bash\npipx install localgit\n```\n\nOtherwise, install globally like usual for Windows and Mac.\n\n## Common arguments\n\nFor all commands in localgit, the following CL optional arguments are available:\n\n1. `repo_names`: The names of the folders with git repos to check/affect.\n1. `--repo-directories`, `-r`: Directories with git repos to affect. Their validity is checked by the parser.\n1. `--exclude`, `-x`: The names of the git repo folders you don't want to check/affect.\n1. `--verbose`, `-v`: Print summary for all repos (including those that are already uptodate). \\* \\~\n1. `--silent`, `-s`: Do not details of the command (including which files are modified/untracked for `status`, pulled for `pull`, and pushed for `push`.\n\n_\\* These flags are not available for `localgit log`._\n_\\~ The only flag used by `localgit list`._\n\n## `localgit status`\n\nCalls `git status` in each git repository clone.\n\nHas the following arguments:\n\n1. `--modified`: Only check for modified files. \\~\n1. `--untracked`: Only check for untracked files. \\~\n1. `--deleted`: Only check for deleted files. \\~\n1. `--commit-diffs`: Check how many commits ahead and behind the origin the local repo clone is. \\*\n\n_\\~ Arguments are mutually exclusive._\n\n_\\* Uses `git rev-list --left-right --count <branch>...origin/<branch>`._\n\n## `localgit pull`\n\nCalls `git pull` in each git repository clone. It reports cases where there are merge conflicts, successful merges, and any errors that occur when pulling from the origin.\n\nHas only the common arguments.\n\n## `localgit push`\n\nCalls `git commit -am \"new updates\" ; git push` in each git repository clone (therefore only commits and pushes modified files). Ensures that the local clone is not behind the origin.\n\nHas the following arguments:\n\n1. `--push-all`, `-A`: Push all the changes including untracked ones.\n1. `--message`, `-m`: The commit message. Default is 'modified \\<comma separated list of modified files>. added \\<comma separated list of untracked files>.\n\n## `localgit log`\n\nCalls `git log --oneline` in each git reposotiry clone and reports the last 3 commit logs or less (if there are fewer) by default.\n\nHas the following argument:\n\n1. `--num-logs`, `-n`: The number of logs to show for each local repo. Default if 3.\n\n## `localgit list`\n\nPrints all the local repo clones found on the device. Formatted to show which will be excluded by the other commands with the `-A` flag.\n\nHas the following argument:\n\n1. `--exclude`, `-x`: The names of the git repo folders you don't want to check/affect.\n1. `--all`, `-A`: List all the local git repo folders including those that would be excluded.\n",
"bugtrack_url": null,
"license": "Apache 2.0",
"summary": "localgit is a CL tool for managing multiple local git repo clones simultaneously.",
"version": "1.1.1",
"project_urls": {
"Homepage": "https://github.com/natibek/localgit/tree/main"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "eb212266042f6745a08593cc98ec94e8c8afe959606112eeb7bd6462f85f7133",
"md5": "0269200b3b463b71fe63ff275ba7a8a8",
"sha256": "d11f979c9ccb52be6f716fb132724262c750b718d4dced10b4773ea86bc8af42"
},
"downloads": -1,
"filename": "localgit-1.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "0269200b3b463b71fe63ff275ba7a8a8",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.11.0",
"size": 19609,
"upload_time": "2024-09-15T21:56:37",
"upload_time_iso_8601": "2024-09-15T21:56:37.958233Z",
"url": "https://files.pythonhosted.org/packages/eb/21/2266042f6745a08593cc98ec94e8c8afe959606112eeb7bd6462f85f7133/localgit-1.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "21c3ea8c6a3b9c6d60255f9eeb24ecaa50074bcba63feedd67899224c27ee1ae",
"md5": "502d8bb61c8a54d66b37f97ab6a976c4",
"sha256": "f19597d74d7b6a360e4317558485facd3e909b49d557fe7b12f6f17661cc6488"
},
"downloads": -1,
"filename": "localgit-1.1.1.tar.gz",
"has_sig": false,
"md5_digest": "502d8bb61c8a54d66b37f97ab6a976c4",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.11.0",
"size": 15475,
"upload_time": "2024-09-15T21:56:39",
"upload_time_iso_8601": "2024-09-15T21:56:39.389624Z",
"url": "https://files.pythonhosted.org/packages/21/c3/ea8c6a3b9c6d60255f9eeb24ecaa50074bcba63feedd67899224c27ee1ae/localgit-1.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-15 21:56:39",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "natibek",
"github_project": "localgit",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "localgit"
}