Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maks/MGit
A Git client for Android.
https://github.com/maks/MGit
Last synced: 4 months ago
JSON representation
A Git client for Android.
- Host: GitHub
- URL: https://github.com/maks/MGit
- Owner: maks
- License: gpl-3.0
- Created: 2016-10-14T02:54:01.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-09-24T07:03:47.000Z (5 months ago)
- Last Synced: 2024-10-29T15:35:32.158Z (4 months ago)
- Language: Java
- Homepage: https://manichord.com/projects/mgit.html
- Size: 9.33 MB
- Stars: 1,238
- Watchers: 50
- Forks: 167
- Open Issues: 276
-
Metadata Files:
- Readme: README.md
- License: COPYING
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# MGit
MGit is a Git client Android App.
This is a continuation of [the SGit project](https://github.com/sheimi/SGit).
[
](https://play.google.com/store/apps/details?id=com.manichord.mgit)
[](https://f-droid.org/packages/com.manichord.mgit)
## Notes
[data:image/s3,"s3://crabby-images/e4e43/e4e439081ff778cf953731ab59b8955d9f310a06" alt="Build Status"](https://travis-ci.org/maks/MGit)
[data:image/s3,"s3://crabby-images/61157/611574ac4c9b7dfcd620169c9510b4b4c30fc7e5" alt="Join the chat at https://gitter.im/MGit-Android/Lobby"](https://gitter.im/MGit-Android/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[data:image/s3,"s3://crabby-images/bc65e/bc65e83859b93a8830926975c5c5f5ea8fd2c88a" alt="Translate - with Stringlate"](https://lonamiwebs.github.io/stringlate/translate?git=https%3A%2F%2Fgithub.com%2Fmaks%2FMGit)
* If you encounter any issues (bugs, crashes, etc.) and want to help improve this project, please open an issue on [GitHub](https://github.com/maks/MGit/issues/new) describing: what the issues are; and how they were caused, to allow for re-creation and fixing of bugs.
* This app requires minimum of for Android v5.0### Editing Files
As of version 1.5.7, MGit no longer provides an internal texteditor, instead if you wish to edit files, you will need to have an editor app installed.
An open source editor that has been tested to work with MGit is ["Viper Exit, nee Turbo Editor"](https://github.com/maks/viper-edit)
but others that support File Providers should also work.
## Supported Features
* Create local repositories
* Clone remote repositories
* Pull from origin
* Delete local repositories
* Browse files
* Browse commit messages (short)
* Checkout branches and tags
* HTTP/HTTPS/SSH are supported (including SSH with private key passphrase)
* Username/Password authentication is supported
* Search local repositories
* Private key management
* Manually choose code language
* `git diff` between commits
* Import existing repositories (that is, you can copy a repository from computer and import to MGit)
* Checkout remote branches
* Merge branches
* Push merged content
* Edit file via external app that can edit the given file type
* Commit and push changed files
* Committer information
* Prompt for password
* *Option* to save username/password
* `git status`
* Cancel when cloning
* Add modified file to stage
* View state of staged files (aka index)
* `git rebase`
* `git cherrypick`
* `git checkout ` (reset changes of a file)## Quick start
### Clone a remote repository
1. Click on the `+` icon to add a new repository
2. Enter remote URL (see URL format below)
3. Enter local repository name - note that this is **not** the full path, as MGit stores all
repositories in the same local directory (can be changed in MGit settings)
4. Click the `Clone` button
5. If required, you will be prompted for credentials to connect to the remote repo. MGit will download the repository (all branches) to your device### Create a local repository
1. Click on the `+` icon to add a new repository
2. Click on `Init Local` to create a local repository
3. Enter the name for this repository when prompted
4. A local empty repo will be created### URL format
#### SSH URLs
* SSH running on standard port (22): `ssh://username@server_name/path/to/repo`
* SSH running on non-standard port: `ssh://username@server_name:port/path/to/repo`
* `username` is needed - by default, MGit tries to connect as root.#### HTTP(S) URLs
* HTTP(S) URL: `https://server_name/path/to/repo`
## ToDo List
[Future enhancements and bugs are tracked here on Github](https://github.com/maks/MGit/issues).
## License
See [GPLv3](./LICENSE)
All code written by `[email protected]` can at your option also be used under the [MIT license](https://en.wikipedia.org/wiki/MIT_License).
## Help
If you want to help improve this project, contributions, especially translations are very welcome. Also contributions to documentation via the wiki for this repo are also most welcome!
### Contributing code
If you would like to contribute code, either a bugfix or a new feature, please make sure there is a open issue that addresses the new code.
**No Pull Requests** will be merged that do not reference an existing issue in the repo.Please use the Android Studio formatting settings set for this project in the repo.
All strings visible to the user need to go into strings resource file.
#### Project Goals
* Provide the best GUI git client available on any platform
* Be usable on both phone, tablet and laptop form-factor devices#### Non-goals for the project
* Support for proprietary vendor APIs (eg. Github)
#### Major Contributions
For new features, a discussion of the new functionality may need to take place in the comments on the issue covering it, so it may be best for that to occur before you spend time on writing the new code.
The app is about to have a major restructure. All new functionality in the app will be written in Kotlin/Rx per #277. Please be aware that the project is now using Data Binding Library and all future functionality should make use of it.
#### Submitting a Pull Request (PR)
Fork from this repo, create a new branch, commit your changes and then send a pull request against the **master** branch of this repo.If you are working on a branch for some time, you may find that changes to master get merged in the meantime, if that happens please do **NOT** merge master into your branch! Instead rebase your branch onto the current head of master.