Skip to content

pappasam/nvim-repl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Neovim REPL

Create, use, and remove interactive REPLs within Neovim 0.5.0+.

Installation

See below for installation instructions for some common Neovim Package managers. For all other package managers, consult your package manager's documentation. Neovim REPL is a normal Neovim package.

lazy.nvim

Configuration for https://github.com/folke/lazy.nvim

{
  "pappasam/nvim-repl",
  init = function()
    vim.g["repl_filetype_commands"] = {
      bash = "bash",
      javascript = "node",
      haskell = "ghci",
      ocaml = {cmd = "utop", suffix = ";;"},
      python = "ipython --no-autoindent",
      r = "R",
      sh = "sh",
      vim = "nvim --clean -ERM",
      zsh = "zsh",
    }
  end,
  keys = {
    { "<Leader>cc", "<Cmd>ReplNewCell<CR>",   mode = "n", desc = "Create New Cell" },
    { "<Leader>cr", "<Plug>(ReplSendCell)",   mode = "n", desc = "Send Repl Cell" },
    { "<Leader>r",  "<Plug>(ReplSendLine)",   mode = "n", desc = "Send Repl Line" },
    { "<Leader>r",  "<Plug>(ReplSendVisual)", mode = "x", desc = "Send Repl Visual Selection" },
  },
}

Usage

demo

  • :Repl or :ReplOpen: open a terminal and run the repl. All arguments are optional; no arguments default to the values set in g:repl_filetype_commands.
    • arg1-cmd the command to start the repl. The command can be multiple words (for example, including conda activate) if escaped properly.
    • arg2-prefix text that precenes all commands sent to the repl ('' to skip).
    • arg3-suffix text that follows all commands sent to the repl ('' to skip). Useful for ocaml.
  • :ReplAttach: attach to an existing, open terminal. Enables multiple buffers to communicate with one terminal.
  • :ReplClose: close the REPL, if open.
  • :ReplToggle: if REPL is open, close it. If REPL is closed, open it using either the filetype associated REPL or the configured default REPL.
  • :ReplClear: clear the REPL, if open.
  • :ReplRunCell: run the cell under the cursor and the cursor will jump to next cell.
  • :ReplNewCell: create a new cell.
  • :ReplSendArgs: send the arguments passed to the command directly to the REPL.

Several pluggable, dot-repeatable mappings are provided for the user to map themselves.

  • <Plug>(ReplSendLine) send the current line to the REPL.
  • <Plug>(ReplSendCell) send the current cell to the REPL.
  • <Plug>(ReplSendVisual) send the visual selection to the REPL.

See below for some suggested mappings (in init.vim):

nnoremap <Leader>cc <Cmd>ReplNewCell<CR>
nmap <silent> <Leader>cr <Plug>(ReplSendCell)
nmap <silent> <Leader>r <Plug>(ReplSendLine)
xmap <silent> <Leader>r <Plug>(ReplSendVisual)

Configuration

  • g:repl_filetype_commands: map Neovim file types to REPL. E.g., if you automatically want to run a ipython REPL for python file types and a "node" REPL for JavaScript file types, your configuration might look like this:

    let g:repl_filetype_commands = {
          \ 'bash': 'bash',
          \ 'javascript': 'node',
          \ 'haskell': 'ghci',
          \ 'ocaml': #{cmd: 'utop', suffix: ';;'},
          \ 'python': 'ipython --no-autoindent',
          \ 'r': 'R',
          \ 'sh': 'sh',
          \ 'vim': 'nvim --clean -ERM',
          \ 'zsh': 'zsh',
          \ }
  • g:repl_default: set the default REPL if no configured REPL is found in g:repl_filetype_commands. Defaults to &shell.

  • g:repl_split: set the REPL window position. vertical and horizontal respect the user-configured global splitright and splitbottom settings.

    • 'bottom'
    • 'top'
    • 'left'
    • 'right'
    • 'horizontal'
    • 'vertical' (default)

    If split bottom is preferred, then add below line to configuration.

    let g:repl_split = 'bottom'
  • g:repl_height: set REPL window's height (number of lines) if g:repl_split set 'bottom'/'top'. Default split equally.

  • g:repl_width: set REPL window's width (number of columns) if g:repl_split set 'left'/'right'. Default vsplit equally.

Cells

Cells are denoted by full-line comments that begin with the characters %%.

Comments are identified by your buffer's filetype's 'commentstring'.

See some examples below:

Python

# %%
print("I am the first cell")
print("I am still the first cell")

# %% anything can follow
print("I am the second cell")
print("I am still the second cell")
print("I am still, still the second cell")
# %%

print("I am the third cell")

Haskell

-- %%
putStrLn "I am the first cell"
putStrLn "I am still the first cell"

-- %% anything can follow
putStrLn "I am the second cell"
putStrLn "I am still the second cell"
putStrLn "I am still, still the second cell"
-- %%

putStrLn "I am the third cell"

Full Documentation

See: https://github.com/pappasam/nvim-repl/blob/main/doc/repl.txt

From within Neovim, type:

:help repl

FAQ

Getting strange errors with Python, please help

One such error might be a IndentError. This has to do with quirks related to the default Python interpreter. To get around this, use ipython as your default interpreter for Python files.

Terminal:

pip install ipython

init.vim:

" init.vim
let g:repl_filetype_commands = {'python': 'ipython --no-autoindent'}

Escape doesn't work in Terminal mode

If you find yourself in Terminal mode, use <C-\><C-n> instead of <Esc> to return to Normal mode.

Type :help Terminal-mode and :help CTRL-\_CTRL-N for more information.

Written by

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published