mirror of
https://github.com/qvacua/vimr.git
synced 2024-12-25 23:02:35 +03:00
106 lines
4.0 KiB
Markdown
106 lines
4.0 KiB
Markdown
VimR — Neovim Refined
|
||
==================
|
||
|
||
![App Icon](https://raw.github.com/qvacua/vimr/master/resources/vimr-app-icon.png)
|
||
|
||
[Download](https://github.com/qvacua/vimr/releases) • [Documentation](https://github.com/qvacua/vimr/wiki) • <http://vimr.org>
|
||
|
||
![Screenshot 1](https://raw.githubusercontent.com/qvacua/vimr/develop/resources/screenshot1.png)
|
||
![Screenshot 0](https://raw.githubusercontent.com/qvacua/vimr/develop/resources/screenshot0.png)
|
||
![Screenshot 2](https://raw.githubusercontent.com/qvacua/vimr/develop/resources/screenshot2.png)
|
||
|
||
## About
|
||
|
||
Project VimR is a (YA) Neovim GUI for macOS.
|
||
The goal is to build an editor that uses Neovim inside with many of the convenience
|
||
GUI features similar to those present in modern editors. We mainly use Swift,
|
||
but also use Objective-C when its C-nature helps.
|
||
|
||
There are other Neovim GUIs for macOS, e.g. [NyaoVim](https://github.com/rhysd/NyaoVim), [neovim-dot-app](https://github.com/rogual/neovim-dot-app), [Oni](https://www.onivim.io), etc., so why?
|
||
|
||
- Play around (obviously) with [Neovim](https://github.com/qvacua/neovim),
|
||
- play around with Swift (and especially with [RxSwift](https://github.com/ReactiveX/RxSwift)), and
|
||
- (most importantly) have fun!
|
||
|
||
If you want to support VimR financially, click the [Github's Sponsor](https://github.com/sponsors/qvacua)
|
||
or [Bountysource](https://www.bountysource.com/teams/vimr).
|
||
|
||
## Download
|
||
|
||
Pre-built binaries can be found under [Releases](https://github.com/qvacua/vimr/releases).
|
||
|
||
## Reusable Components
|
||
|
||
* [RxMessagePort](https://github.com/qvacua/vimr/blob/develop/RxPack/RxMessagePort.swift): RxSwift wrapper for local and remote `CFMessagePort`.
|
||
* [RxMsgpackRpc](https://github.com/qvacua/vimr/blob/develop/RxPack/RxMsgpackRpc.swift): implementation of MsgpackRpc using RxSwift.
|
||
* [RxNeovimApi](https://github.com/qvacua/vimr/blob/develop/RxPack/RxNeovimApi.swift): RxSwift wrapper of Neovim API.
|
||
* [NvimView](https://github.com/qvacua/vimr/tree/develop/NvimView): Cocoa Framework which bundles everything, e.g. Neovim's `runtime`-files, needed to embed Neovim in a Cocoa App.
|
||
|
||
## Some Features
|
||
|
||
* Markdown preview
|
||
* Generic HTML preview (retains the scroll position when reloading)
|
||
* Fuzzy file finder a la Xcode's "Open Quickly..."
|
||
* Trackpad support: Pinching for zooming and two-finger scrolling.
|
||
* Ligatures: Turned off by default. Turn it on in the Preferences.
|
||
* Command line tool.
|
||
* (Simple) File browser
|
||
* Flexible workspace model a la JetBrain's IDEs
|
||
|
||
## How to Build
|
||
|
||
First after cloning the VimR source tree you need to initialize git submodules
|
||
|
||
```bash
|
||
git lfs install
|
||
git submodule update --init
|
||
```
|
||
|
||
First install `homebrew`, then in the project root:
|
||
|
||
```bash
|
||
xcode-select --install # install the Xcode command line tools, if you haven't already
|
||
brew bundle
|
||
|
||
code_sign=false use_carthage_cache=false ./bin/build_vimr.sh # VimR.app will be placed in build/Build/Products/Release/
|
||
```
|
||
|
||
If the build fails for some reason, do the following and build again:
|
||
|
||
```
|
||
cd NvimView/neovim
|
||
git reset --hard @
|
||
git clean -fd
|
||
make distclean
|
||
cd ../..
|
||
code_sign=false use_carthage_cache=false ./bin/build_vimr.sh
|
||
```
|
||
|
||
## Project Setup
|
||
|
||
### Artifacts Hierarchy
|
||
|
||
```
|
||
VimR.app
|
||
+-- NvimView.framework
|
||
+-- NVimView
|
||
+-- runtime files for Neovim
|
||
+-- NvimServer
|
||
+-- libnvim
|
||
+-- other libs for Neovim
|
||
```
|
||
|
||
### Libraries for Neovim
|
||
|
||
* The library `libiconv` is linked by the linker flag `-liconv`. The version bundled with macOS will be linked.
|
||
* The library `libintl` is pre-built in `third-party/libintl/lib` and linked by "Other Linker Flags" of the NvimServer target.
|
||
* Other libraries used by Neovim, which are automatically built by building `libnvim`, are linked by "Other Linker Flags" of the NvimServer target.
|
||
|
||
## License
|
||
|
||
[MIT](https://github.com/qvacua/vimr/blob/master/LICENSE)
|
||
|
||
---
|
||
|
||
If you are here for VimR-MacVim, use the [macvim/master](https://github.com/qvacua/vimr/tree/macvim/master) branch and the version [0.8.0 (32)](https://github.com/qvacua/vimr/releases/tag/v0.8.0-32).
|