Skip to content

Keybindings#

When using lsp-mode most of the features depend on server capabilities. lsp-mode provides default bindings which are dynamically enabled/disabled based on the server functionality. All the commands are configured lsp-command-map which is bound to lsp-keymap-prefix (default s-l).

Keybinding Description
s-l w s Entry point for the server startup.
s-l w r Restart language server
s-l w q Shutdown language server
s-l w d Describes current session
s-l w D Disconnect the buffer from the language server keeping the server running.
s-l = = Ask the server to format this document.
s-l = r Ask the server to format the region, or if none is selected, the current line.
s-l F a Add new project root to the list of workspace folders.
s-l F r Remove project root from the list of workspace folders.
s-l F b Remove project root from the workspace blocklist.
s-l T l Toggle code-lens overlays.
s-l T L Toggle client-server protocol logging.
s-l T h Toggle symbol highlighting.
s-l T S Toggle minor mode for showing information for current line in sideline. (requires lsp-ui)
s-l T d Toggle minor mode for showing hover information in child frame. (requires lsp-ui)
s-l T s Toggle signature auto activate.
s-l T f Toggle on type formatting.
s-l T T Toggle global minor mode for synchronizing lsp-mode workspace folders and treemacs projects. (requires lsp-treemacs)
s-l g g Find definitions of the symbol under point.
s-l g r Find references of the symbol under point.
s-l g i Find implementations of the symbol under point.
s-l g t Find type definitions of the symbol under point.
s-l g d Find declarations of the symbol under point.
s-l g h Show the incoming call hierarchy for the symbol at point. (requires lsp-treemacs)
s-l g a Find all meaningful symbols that match pattern.
s-l h h Display the type signature and documentation of the thing at point.
s-l h s Activate signature help.
s-l h g Trigger display hover information popup and hide it on next typing.
s-l r r Rename the symbol (and all references to it).
s-l r o Perform the source.organizeImports code action, if available.
s-l a a Execute code action.
s-l a l Click lsp lens using ‘avy’ package.
s-l a h Highlight symbol at point.
s-l G g Peek definitions to the identifier at point. (requires lsp-ui)
s-l G r Peek references to the identifier at point. (requires lsp-ui)
s-l G i Peek implementation locations of the symbol at point. (requires lsp-ui)
s-l G s Peek symbols in the workspace. (requires lsp-ui)
C-u RET When inserting C-u will change the behaviour from insert to replace or vice versa depending on lsp-completion-default-behaviour

which-key integration#

To enable which-key integration in the active major mode for lsp-mode-map you will need to call the lsp-enable-which-key-integration function. This could be done when lsp-mode starts with the following:

(with-eval-after-load 'lsp-mode
  (add-hook 'lsp-mode-hook #'lsp-enable-which-key-integration))

You can also enable which-key integration for all major modes by passing t as a parameter. This is useful for buffers that can use multiple major modes like those using vue-mode.


Last update: January 16, 2025