vis

A vi-like editor based on Plan 9's structural regular expressions

Github stars Tracking Chart

Vis a vim-like text editor

Linux Build Status
Cygwin Build Status
Coverity Scan Build Status
codecov
Documentation Status
#vis-editor on freenode

Vis aims to be a modern, legacy-free, simple yet efficient editor,
combining the strengths of both vi(m) and sam.

It extends vi's modal editing with built-in support for multiple
cursors/selections and combines it with sam's
structural regular expression
based command language.

A universal editor, it has decent Unicode support and should cope with arbitrary
files, including large, binary or single-line ones.

Efficient syntax highlighting is provided using
Parsing Expression Grammars,
which can be conveniently expressed using Lua
in the form of LPeg.

The editor core is written in a reasonable amount of clean (your mileage
may vary), modern and legacy-free C code, enabling it to run in
resource-constrained environments. The implementation should be easy to hack on
and encourage experimentation. There is also a Lua API for in-process
extensions.

Vis strives to be simple and focuses on its core task: efficient text
management. Clipboard and digraph handling as well as a fuzzy file open
dialog are all provided by independent utilities. There exist plans to use
a client/server architecture, delegating window management to your windowing
system or favorite terminal multiplexer.

The intention is not to be bug-for-bug compatible with vi(m). Instead,
we aim to provide more powerful editing features based on an elegant design
and clean implementation.

vis demo

Build instructions

In order to build vis you will need a
C99
compiler, a POSIX.1-2008
compatible environment as well as:

  • libtermkey
  • curses (recommended)
  • Lua >= 5.2 (optional)
  • LPeg >= 0.12
    (optional runtime dependency required for syntax highlighting)
  • TRE (optional for more memory efficient regex search)

Assuming these dependencies are met, execute:

$ ./configure && make && sudo make install

By default the configure script will try to auto detect support for
Lua. See configure --help for a list of supported options. You can
also manually tweak the generated config.mk file.

Or simply use one of the
distribution provided packages.

Documentation

End user documentation can be found in the
vis(1) manual page
and the Wiki. Read the
FAQ for common questions.
Learn about some differences compared to
sam(1) and
vim(1),
respectively.

C API as well as Lua API
documentation is also available.

Non Goals

Some features which will not be implemented:

  • tabs / multiple workspaces / advanced window management
  • file and directory browser
  • support for file archives (tar, zip, ...)
  • support for network protocols (ftp, http, ssh ...)
  • encryption
  • compression
  • GUIs (neither x11, motif, gtk, win32 ...) although the codebase
    should make it easy to add them
  • VimL
  • right-to-left text
  • ex mode, we have more elegant structural regexp
  • diff mode
  • vimgrep
  • internal spell checker
  • lots of compile time configurable features / #ifdef mess

How to help?

There are plenty of ways to contribute, below are a few ideas:

Checkout the Developer Overview
to get started and do not hesitate to ask question in the #vis-editor
IRC channel on freenode.

Main metrics

Overview
Name With Ownermartanne/vis
Primary LanguageC
Program languageMakefile (Language Count: 8)
Platform
License:Other
所有者活动
Created At2014-11-15 11:09:17
Pushed At2025-04-01 06:10:56
Last Commit At2025-04-01 00:47:12
Release Count11
Last Release Namev0.9 (Posted on 2024-05-01 15:08:21)
First Release Namev0.1 (Posted on 2015-12-31 18:47:30)
用户参与
Stargazers Count4.3k
Watchers Count97
Fork Count269
Commits Count3k
Has Issues Enabled
Issues Count769
Issue Open Count120
Pull Requests Count242
Pull Requests Open Count6
Pull Requests Close Count210
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private