A customizable Neovim plugin to run code inside the editor
Using packer.nvim:
return require('packer').startup(function(use)
use {
'MarcHamamji/runner.nvim',
requires = {
'nvim-telescope/telescope.nvim',
requires = { 'nvim-lua/plenary.nvim' }
},
config = function()
require('runner').setup()
end
}
end)Using lazy.nvim:
require('lazy').setup({
{
'MarcHamamji/runner.nvim',
dependencies = {
'nvim-telescope/telescope.nvim',
dependencies = { 'nvim-lua/plenary.nvim' }
},
config = function()
require('runner').setup()
end
}
})| Command | lua | Description |
|---|---|---|
:Runner |
require('runner').run() |
Runs code in buffer |
:AutoRunner |
require('runner').autorun() |
Runs code in buffer on every file save |
:AutoRunnerStop |
require('runner').autorun_stop() |
Stops AutoRunner and closes the window |
require('runner').run()
require('runner').autorun()
require('runner').autorun_stop()
-- Can also be called with the buffer number where the code is:
-- require('runner').run( <buffer_number> )
-- require('runner').autorun( <buffer_number> )
-- To set a mapping
vim.keymap.set('n', '<leader><space>', require('runner').run)Runner comes with the following defaults:
require('runner').setup({
position = 'right', -- position of the terminal window when using the shell_handler
-- can be: top, left, right, bottom
-- will be overwritten when using the telescope mapping to open horizontally or vertically
width = 80, -- width of window when position is left or right
height = 10, -- height of window when position is top or bottom
handlers = {} -- discussed in the next section
})Runner has the concept of handlers. Handlers are language specific and are little functions that run code. For example, a handler could run the project, run the tests, build the project, or even run custom project scripts.
A handler is a function that accepts a buffer number as an argument, and doesn't
return anything. This buffer number is the buffer where the code to run is located.
It defaults to the buffer where the run() function was called, or, if specified,
is the buffer number that was passed to the run() function. Runner runs the
appropriate handler based on this buffer's filetype.
Default handlers can be found here.
When setting a handler, you should pass the following arguments
| Argument | Description | Type |
|---|---|---|
filetype |
The filetype on which to run the given handler | string |
handler |
The handler to run when the current file matches the filetype | function(bufnr) |
There are 2 ways to set handlers. Both of them overwrite the handlers already set for the specified filetype.
-
You can pass the handlers you want to set to the
setup()function. The handlers table has the following format:{ ["filetype"] = handler }Example:
require('runner').setup({ -- Other options handlers = { lua = function(bufnr) vim.print('Running lua file in buffer ' .. bufnr) -- Run the file here end } })
-
Example:
require('runner').set_handler('lua', function(bufnr) vim.print('Running lua file in buffer ' .. bufnr) -- Run the file here end)
NOTE: For using multiple handlers on the same filetype, see the choice helper.
This plugin exposes some helpers to make creating handlers easier. They're all available by importing them as follows:
local helper_name = require('runner.handlers.helpers').helper_nameHere is a description of each one:
-
Runs a command in a shell by opening it in a new split window, with a terminal buffer.
The split window's position will be determined by the
positionvalue from the config. It will be overwritten when using the telescope mapping to open horizontally or vertically.-
select_horizontal(defaults to<C-X>): Opens the window at the bottom of the screen. -
select_vertical(defaults to<C-V>): Opens the window at the right of the screen.
Argument name Description Type commandThe shell command to run when the handler is called stringeditableWhether the user should be prompted to edit the command using vim.input()before running it. Useful when giving command line arguments to a scriptboolean(optional, defaults to false)Example:
local shell_handler = require('runner.handlers.helpers').shell_handler require('runner').set_handler('rust', shell_handler('cargo run', true))
-
-
Runs a command in the Vim command mode.
Argument name Description Type commandThe Vim command to run when the handler is called stringExample:
local command_handler = require('runner.handlers.helpers').command_handler require('runner').set_handler('lua', command_handler('luafile %'))
-
Opens a
Telescopefinder to allow the user to choose which handler to run.Argument name Description Type handlersThe list of handlers to choose from tablewhere the keys are the name of the handlers in thetelescopefinder, and where the values are the actual handlersExample:
local choice = require('runner.handlers.helpers').choice require('runner').set_handler('rust', choice({ ['Run'] = helpers.shell_handler('cargo run'), ['Test'] = helpers.shell_handler('cargo test'), ['Custom'] = helpers.shell_handler('cargo ', true), }))
For creating dynamic handlers like one for each npm or cargo script, you can write your own handler function that generates the other handlers, gives them to the choice handler, and runs it itself.
See Node.js example.
This project uses StyLua for enforcing code style, and has a pre-commit hook setup for running it automatically. It also has a Github Action that runs the linter on every pull request. If a check doesn't pass on a specific pull request, please lint the code and commit it again.
For running these tools locally, you have to have them installed on your system:
-
Install the pre-commit hook
pre-commit install
-
Check for StyLua errors
stylua --check lua/
-
Fix StyLua errors
stylua lua/
Licensed under the MIT license.
