francescmm / GitQlient

GitQlient: Multi-platform Git client written with Qt.
https://www.francescmm.com
GNU Lesser General Public License v2.1
843 stars 84 forks source link
cpp git git-client qt5

GitQlient logo

GitQlient: Multi-platform Git client written with Qt

Linux MacOS Windows

GitQlient, pronounced as git+client (/gɪtˈklaɪənt/) is a multi-platform Git client originally forked from QGit. Nowadays it goes beyond of just a fork and adds a lot of new functionality.

GitQlient main screen

Main features

Some of the major feature you can find are:

  1. Easy access to remote actions like: push, pull, submodules management and branches
  2. Branches management
  3. Tags and stashes management
  4. Submodules handling
  5. Allow to open several repositories in the same window
  6. Better visualization of the commits and the work in progress
  7. Better visualization of the repository view
  8. GitHub/GitLab integration
  9. Embedded text editor with syntax highlight for C++

For all the features take a look to the Release Notes in the Wiki.

User Manual

Please, if you have any doubts about how to use it or you just want to know all you can do with GitQlient, take a look to the user manual in here.

It is planned to release for Linux, MacOs and Windows. However, take into account that the development environment is based on Linux and it will be the first platform released.

Interactive UI guide (with code links)

I've set up a small (and ugly) webpage for those developers that want to get some help understanding the different parts of the UI of GitQlient and how they are connected with the C++ code.

The web shows the current UI design with links to the code of the widgets when you click on the areas of the image. The code is shown in a frame near to the image, so a 1920px screen might be needed. Since I'm not a web developer and I don't intend to dedicate too much time to that, I'll update the guide only with major releases. If anybody wants to make it pritier and knows how to do it, please contact me to see if we can collaborate.

Check the Interactive UI guide of GitQlient.

How to install GitQlient

Packaging status

Linux

AppImage

GitQlient is offered in the form of AppImage. Although a big binary, it includes all the libraries needed to run. It is a portable multi-OS version so just download the version you want from the releases page and execute it (make sure it has execution rights).

RPM package for Fedora

Package available in official Fedora repos. To install, type the following command in the terminal:

sudo dnf install gitqlient

DEB package for Ubuntu

For now there is no GitQlient in the official repos of Ubuntu or Debian (Ubuntu bug). However, to install it via .deb package, go to the releases page and download the package from the version you want. Once you download it, you can install it using apt-get command as root.

Windows

For Windows 10 there is a package provided on every release. It installs all the dependencies and creates an shortcut in the Desktop. From the releases page, download the GitQlientInstaller-.exe binary from the release you want to use.

MacOS

For MacOS there is also a DMG package you can install as usual. Take into account that because of lack of resources this version is not tested.

If the app appears damaged and can't be opened, run the following (see #234):

sudo xattr -rd com.apple.quarantine /Applications/gitqlient.app

MacPorts package

GitQlient is available in MacPorts. To install, type the following command in the terminal:

sudo port install gitqlient

Translating GitQlient

GitQlient is using the translation system of Qt. That means that for every new language two files are needed: .ts and .qm. The first one is the text translation and the second one is a compiled file that GitQlient will load.

To add a new translation, please generate those files and add them to the resources.qrc.

For more information on Qt translation system.

Building GitQlient

In the User Manual you can find a whole section about building GitQlient and what dependencies you need.

Licenses

Most of the icons on GitQlient are from Font Awesome. The license states is GPL friendly. Those icons that are not from Font Awesome are custom made icons.

The font used bt GitQlient is DejaVu Sans and DejaVu Sans Mono. It is a free font used by most of the Linux distros and its license can be found on GitHub.