Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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.
- Host: GitHub
- URL: https://github.com/akiyosi/goneovim
- Owner: akiyosi
- License: mit
- Created: 2017-10-16T12:29:07.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T03:24:14.000Z (3 months ago)
- Last Synced: 2024-10-29T14:53:28.067Z (3 months ago)
- Topics: cross-platform, editor, go, golang, gui, ide, neovim, neovim-guis, nvim, nvim-plugin, qt, text-editor
- Language: Go
- Homepage:
- Size: 31.5 MB
- Stars: 2,390
- Watchers: 28
- Forks: 62
- Open Issues: 90
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome - akiyosi/goneovim - platform,editor,go,golang,gui,ide,neovim,neovim-guis,nvim,nvim-plugin,qt,text-editor pushed_at:2025-01 star:2.4k fork:0.1k A GUI frontend for neovim. (Go)
- awesome - akiyosi/goneovim - A GUI frontend for neovim. (Go)
- my-awesome-github-stars - akiyosi/goneovim - A GUI frontend for neovim. (Go)
- awesome-list - goneovim
- awesome-golang-repositories - goneovim
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)