Warning
ocaml-eglot
is highly experimental and at a very early stage
of development. While we're very happy to collect user feedback,
don't overwhelm your OCaml development environment just yet.
ocaml-eglot
is a lightweight
Emacs minor mode designed
to enhance the experience of writing OCaml code by leveraging the
Eglot
Language Server
Protocol (LSP)
client. This tool specifically caters to the OCaml ecosystem by
implementing canonical custom requests and commands exposed by the
ocaml-lsp-server
.
ocaml-eglot
bridges the gap between generic LSP support and the
specific needs of OCaml developers. Its tight coupling with Eglot
ensures a lightweight experience without sacrificing the advanced
features made available by ocaml-lsp-server
. Its aim is to offer a
user experience as close as possible to that offered by the Emacs mode
Merlin.
Eglot relies on Flymake for error diagnosis. OCaml-eglot offers two functions for quickly navigating through errors:
ocaml-eglot-error-next
(C-c C-x): jump to the next errorocaml-eglot-error-prev
(C-c C-c): jump to the previous error
In ocaml-eglot
one can display the type of the expression below the cursor and
navigate the enclosing nodes while increasing or decreasing verbosity:
ocaml-eglot-type-enclosing
(C-c C-t) Display the type of the selection and start a "type enclosing" session.
During a "type enclosing" session the following commands are available:
ocaml-eglot-type-enclosing-increase-verbosity
(C-c C-t or C-→): to increase the verbosity of the type observedocaml-eglot-type-enclosing-decrease-verbosity
(C-←): to decrease verbosity of the type observedocaml-eglot-type-enclosing-grow
(C-↑): to grow the expressionocaml-eglot-type-enclosing-shrink
(C-↓): to shrink the expressionocaml-eglot-type-enclosing-copy
(C-w): to copy the type expression to the kill-ring (clipboard)
OCaml-eglot provides a shortcut to quickly jump to the definition or declaration of an identifier:
-
ocaml-eglot-find-definition
(C-c C-l): jump to definition (the implementation) -
ocaml-eglot-find-declaration
(C-c C-i): jump to declaration (the signature)
The default calculation for the window containing the jump result is smart: if the target is on the same file, the command uses the same window; if the target is on another file, the command opens a new window. Auxiliary functions for controlling the placement of a result are provided:
ocaml-eglot-find-definition-in-new-window
ocaml-eglot-find-declaration-in-new-window
ocaml-eglot-find-definition-in-current-window
ocaml-eglot-find-declaration-in-current-window
The default behavior can also be configured using the
ocaml-eglot-open-window-strategy
variable.
You can also jump to the type definition of the expression at point.
Auxiliary functions for controlling the placement of a result are provided:
ocaml-eglot-find-type-definition-in-new-window
ocaml-eglot-find-type-definition-in-current-window
Used to infer the type of an interface file. If the buffer is not empty, a prompt will ask for confirmation to overwrite the buffer contents:
ocaml-eglot-infer-interface
: infer the interface for the current implementation file
OCaml-eglot allows you to quickly switch from the implementation file
to the interface file and vice versa. If the interface file does not
exist, a prompt can be used to generate it (using type inference,
based on ocaml-eglot-infer-inteface
):
ocaml-eglot-alternate-file
(C-c C-a): switch from the implementation file to the interface file and vice versa
Although the Hover
primitive in the LSP protocol can be used to
conveniently display value documentation, it is also possible to query for it
specifically:
ocaml-eglot-document
(C-c C-d): documents the expression below the cursor.ocaml-eglot-document-identifier
: enables you to enter an identifier (present in the environment) and return its documentation.
Enables you to navigate between the different typed-holes (_
) in a
document and interactively substitute them:
ocaml-eglot-hole-next
: jump to the next holeocaml-eglot-hole-prev
: jump to the previous holeocaml-eglot-construct
: open up a list of valid substitutions to fill the hole
If the ocaml-eglot-construct
command is prefixed by an argument, ie:
C-u M-x ocaml-eglot-construct
, the command will also search for
valid candidates in the current environment:
OCaml-eglot allows you to navigate semantically in a buffer, passing
from an expression to the parent let
, the parent module
, the
parent fun
and the parent match
expression. It is also possible to
navigate between pattern matching cases:
ocaml-eglot-jump
: jumps to the referenced expression
Search for values using a by polarity query or a type expression. A
polarity query prefixes the function arguments with -
and the return
with +
. For example, to search for a function of this type: int -> string
. Search for -int +string
. Searching by polarity does not
support type parameters. A search by type (modulo isomorphisms) uses a
query closer to what you would write to describe a type. For example,
to find the function int_of_string_opt
, search for string -> int option
:
ocaml-eglot-search
searches for a value by its type or polarity (the search type is defined by the input query)