package vcaml
OCaml bindings for the Neovim API
Install
Dune Dependency
Authors
Maintainers
Sources
vcaml-v0.15.0.tar.gz
sha256=0dbf2526a24d838988ae9a327550fdd9f0328dbdca9d026430fb4b579e0e0442
Description
The Neovim text editor comes with an RPC-based public API which can be used to control the editor. This set of libraries implements an OCaml interface to those APIs, for the purpose of permitting neovim plugins to be written in OCaml.
Published: 21 Mar 2022
README
VCaml
A library for building Neovim plugins in OCaml.
Reviewing
Most of this library is a direct port of the neovim remote API. For review, consult the following help pages:
:help api.txt
:help msgpack-rpc
:help --embed
:help --headless
:help --listen
Structure
Almost all of the functions in the library are small idiomatic shims on top of the auto-generated functions produced by lib/neovim_api_wrapper
Those that have not been tested are in Untested
submodules.
VCaml
- Library entrypoint
API type definitions
- OCaml -> Neovim:
Defun.Vim.t
- Neovim -> OCaml:
Defun.Ocaml.t
- These types can't be unified for deep GADT reasons.
- OCaml -> Neovim:
Api_call
- A type that represents an API call that can be executed
- A let-syntax for combining these types
Nvim
- Functions that operate on global Neovim state
Buffer
- Functions that operate on Neovim buffers
Window
- Functions that operate on Neovim windows
Tabpage
- Functions that operate on Neovim tabpages
Ui
- Functions that operate on the Neovim UI
Client
Client.t
is opaque to library users. You can interact with clients via the interface exposed in [Vcaml], but for the most part it is an opaque object that is just passed to functions that need it.
Client_info
Client_info.t
is some data that is present for every plugin, embedder, or UI that is attached to Neovim.
Keymap
- A type for representing key mappings
Command
- A type for representing commands (e.g. ":Foo")
Color
- Types for representing colors and highlights
Mark
- A type for representing a mark (e.g. "'m")
Mode
- A type for representing a mode (e.g. "Normal")
Transport
- Generic code for setting up communication between OCaml and Neovim
Extract
- Utilities for pulling values out of
VCaml
related msgpack objects.
Notifier
- Functions that let you send Neovim asynchronous notifications. In most cases this isn't something you want to do: normally you only want to (1) send synchronous requests & responses back and forth, and (2) receive asynchronous notifications.
Dependencies (13)
- faraday
-
dune
>= "2.0.0"
-
angstrom-async
>= "0.14.1"
-
angstrom
>= "0.14.1"
-
textutils
>= "v0.15" & < "v0.16"
-
ppx_jane
>= "v0.15" & < "v0.16"
-
expect_test_helpers_async
>= "v0.15" & < "v0.16"
-
core_unix
>= "v0.15" & < "v0.16"
-
core_kernel
>= "v0.15" & < "v0.16"
-
core
>= "v0.15" & < "v0.16"
-
base
>= "v0.15" & < "v0.16"
-
async
>= "v0.15" & < "v0.16"
-
ocaml
>= "4.08.0"
Dev Dependencies
None
Used by
None
Conflicts
None
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page