Module vis

Lua Extension API for the [Vis Editor](https://github.com/martanne/vis).

*WARNING:* there is no stability guarantee at this time, the API might change without notice!

This document might be out of date, run `make luadoc` to regenerate it.

Info:

  • Release: 6d362f2
  • License: ISC
  • Author: Marc André Tanner

Class Vis

vis.VERSION Version information.
vis.count Current count.
vis.events Events.
vis.input_queue Currently unconsumed keys in the input queue.
vis.lexers Scintillua lexer module.
vis.lpeg LPeg lexer module.
vis.mark Mark name in use.
vis.mode Currently active mode.
vis.modes Mode constants.
vis.options Vis Options
vis.recording Whether a macro is being recorded.
vis.register Register name in use.
vis.registers Registers.
vis.ui User interface.
vis.win Currently active window.
vis:action_register(name, func[, help]) Register a Lua function as key action.
vis:close(inputfd) Closes a stream returned by ???.
vis:command(command) Execute a `:`-command.
vis:command_register(name, command[, help]) Register a custom `:`-command.
vis:communicate(name, command) Open new process and return its input stream (stdin).
vis:exit(code) Terminate editor process.
vis:feedkeys(keys) Push keys to input queue and interpret them.
vis:files() Create an iterator over all files.
vis:info(message) Display a short message.
vis:insert(keys) Insert keys at all cursor positions of active window.
vis:map(mode, key, func[, help]) Map a key to a Lua function.
vis:map(mode, key, action) Map a key to a key action.
vis:map(mode, key, alias) Setup a key alias.
vis:mappings(mode) Get all currently active mappings of a mode.
vis:mark_names() Create an iterator over all mark names.
vis:message(message) Display a multi line message.
vis:module_exist(name) Check whether a Lua module exists
vis:motion_new(key, motion[, help]) Map a new motion.
vis:operator_new(key, operator[, help]) Map a new operator.
vis:option_register(name, type, handler[, help]) Register a custom `:set` option.
vis:option_unregister(name) Unregister a `:set` option.
vis:pipe(text, command[, fullscreen]) Pipe a string to external process and collect output.
vis:pipe([file][, range], command[, fullscreen]) Pipe file range to external process and collect output.
vis:redraw() Redraw complete user interface.
vis:register_names() Create an iterator over all register names.
vis:replace(keys) Replace keys at all cursor positions of active window.
vis:textobject_new(key, textobject[, help]) Map a new text object.
vis:unmap(mode, key) Unmap a global key binding.
vis:windows() Create an iterator over all windows.

Class Ui

ui.colors Number of available colors.
ui.layout Current layout.

Class Window

window.file The file being displayed in this window.
window.height The window height.
window.marks Window marks.
window.options Window Options
window.selection The primary selection of this window.
window.selections The selections of this window.
window.syntax The file type associated with this window.
window.viewport Viewport currently being displayed.
window.width The window width.
window:close(force) Close window.
window:draw() Redraw window content.
window:map(...) Set up a window local key mapping.
window:selections_iterator() Create an iterator over all selections of this window.
window:set_syntax(syntax) Change syntax lexer to use for this window
window:status(left[, right]) Set window status line.
window:style(id, start, finish) Style a window range.
window:style_define(id, style) Define a display style.
window:style_pos(id, x, y) Style the single terminal cell at the given coordinates, relative to this window.
window:unmap(...) Remove a window local key mapping.

Class Selection

selection.anchored Whether this selection is anchored.
selection.col The 1-based column position the cursor of this selection resides on.
selection.line The 1-based line the cursor of this selection resides on.
selection.number The 1-based selection index.
selection.pos The zero based byte position in the file.
selection.range The range covered by this selection.
selection:remove() Remove selection.
selection:to(line, col) Move cursor of selection.

Class File

file.lines File content by logical lines.
file.modified File state.
file.name File name.
file.path File path.
file.permission File permission.
file.savemethod File save method
file.size File size in bytes.
file:content(range) Get file content of range.
file:content(pos, len) Get file content of position and length.
file:delete(range) Delete file range.
file:delete(pos, len) Delete data at position.
file:insert(pos, data) Insert data at position.
file:lines_iterator() Create an iterator over all lines of the file.
file:mark_get(mark) Get position of mark.
file:mark_set(pos) Set mark.
file:match_at(pattern, pos[, horizon]) Check whether LPeg pattern matches at a given file position.
file:text_object_longword(pos) WORD text object.
file:text_object_word(pos) Word text object.

Class Range

range.finish The end of the range.
range.start The beginning of the range.

Layouts

layouts Layout Constants.

Modes

modes Mode constants.

Key Handling

keyhandler(keys) Example of a key handling function.

Core Events

file_close(file) File close.
file_open(file) File open.
file_save_post(file, path) File post save.
file_save_pre(file, path) File pre save.
init() Editor initialization completed.
input(key) Input key event in either input or replace mode.
process_response(name, response_type, code, buffer) The response received from the process started via ???.
quit() Editor is about to terminate.
start() Editor startup completed.
term_csi(List) CSI command received from terminal.
ui_draw() Emitted immediately before the UI is drawn to the screen.
win_close(win) Window close.
win_highlight(win) Window highlight.
win_open(win) Window open.
win_status(win) Window status bar redraw.

Events

events Event names.
events.emit(event, ...) Generate event.
events.subscribe(event, handler[, index]) Subscribe to an event.
events.unsubscribe(event, handler) Unsubscribe from an event.


Class Vis

The main editor object.
vis.VERSION
Version information.
  • VERSION string version information in `git describe` format, same as reported by `vis -v`.
vis.count
Current count.
  • count int the specified count for the current command or `nil` if none was given
vis.events
Events.
vis.input_queue
Currently unconsumed keys in the input queue.
vis.lexers
Scintillua lexer module.
  • lexers might be `nil` if module is not found
vis.lpeg
LPeg lexer module.
  • lpeg might be `nil` if module is not found
vis.mark
Mark name in use.
vis.mode
Currently active mode.
vis.modes
Mode constants.
vis.options
Vis Options

Fields:

  • autoindent boolean {ai} (default false)
  • changecolors boolean (default false)
  • escdelay int (default 50)
  • ignorecase boolean {ic} (default false)
  • loadmethod string `"auto"`, `"read"`, or `"mmap"`. (default "auto")
  • shell string (default "/bin/sh")

See also:

vis.recording
Whether a macro is being recorded.
  • recording bool
vis.register
Register name in use.
vis.registers
Registers.
  • registers array to access the register by single letter name
vis.ui
User interface.
  • ui Ui the user interface being used
vis.win
Currently active window.

See also:

vis:action_register(name, func[, help])
Register a Lua function as key action.

Parameters:

  • name string the name of the action, can be referred to in key bindings as `` pseudo key
  • func Function the lua function implementing the key action (see keyhandler)
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    KeyAction action the registered key action

See also:

vis:close(inputfd)
Closes a stream returned by ???.

Parameters:

  • inputfd io.file the stream to be closed

Returns:

    bool identical to io.close
vis:command(command)
Execute a `:`-command.

Parameters:

  • command string the command to execute

Returns:

    bool whether the command succeeded

Usage:

    vis:command("set number")
vis:command_register(name, command[, help])
Register a custom `:`-command.

Parameters:

  • name string the command name
  • command function the Lua function implementing the command
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the command has been successfully registered

Usage:

    vis:command_register("foo", function(argv, force, win, selection, range)
    	 for i,arg in ipairs(argv) do
    		 print(i..": "..arg)
    	 end
    	 print("was command forced with ! "..(force and "yes" or "no"))
    	 print(win.file.name)
    	 print(selection.pos)
    	 print(range ~= nil and ('['..range.start..', '..range.finish..']') or "invalid range")
    	 return true;
    end)
vis:communicate(name, command)
Open new process and return its input stream (stdin). If the stream is closed (by calling the close method or by being removed by a garbage collector) the spawned process will be killed by SIGTERM. When the process will quit or will output anything to stdout or stderr, the process_response event will be fired.

The editor core won't be blocked while the external process is running.

Parameters:

Returns:

    the file handle to write data to the process, in case of error the return values are equivalent to io.open error values.
vis:exit(code)
Terminate editor process.

Termination happens upon the next iteration of the main event loop. This means the calling Lua code will be executed further until it eventually hands over control to the editor core. The exit status of the most recent call is used.

All unsaved changes will be lost!

Parameters:

  • code int the exit status returned to the operating system
vis:feedkeys(keys)
Push keys to input queue and interpret them.

The keys are processed as if they were read from the keyboard.

Parameters:

  • keys string the keys to interpret
vis:files()
Create an iterator over all files.

Returns:

    the new iterator

Usage:

    for file in vis:files() do
    	-- do something with file
    end
vis:info(message)
Display a short message.

The single line message will be displayed at the bottom of the screen and automatically hidden once a key is pressed.

Parameters:

  • message string the message to display
vis:insert(keys)
Insert keys at all cursor positions of active window.

This function behaves as if the keys were entered in insert mode, but in contrast to ??? it bypasses the input queue, meaning mappings do not apply and the keys will not be recorded in macros.

Parameters:

  • keys string the keys to insert

See also:

vis:map(mode, key, func[, help])
Map a key to a Lua function.

Creates a new key mapping in a given mode.

Parameters:

  • mode int the mode to which the mapping should be added
  • key string the key to map
  • func function the Lua function to handle the key mapping (see keyhandler)
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the mapping was successfully established

See also:

Usage:

    vis:map(vis.modes.INSERT, "<C-k>", function(keys)
    	if #keys < 2 then
    		return -1 -- need more input
    	end
    	local digraph = keys:sub(1, 2)
    	if digraph == "l*" then
    		vis:feedkeys('λ')
    		return 2 -- consume 2 bytes of input
    	end
    end, "Insert digraph")
vis:map(mode, key, action)
Map a key to a key action.

Parameters:

  • mode int the mode to which the mapping should be added
  • key string the key to map
  • action the action to map

Returns:

    bool whether the mapping was successfully established

See also:

Usage:

    local action = vis:action_register("info", function()
      vis:info("Mapping works!")
    end, "Info message help text")
    vis:map(vis.modes.NORMAL, "gh", action)
    vis:map(vis.modes.NORMAL, "gl", action)
vis:map(mode, key, alias)
Setup a key alias.

This is equivalent to `vis:command('map! mode key alias')`.

Mappings are always recursive!

Parameters:

  • mode int the mode to which the mapping should be added
  • key string the key to map
  • alias string the key to map to

Returns:

    bool whether the mapping was successfully established

See also:

Usage:

    vis:map(vis.modes.NORMAL, "j", "k")
vis:mappings(mode)
Get all currently active mappings of a mode.

Parameters:

  • mode int the mode to query

Returns:

    table the active mappings and their associated help texts

See also:

Usage:

    local bindings = vis:mappings(vis.modes.NORMAL)
    for key, help in pairs(bindings) do
    	-- do something
    end
vis:mark_names()
Create an iterator over all mark names.

Returns:

    the new iterator

Usage:

    local marks = vis.win.marks
    for name in vis:mark_names() do
    	local mark = marks[name]
    	for i = 1, #mark do
    		-- do something with: name, mark[i].start, mark[i].finish
    	end
    end
vis:message(message)
Display a multi line message.

Opens a new window and displays an arbitrarily long message.

Parameters:

  • message string the message to display
vis:module_exist(name)
Check whether a Lua module exists Checks whether a subsequent require call will succeed.

Parameters:

  • name string the module name to check

Returns:

    bool whether the module was found
vis:motion_new(key, motion[, help])
Map a new motion.

Sets up a mapping in normal, visual and operator pending mode. The motion function will receive the Window and an initial position (in bytes from the start of the file) as argument and is expected to return the resulting position.

Parameters:

  • key string the key to associate with the new option
  • motion function the motion logic implemented as Lua function
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the new motion could be installed

Usage:

    vis:motion_new("<C-l>", function(win, pos)
    	return pos+1
    end, "Advance to next byte")
vis:operator_new(key, operator[, help])
Map a new operator.

Sets up a mapping in normal, visual and operator pending mode. The operator function will receive the File, Range and position to operate on and is expected to return the new cursor position.

Parameters:

  • key string the key to associate with the new operator
  • operator function the operator logic implemented as Lua function
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the new operator could be installed

Usage:

    vis:operator_new("gq", function(file, range, pos)
    	local status, out, err = vis:pipe(file, range, "fmt")
    	if status ~= 0 then
    		vis:info(err)
    	else
    		file:delete(range)
    		file:insert(range.start, out)
    	end
    	return range.start -- new cursor location
    end, "Formatting operator, filter range through fmt(1)")
vis:option_register(name, type, handler[, help])
Register a custom `:set` option.

Parameters:

  • name string the option name
  • type string the option type (`bool`, `string` or `number`)
  • handler function the Lua function being called when the option is changed
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the option was successfully registered

Usage:

    vis:option_register("foo", "bool", function(value, toggle)
    	if not vis.win then return false end
    	vis.win.foo = toggle and not vis.win.foo or value
    	vis:info("Option foo = " .. tostring(vis.win.foo))
    	return true
    end, "Foo enables superpowers")
vis:option_unregister(name)
Unregister a `:set` option.

Parameters:

Returns:

    bool whether the option was successfully unregistered
vis:pipe(text, command[, fullscreen])
Pipe a string to external process and collect output.

The editor core will be blocked while the external process is running.

Parameters:

  • text string the text written to the external command
  • command string the command to execute
  • fullscreen bool whether command is a fullscreen program (e.g. curses based) (optional)

Returns:

  1. int code the exit status of the executed command
  2. string stdout the data written to stdout
  3. string stderr the data written to stderr
vis:pipe([file][, range], command[, fullscreen])
Pipe file range to external process and collect output.

The editor core will be blocked while the external process is running. File and Range can be omitted or nil to indicate empty input.

Parameters:

  • file File the file to which the range applies (optional)
  • range Range the range to pipe (optional)
  • command string the command to execute
  • fullscreen bool whether command is a fullscreen program (e.g. curses based) (optional)

Returns:

  1. int code the exit status of the executed command
  2. string stdout the data written to stdout
  3. string stderr the data written to stderr
vis:redraw()
Redraw complete user interface.

Will trigger redraw events, make sure to avoid recursive events.

vis:register_names()
Create an iterator over all register names.

Returns:

    the new iterator

Usage:

    for name in vis:register_names() do
    	local reg = vis.registers[name]
    	for i = 1, #reg do
    		-- do something with register value reg[i]
    	end
    end
vis:replace(keys)
Replace keys at all cursor positions of active window.

This function behaves as if the keys were entered in replace mode, but in contrast to ??? it bypasses the input queue, meaning mappings do not apply and the keys will not be recorded in macros.

Parameters:

  • keys string the keys to insert

See also:

vis:textobject_new(key, textobject[, help])
Map a new text object.

Sets up a mapping in visual and operator pending mode. The text object function will receive the Window and an initial position(in bytes from the start of the file) as argument and is expected to return the resulting range or `nil`.

Parameters:

  • key string the key associated with the new text object
  • textobject function the text object logic implemented as Lua function
  • help string the single line help text as displayed in `:help` (optional)

Returns:

    bool whether the new text object could be installed

Usage:

    vis:textobject_new("<C-l>", function(win, pos)
    	return pos, pos+1
    end, "Single byte text object")
vis:unmap(mode, key)
Unmap a global key binding.

Parameters:

  • mode int the mode from which the mapping should be removed
  • key string the mapping to remove

Returns:

    bool whether the mapping was successfully removed

See also:

vis:windows()
Create an iterator over all windows.

Returns:

    the new iterator

See also:

Usage:

    for win in vis:windows() do
    	-- do something with win
    end

Class Ui

The user interface.
ui.colors
Number of available colors.
  • colors int
ui.layout
Current layout.
  • layout layouts current window layout.

Class Window

A window object.
window.file
The file being displayed in this window. Changing the value to a file path will replace the current file with a new one for the specified path.
window.height
The window height.
  • height int
window.marks
Window marks. Most of these marks are stored in the associated File object, meaning they are the same in all windows displaying the same file.
  • marks array to access the marks of this window by single letter name

See also:

window.options
Window Options

Fields:

  • breakat string {brk} (default "")
  • colorcolumn int {cc} (default 0)
  • cursorline boolean {cul} (default false)
  • expandtab boolean {et} (default false)
  • numbers boolean {nu} (default false)
  • relativenumbers boolean {rnu} (default false)
  • showeof boolean (default true)
  • shownewlines boolean (default false)
  • showspaces boolean (default false)
  • showtabs boolean (default false)
  • statusbar boolean (default true)
  • tabwidth int {tw} (default 8)
  • wrapcolumn int {wc} (default 0)

See also:

window.selection
The primary selection of this window.
window.selections
The selections of this window.
  • selections Array(Selection)
window.syntax
The file type associated with this window.
  • syntax string the syntax lexer name or `nil` if unset
window.viewport
Viewport currently being displayed. Changing these values will not move the viewport.

Fields:

  • bytes Range file bytes, from 0, at the start and end of the viewport
  • lines Range file lines, from 1, at the top and bottom of the viewport
  • height int lines in viewport, accounting for window decoration
  • width int columns in viewport, accounting for window decoration
window.width
The window width.
  • width int
window:close(force)
Close window.

After a successful call the Window reference becomes invalid and must no longer be used. Attempting to close the last window will always fail.

Parameters:

  • force bool whether unsaved changes should be discarded

Returns:

    bool whether the window was closed

See also:

window:draw()
Redraw window content.
window:map(...)
Set up a window local key mapping. The function signatures are the same as for ???.

Parameters:

  • ...

See also:

window:selections_iterator()
Create an iterator over all selections of this window.

Returns:

    the new iterator
window:set_syntax(syntax)
Change syntax lexer to use for this window

Parameters:

  • syntax string the syntax lexer name or `nil` to disable syntax highlighting

Returns:

    bool whether the lexer could be changed
window:status(left[, right])
Set window status line.

Parameters:

  • left string the left aligned part of the status line
  • right string the right aligned part of the status line (optional)
window:style(id, start, finish)
Style a window range.

The style will be cleared after every window redraw.

Parameters:

  • id int the display style as registered with style_define
  • start int the absolute file position in bytes
  • finish int the end position

See also:

Usage:

    win:style(win.STYLE_DEFAULT, 0, 10)
window:style_define(id, style)
Define a display style.

Parameters:

  • id int the style id to use
  • style string the style definition

Returns:

    bool whether the style definition has been successfully associated with the given id

See also:

Usage:

    win:style_define(win.STYLE_DEFAULT, "fore:red")
window:style_pos(id, x, y)
Style the single terminal cell at the given coordinates, relative to this window.

Completely independent of the file buffer, and can be used to style UI elements, such as the status bar. The style will be cleared after every window redraw.

Parameters:

  • id int display style registered with style_define
  • x int 0-based x coordinate within Win, where (0,0) is the top left corner
  • y int See above

Returns:

    bool false if the coordinates would be outside the window's dimensions

See also:

Usage:

    win:style_pos(win.STYLE_COLOR_COLUMN, 0, win.height - 1)
    -- Styles the first character of the status bar (or the last line, if disabled)
window:unmap(...)
Remove a window local key mapping. The function signature is the same as for ???.

Parameters:

  • ...

See also:

Class Selection

A selection object.

A selection is a non-empty, directed range with two endpoints called *cursor* and *anchor*. A selection can be anchored in which case the anchor remains fixed while only the position of the cursor is adjusted. For non-anchored selections both endpoints are updated. A singleton selection covers one character on which both cursor and anchor reside. There always exists a primary selection which remains visible (i.e. changes to its position will adjust the viewport).

The range covered by a selection is represented as an interval whose endpoints are absolute byte offsets from the start of the file. Valid addresses are within the closed interval `[0, file.size]`.

Selections are currently implemented using character marks into the underlying persistent [text management data structure](https://github.com/martanne/vis/wiki/Text-management-using-a-piece-chain).

This has a few consequences you should be aware of:

- A selection becomes invalid when the delimiting boundaries of the underlying text it is referencing is deleted:

-- leaves selection in an invalid state win.file:delete(win.selection.pos, 1) assert(win.selection.pos == nil)

Like a regular mark it will become valid again when the text is reverted to the state before the deletion.

- Inserts after the selection position (`> selection.pos`) will not affect the selection position.

local pos = win.selection.pos win.file:insert(pos+1, "-") assert(win.selection.pos == pos)

- Non-cached inserts before the selection position (`<= selection.pos`) will affect the mark and adjust the selection position by the number of bytes which were inserted.

local pos = win.selection.pos win.file:insert(pos, "-") assert(win.selection.pos == pos+1)

- Cached inserts before the selection position (`<= selection.pos`) will not affect the selection position because the underlying text is replaced inplace.

For these reasons it is generally recommended to update the selection position after a modification. The general procedure amounts to:

1. Read out the current selection position 2. Perform text modifications 3. Update the selection position

This is what ??? and ??? do internally.

Usage:

local data = "new text"
local pos = win.selection.pos
win.file:insert(pos, data)
win.selection.pos = pos + #data
selection.anchored
Whether this selection is anchored.
  • anchored bool
selection.col
The 1-based column position the cursor of this selection resides on.
  • col int

See also:

selection.line
The 1-based line the cursor of this selection resides on.
  • line int

See also:

selection.number
The 1-based selection index.
  • number int
selection.pos
The zero based byte position in the file.

Might be `nil` if the selection is in an invalid state. Setting this field will move the cursor endpoint of the selection to the given position.

  • pos int
selection.range
The range covered by this selection.
selection:remove()
Remove selection.
selection:to(line, col)
Move cursor of selection.

Parameters:

  • line int the 1-based line number
  • col int the 1-based column number

Class File

A file object.
file.lines
File content by logical lines.

Assigning to array element `0` (`#lines+1`) will insert a new line at the beginning (end) of the file.

  • lines Array(string) the file content accessible as 1-based array

See also:

Usage:

    local lines = vis.win.file.lines
    for i=1, #lines do
    	lines[i] = i .. ": " .. lines[i]
    end
file.modified
File state.
  • modified bool whether the file contains unsaved changes
file.name
File name.
  • name string the file name relative to current working directory or `nil` if not yet named
file.path
File path.
  • path string the absolute file path or `nil` if not yet named
file.permission
File permission.
  • permission int the file permission bits as of the most recent load/save
file.savemethod
File save method
  • savemethod string `"auto"`, `"atomic"`, or `"inplace"`. (default "auto")
file.size
File size in bytes.
  • size int the current file size in bytes
file:content(range)
Get file content of range.

Parameters:

  • range Range the range to read

Returns:

    string the file content corresponding to the range
file:content(pos, len)
Get file content of position and length.

Parameters:

  • pos int the 0-based file position in bytes
  • len int the length in bytes to read

Returns:

    string the file content corresponding to the range

See also:

Usage:

    local file = vis.win.file
    local text = file:content(0, file.size)
file:delete(range)
Delete file range.

Parameters:

  • range Range the range to delete

Returns:

    bool whether the file content was successfully changed
file:delete(pos, len)
Delete data at position.

Parameters:

  • pos int the 0-based file position in bytes
  • len int the length in bytes to delete

Returns:

    bool whether the file content was successfully changed
file:insert(pos, data)
Insert data at position.

Parameters:

  • pos int the 0-based file position in bytes
  • data string the data to insert

Returns:

    bool whether the file content was successfully changed
file:lines_iterator()
Create an iterator over all lines of the file.

For large files this is probably faster than lines.

Returns:

    the new iterator

See also:

Usage:

    for line in file:lines_iterator() do
    	-- do something with line
    end
file:mark_get(mark)
Get position of mark.

Parameters:

  • mark Mark the mark to look up

Returns:

    int pos the position of the mark, or `nil` if invalid
file:mark_set(pos)
Set mark.

Parameters:

  • pos int the position to set the mark to, must be in [0, file.size]

Returns:

    Mark mark the mark which can be looked up later
file:match_at(pattern, pos[, horizon])
Check whether LPeg pattern matches at a given file position.

Parameters:

  • pattern the LPeg pattern
  • pos int the absolute file position which should be tested for a match
  • horizon int the number of bytes around `pos` to consider (defaults to 1K) (optional)

Returns:

    int start,end the range of the matched region or `nil`
file:text_object_longword(pos)
WORD text object.

Parameters:

  • pos int the position which must be part of the word

Returns:

    Range range the range
file:text_object_word(pos)
Word text object.

Parameters:

  • pos int the position which must be part of the word

Returns:

    Range range the range

Class Range

A file range.

For a valid range `start <= finish` holds. An invalid range is represented as `nil`.

range.finish
The end of the range.
  • finish int
range.start
The beginning of the range.
  • start int

Layouts

layouts
Layout Constants.

Fields:

  • HORIZONTAL int
  • VERTICAL int

Modes

modes
Mode constants.

Fields:

  • NORMAL int
  • OPERATOR_PENDING int
  • INSERT int
  • REPLACE int
  • VISUAL int
  • VISUAL_LINE int

See also:

Key Handling

This section describes the contract between the editor core and Lua key handling functions mapped to symbolic keys using either ??? or ???.

keyhandler(keys)
Example of a key handling function.

The keyhandler is invoked with the pending content of the input queue given as argument. This might be the empty string if no further input is available.

The function is expected to return the number of *bytes* it has consumed from the passed input keys. A negative return value is interpreted as an indication that not enough input was available. The function will be called again once the user has provided more input. A missing return value (i.e. `nil`) is interpreted as zero, meaning no further input was consumed but the function completed successfully.

Parameters:

  • keys string the keys following the mapping

Returns:

    int the number of *bytes* being consumed by the function (see above)

See also:

Usage:

    vis:map(vis.modes.INSERT, "<C-k>", function(keys)
    	if #keys < 2 then
    		return -1 -- need more input
    	end
    	local digraph = keys:sub(1, 2)
    	if digraph == "l*" then
    		vis:feedkeys('λ')
    		return 2 -- consume 2 bytes of input
    	end
    end, "Insert digraph")

Core Events

These events are invoked from the editor core. The following functions are invoked if they are registered in the `vis.events` table. Users scripts should generally use the [Events](#events) mechanism instead which multiplexes these core events.

file_close(file)
File close. The last window displaying the file has been closed.

Parameters:

  • file File the file being closed
file_open(file)
File open.

Parameters:

  • file File the file to be opened
file_save_post(file, path)
File post save. Triggered *after* a successful write operation.

Parameters:

  • file File the file which was written
  • path string the absolute path to which it was written, `nil` if standard output
file_save_pre(file, path)
File pre save. Triggered *before* the file is being written.

Parameters:

  • file File the file being written
  • path string the absolute path to which the file will be written, `nil` if standard output

Returns:

    bool whether the write operation should be proceeded
init()
Editor initialization completed. This event is emitted immediately after `visrc.lua` has been sourced, but before any other events have occurred, in particular the command line arguments have not yet been processed.

Can be used to set *global* configuration options.

input(key)
Input key event in either input or replace mode.

Parameters:

Returns:

    bool whether the key was consumed or not
process_response(name, response_type, code, buffer)
The response received from the process started via ???.

Parameters:

  • name string the name of process given to ???
  • response_type string can be "STDOUT" or "STDERR" if new output was received in corresponding channel, "SIGNAL" if the process was terminated by a signal or "EXIT" when the process terminated normally
  • code int the exit code number if response_type is "EXIT", or the signal number if response_type is "SIGNAL"
  • buffer string the available content sent by the process
quit()
Editor is about to terminate.
start()
Editor startup completed. This event is emitted immediately before the main loop starts. At this point all files are loaded and corresponding windows are created. We are about to process interactive keyboard input.
term_csi(List)
CSI command received from terminal.

Parameters:

  • List of CSI parameters
ui_draw()
Emitted immediately before the UI is drawn to the screen. Allows last-minute overrides to the styling of UI elements.

*WARNING:* This is emitted every screen draw! Use sparingly and check for `nil` values!

win_close(win)
Window close. An window is being closed.

Parameters:

  • win Window the window being closed
win_highlight(win)
Window highlight. The window has been redrawn and the syntax highlighting needs to be performed.

Parameters:

  • win Window the window being redrawn

See also:

win_open(win)
Window open. A new window has been created.

Parameters:

  • win Window the window being opened
win_status(win)
Window status bar redraw.

Parameters:

  • win Window the affected window

See also:

Events

User scripts can subscribe Lua functions to certain events. Multiple functions can be associated with the same event. They will be called in the order they were registered. The first function which returns a non `nil` value terminates event propagation. The remaining event handler will not be called.

Keep in mind that the editor is blocked while the event handlers are being executed, avoid long running tasks.

events
Event names.

Fields:

events.emit(event, ...)
Generate event.

Invokes all event handlers in the order they were registered. Passes all arguments to the handler. The first handler which returns a non `nil` value terminates the event propagation. The other handlers will not be called.

Parameters:

  • event string the event name
  • ... ... the remaining parameters are passed on to the handler
events.subscribe(event, handler[, index])
Subscribe to an event.

Register an event handler.

Parameters:

  • event string the event name
  • handler function the event handler
  • index int the index at which to insert the handler (1 is the highest priority) (optional)

Usage:

    vis.events.subscribe(vis.events.FILE_SAVE_PRE, function(file, path)
    	-- do something useful
    	return true
    end)
events.unsubscribe(event, handler)
Unsubscribe from an event.

Remove a registered event handler.

Parameters:

  • event string the event name
  • handler function the event handler to unsubscribe

Returns:

    bool whether the handler was successfully removed
generated by LDoc 1.5.0 Last updated 2025-01-04 19:44:13