Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/akiyosi/goneovim

A GUI frontend for neovim.
https://github.com/akiyosi/goneovim

cross-platform editor go golang gui ide neovim neovim-guis nvim nvim-plugin qt text-editor

Last synced: 3 days ago
JSON representation

A GUI frontend for neovim.

Awesome Lists containing this project

README

        

goneovim
---

![CI](https://github.com/akiyosi/goneovim/workflows/CI/badge.svg)
[![Go Report Card](https://goreportcard.com/badge/github.com/akiyosi/goneovim)](https://goreportcard.com/report/github.com/akiyosi/goneovim)
![GitHub Releases](https://img.shields.io/github/downloads/akiyosi/goneovim/v0.6.11/total)
[![Join the chat at https://gitter.im/goneovim/community](https://badges.gitter.im/goneovim/community.svg)](https://gitter.im/goneovim/community)

goneovim (pronounced like "go-neovim") is a Neovim GUI written in Go, using a [Qt binding for Go](https://github.com/therecipe/qt).
This repository forked from the original [Gonvim](https://github.com/dzhou121/gonvim) for the purpose of maintenance and enhancement.

![](https://raw.githubusercontent.com/wiki/akiyosi/goneovim/screenshots/goneovim.png)

## Why Neovim GUI

Traditionally, Neovim (and even Vim) has been optimized for working with Terminal, and some Terminal-based workflows cannot be achieved with a GUI.
Therefore, for some people, a GUI would be an unnecessary additional stuff.
On the other hand, in my opinion, there are some attractive features of GUI as follows.

* **More meta keys can be used**
* Since Neovim performs all of its operations with the keyboard, having more meta keys available is a simple advantage.
* **Terminal is also available in Neovim GUI**
* Neovim has an embedded terminal emulator that can be run in `:terminal`, so you can run basic terminal workflows using `:terminal` with `bash` or `zsh` in Neovim GUI. It is also possible to use remote control tools such as [nvr](https://github.com/mhinz/neovim-remote) to avoid nvim in nvim in Neovim GUI.
* **Experience the rich drawing expressions of GUI**
* For example, it is possible to scroll based on pixels, to set different font families and point sizes for each window.

If you are interested in these GUI attractions, try goneovim.

## Features

All of the features are optional. You can use it like a plain nvim or as a nvim with a rich UI.

- Fast
- Cross-platform
- Modern Text Editor Features
- Smooth pixel scroll (Support for both touchpad and Vim scroll command reactions.)
- Animated Cursor
- Ligatures
- Built-in Indent guide
- Scrollbar
- Workspace feature which manages multiple nvim
- Features as neovim GUI
- Externalizable tabline, popupmenu, wildmenu, cmdline, messages
- Support gui option: `guifont`, `guifontwide`, `guifont=*`, `linespace`, `guicursor`. You don't need `neovim-gui-shim`
- Supports per character font fallback feature
- Support mouse
- Independent font settings per window (experimental)
- Attach/Connect feature to a remote nvim
- WSL integration (for Windows)
- Own clipboard provider
- Basic feature as a Text Editor
- Multi byte character
- Drag and Drop files
- InputMethod Editor (for east asian users)
- Miscellaneous
- Supports application window transparency
- Desktop Notification of the messages emitted nvim

## Requirements
* Neovim [v0.10.2](https://github.com/neovim/neovim/releases/tag/v0.10.2) or [Nightly](https://github.com/neovim/neovim/releases/tag/nightly)

See [Installing Neovim](https://github.com/neovim/neovim/wiki/Installing-Neovim)

## Getting Started
### Download from Github
Pre-built packages for Windows, MacOS, Linux are found at the [Releases](https://github.com/akiyosi/goneovim/releases) page.

Or you can get the latest binary from Github Actions CI. See [Actions](https://github.com/akiyosi/goneovim/actions) page.

### Install via Package Manager

Windows users can install using scoop:

```
scoop bucket add extras
scoop install goneovim
```

or

```
scoop bucket add versions
scoop install goneovim-nightly
```

MacOS users can install using homebrew:

`brew install --cask goneovim`

> [!NOTE]
> If you are a macOS user, since this is an unsigned application, you need to execute the following command after obtaining goneovim.app:
> ```
> xattr -c /path/to/goneovim.app
> ```
>
> This will help you avoid the "unknown developer" warning or the "Goneovim is damaged and can't be opened" error.

## Usage

See `:h goneovim` or [wiki](https://github.com/akiyosi/goneovim/wiki/Usage)

## Development

1. Clone this repo and cd into the repo
1. `make qt_bindings`
1. `make deps`
1. `make app`

For more information, see [Development](https://github.com/akiyosi/goneovim/blob/master/Development.md)

## Similar projects

* [Neovide](https://github.com/Kethku/neovide)
* [FVim](https://github.com/yatli/fvim)
* [Gnvim](https://github.com/vhakulinen/gnvim)
* [Uivonim](https://github.com/smolck/uivonim)

## Credits

* Gonvim was created by dzhou121 ([https://github.com/dzhou121/gonvim](https://github.com/dzhou121/gonvim))

## Screenshots

### Workspaces
![](https://raw.githubusercontent.com/wiki/akiyosi/goneovim/screenshots/v0.4.10-workspaces.gif)

### Smooth Scroll with touchpad
![](https://raw.githubusercontent.com/wiki/akiyosi/goneovim/screenshots/v0.4.10-smoothscroll-1.gif)

### Smooth Scroll for neovim scroll commands
![](https://raw.githubusercontent.com/wiki/akiyosi/goneovim/screenshots/v0.4.10-smoothscroll-2.gif)

### External Float Window, Minimap(experimental)
![](https://raw.githubusercontent.com/wiki/akiyosi/goneovim/screenshots/v0.4.10-top.png)