2024-03-31 16:54:29 +08:00
# SourceGit
Opensource Git GUI client.
## Highlights
* Supports Windows/macOS/Linux
* Opensource/Free
* Fast
2024-09-22 19:03:55 +08:00
* English/Français/Deutsch/Português/Русский/简体中文/繁體中文
2024-03-31 16:54:29 +08:00
* Built-in light/dark themes
2024-06-13 17:08:38 +08:00
* Customize theme
2024-03-31 16:54:29 +08:00
* Visual commit graph
* Supports SSH access with each remote
* GIT commands with GUI
* Clone/Fetch/Pull/Push...
2024-06-20 17:08:29 +08:00
* Merge/Rebase/Reset/Revert/Amend/Cherry-pick...
2024-08-06 11:53:33 +08:00
* Amend/Reword
2024-06-20 17:08:29 +08:00
* Interactive rebase (Basic)
2024-03-31 16:54:29 +08:00
* Branches
* Remotes
* Tags
* Stashes
* Submodules
2024-06-27 18:25:16 +08:00
* Worktrees
2024-03-31 16:54:29 +08:00
* Archive
* Diff
* Save as patch/apply
* File histories
* Blame
* Revision Diffs
2024-06-13 17:08:38 +08:00
* Branch Diff
2024-06-22 11:51:58 +08:00
* Image Diff - Side-By-Side/Swipe/Blend
2024-08-06 11:53:33 +08:00
* GitFlow
* Git LFS
* Issue Link
2024-09-09 19:46:14 +08:00
* Workspace
2024-09-11 18:22:05 +08:00
* Using AI to generate commit message (C# port of [anjerodev/commitollama ](https://github.com/anjerodev/commitollama ))
2024-03-31 16:54:29 +08:00
2024-08-15 14:39:41 +08:00
> [!WARNING]
2024-06-18 21:12:23 +08:00
> **Linux** only tested on **Debian 12** on both **X11** & **Wayland**.
2024-03-31 16:54:29 +08:00
2024-04-24 22:07:48 +08:00
## How to Use
2024-03-31 16:54:29 +08:00
2024-04-18 09:38:28 +08:00
**To use this tool, you need to install Git(>=2.23.0) first.**
2024-03-31 16:54:29 +08:00
2024-04-02 20:05:33 +08:00
You can download the latest stable from [Releases ](https://github.com/sourcegit-scm/sourcegit/releases/latest ) or download workflow artifacts from [Github Actions ](https://github.com/sourcegit-scm/sourcegit/actions ) to try this app based on latest commits.
2024-03-31 16:54:29 +08:00
2024-07-21 18:05:50 +08:00
This software creates a folder `$"{System.Environment.SpecialFolder.ApplicationData}/SourceGit"` , which is platform-dependent, to store user settings, downloaded avatars and crash logs.
2024-04-24 22:07:48 +08:00
2024-08-12 21:29:18 +08:00
| OS | PATH |
|---------|-----------------------------------------------------|
| Windows | `C:\Users\USER_NAME\AppData\Roaming\SourceGit` |
2024-08-13 10:19:16 +08:00
| Linux | `${HOME}/.config/SourceGit` or `${HOME}/.sourcegit` |
2024-08-12 21:29:18 +08:00
| macOS | `${HOME}/Library/Application Support/SourceGit` |
2024-04-24 22:07:48 +08:00
2024-08-15 14:39:41 +08:00
> [!TIP]
> You can open the app data dir from the main menu.
2024-04-01 09:29:04 +08:00
For **Windows** users:
2024-04-02 20:05:33 +08:00
* **MSYS Git is NOT supported**. Please use official [Git for Windows ](https://git-scm.com/download/win ) instead.
2024-07-21 18:05:50 +08:00
* You can install the latest stable from `winget` with follow commands:
```shell
winget install SourceGit
```
2024-08-15 16:02:38 +08:00
> [!NOTE]
> `winget` will install this software as a commandline tool. You need run `SourceGit` from console or `Win+R` at the first time. Then you can add it to the taskbar.
2024-07-21 18:05:50 +08:00
* You can install the latest stable by `scoope` with follow commands:
```shell
scoop bucket add extras
scoop install sourcegit
```
2024-07-02 12:35:09 +08:00
* Portable versions can be found in [Releases ](https://github.com/sourcegit-scm/sourcegit/releases/latest )
2024-04-01 09:29:04 +08:00
2024-03-31 16:54:29 +08:00
For **macOS** users:
2024-04-16 17:29:36 +08:00
* Download `sourcegit_x.y.osx-x64.zip` or `sourcegit_x.y.osx-arm64.zip` from Releases. `x64` for Intel and `arm64` for Apple Silicon.
2024-03-31 16:54:29 +08:00
* Move `SourceGit.app` to `Applications` folder.
* Make sure your mac trusts all software from anywhere. For more information, search `spctl --master-disable` .
* Make sure [git-credential-manager ](https://github.com/git-ecosystem/git-credential-manager/releases ) is installed on your mac.
* You may need to run `sudo xattr -cr /Applications/SourceGit.app` to make sure the software works.
For **Linux** users:
* `xdg-open` must be installed to support open native file manager.
2024-04-18 09:38:28 +08:00
* Make sure [git-credential-manager ](https://github.com/git-ecosystem/git-credential-manager/releases ) is installed on your linux.
2024-09-11 20:32:10 +08:00
* Maybe you need to set environment variable `AVALONIA_SCREEN_SCALE_FACTORS` . See https://github.com/AvaloniaUI/Avalonia/wiki/Configuring-X11-per-monitor-DPI.
2024-03-31 16:54:29 +08:00
2024-09-13 20:46:00 +08:00
## OpenAI
This software supports using OpenAI or other AI service that has an OpenAI comaptible HTTP API to generate commit message. You need configurate the service in `Preference` window.
For `OpenAI` :
* `Server` must be `https://api.openai.com/v1/chat/completions`
For other AI service:
2024-09-19 14:41:59 +08:00
* The `Server` should fill in a URL equivalent to OpenAI's `https://api.openai.com/v1/chat/completions` . For example, when using `Ollama` , it should be `http://localhost:11434/v1/chat/completions` instead of `http://localhost:11434/api/generate`
2024-09-13 20:46:00 +08:00
* The `API Key` is optional that depends on the service
2024-04-08 17:39:52 +08:00
## External Tools
2024-04-03 12:17:20 +08:00
2024-04-08 17:39:52 +08:00
This app supports open repository in external tools listed in the table below.
2024-04-06 13:14:22 +08:00
2024-08-15 11:32:02 +08:00
| Tool | Windows | macOS | Linux | KEY IN `external_editors.json` |
|-------------------------------|---------|-------|-------|--------------------------------|
| Visual Studio Code | YES | YES | YES | VSCODE |
| Visual Studio Code - Insiders | YES | YES | YES | VSCODE_INSIDERS |
| VSCodium | YES | YES | YES | VSCODIUM |
| JetBrains Fleet | YES | YES | YES | FLEET |
| Sublime Text | YES | YES | YES | SUBLIME_TEXT |
2024-09-18 10:00:32 +08:00
| Zed | NO | YES | YES | ZED |
2024-08-15 11:32:02 +08:00
> [!NOTE]
> This app will try to find those tools based on some pre-defined or expected locations automatically. If you are using one portable version of these tools, it will not be detected by this app.
2024-08-15 14:39:41 +08:00
> To solve this problem you can add a file named `external_editors.json` in app data dir and provide the path directly. For example:
2024-08-15 11:32:02 +08:00
```json
{
"tools": {
"VSCODE": "D:\\VSCode\\Code.exe"
}
}
```
> [!NOTE]
> This app also supports a lot of `JetBrains` IDEs, installing `JetBrains Toolbox` will help this app to find them.
2024-04-03 12:17:20 +08:00
2024-04-08 17:39:52 +08:00
## Screenshots
2024-03-31 16:54:29 +08:00
* Dark Theme
2024-07-21 18:08:55 +08:00
![Theme Dark ](./screenshots/theme_dark.png )
2024-03-31 16:54:29 +08:00
* Light Theme
2024-07-21 18:08:55 +08:00
![Theme Light ](./screenshots/theme_light.png )
2024-03-31 16:54:29 +08:00
2024-07-21 18:08:55 +08:00
* Custom
2024-06-13 17:08:38 +08:00
2024-08-23 11:57:17 +08:00
You can find custom themes from [sourcegit-theme ](https://github.com/sourcegit-scm/sourcegit-theme.git ). And welcome to share your own themes.
2024-06-13 17:08:38 +08:00
2024-03-31 16:54:29 +08:00
## Contributing
2024-08-01 09:57:03 +08:00
Everyone is welcome to submit a PR. Please make sure your PR is based on the latest `develop` branch and the target branch of PR is `develop` .
2024-03-31 16:54:29 +08:00
Thanks to all the people who contribute.
2024-06-03 14:53:52 +08:00
[![Contributors ](https://contrib.rocks/image?repo=sourcegit-scm/sourcegit&columns=10 )](https://github.com/sourcegit-scm/sourcegit/graphs/contributors)