This project aims to provide a simple and clean terminal application for git committing changes in "conventional commit"-like format. It also comes with automatic repository, current branch, repository branches and remotes detection. It, in some sense, follows the behavior of Visual Studio Code when committing and pushing using conventional commit.
The following images shows the UI of Conventional Commits CLI.
There are 5 sections:
-
Header: it contains the name of the application, the version and the author name (me) and the current detected user repository, branch and remote.
-
Type of change: a multi-option selection box for selecting the type of the changes the user is going to commit
-
Gitmoji: a multi-option selection box for selecting the gitmoji
-
Short description: a textbox for the main description of the commit
-
Long description: a textbox for a longer description
These sections follows the same order of VS-code conventional commits, except for the Scope and BREAKING CHANGES sections that are missing in the current version.
Note: when compiling the commit message you don't need to follow neither the same order I gave to you nor the one represented in the UI
Once you enter the UI no box has the focus, which means that you cannot select any option or write any characters in the textbox. A box became active whenever you give it the focus. Once you move from a box to another, the previous focused one lose the focus, which is gained by the new one.
There are two ways to give the focus to a box:
-
MB1
(Mouse Button 1). This is the most straightforward one. Just click on a different box, the previous will lose its focus and the new one will gain it. -
Left/Right Arrow Keys
. It works only when no box has the focus at the moment. When pressed, the next box, in UI order, will gain the focus. To "deactivate" the current box just pressESC
.
If you would like to use the second way for moving between the boxes, remember that it is always a combination of Esc + L/R Arrow
. Here is some other useful commands:
Box | Command | Result |
---|---|---|
Multi-Option Selection | Up Arrow | Move to the line above (if possible) |
Down Arrow | Move to the line below (if possible) | |
TextBox | Letter Key | Add the pressed letter to the content |
Backspace | Remove the current char | |
Arrows | Move the cursor where the pressed arrow is pointing to |
The Textbox development is still in early stage development and provides just the required features to write a commit message. There are some bugs that needs to be fixed and improvemenets to be coded. Here is the list of some bugs:
-
When the window is resized its previous content will not be synched
-
The ENTER Key not working in Textbox (I have decided to disable it for the moment and get back to it after the first release)
Given the previous listed bugs, there are some tips that I can give you:
-
Before running the program resize the terminal to be almost the screen size. Do not keep the terminal dimension small, since there are some lines that needs to be displayed having a reasonable size.
-
Although they are available and working, do not use arrow keys in TextBox, since they can lead to a number of problems (the first two listed in the previous section)
Installation is not required if using Docker containers. However, it is required to distinguish between two situations:
- The current working folder is also the root folder of the repository
- The current working folder is behind a Git worktree
The main difference is about the .git
file, while in the first case it is a folder, in the last one it is a file containing a link to the repository root folder. When bind mounting the current folder into the container, the link specified in the .git
file is no longer valid.
Notice, also, that when running inside a docker container SSH authentication might not be available. A possible solution could be bind mounting the .ssh folder conataining the private and public keys into the container as well.
In the first case we can bind mount the working folder
# For Linux and MacOs
docker run -it --rm -v $(pwd):/app -w /app/ lmriccardo/ccommits-cli:latest
# For Windows
docker run -it --rm -v .\:/app -w /app/ lmriccardo/ccommits-cli:latest
In this case the user should bind mount the root folder of the git worktree. For example assuming the current folder setup
rootFolder/
|-master/
|--.git/
|-branch1/
|--.git
Then the command required to run the docker container is
# pwd = rootFolder
docker run -it --rm --env CCOMMITS_WD=<target1> -v $(pwd):/app -w /app/ lmriccardo/ccommits-cli:latest
The environment variable CCOMMITS_WD
is used to take the target branch on which committing changes. The presence of the environment variable is optional, when running the docker container, however a prompt will be shown to the user asking for the target folder.
In case you are authenticating git remote operations using SSH authentication (Pub and Priv Keys), notice that by running above commands it will not works, since the required files are missing inside the container. In order to make it working, the following command should be used instead:
docker run -it -v <path/to/.ssh>:/root/.ssh \
-v $(pwd):/app/ \
-w /app/ lmriccardo/ccommits-cli:latest
Obviously, the same holds for worktrees. In this last case the --env CCOMMITS_WD
can be given.
On the other hand it is possible to install it locally using go
go install github.com/lmriccardo/conventional-commits-cli@<version>
This will install a binary called conventional-commits-cli
into the $GOPATH/bin
folder, which is may be located at $HOME/go/bin
. I suggest, first to rename the binary and then move it into /usr/bin
if the $GOPATH/bin
is not in your PATH.
ln -s $GOPATH/bin/conventional-commits-cli /usr/bin/ccommits
Finally, call the executable
ccommits [-remote=<remote-name>] [-yes]
Commands:
-remote=<remote-name> : Select the given remote instead of automatic detection
-yes : skips all pauses waiting for user input (ENTER or CTRL+C)
It is also possible to download the binary from the Releases page
In case you would like to contribute to this project, the docker image comes with the required tools to run, build and debug a go application.
The usual setup workflow, without installing go locally, is the following (Linux, Windows should be the same):
# Starts the docker container overwriting the entrypoint
# This will starts the container in interactive mode with a shell
# located in the chosen working folder. A shell is required to compile
docker run -it -v $(pwd):/app -w /app/ lmriccardo/ccommits-cli:dev /bin/bash
Open VS Code (assuming you are using it), on Remote Connection chose "Attach to a Running Container". Look for the container that is running ccommits-cli:latest and start coding! Attaching to the running container is useful for debugging purposes, but it is not strictly required since the current workspace is bind mounted into the container. In any case, running and building must be done using the shell.
In the last update, only for VS Code, a .devcontainer
folder has been created.
I would like to thank:
- tcell for providing the baseline developement kit
- conventional commits for providing, well, conventional commits, without which this project would have never been born