small yet mighty GNU Emacs style editor

Kevin "The Nuclear" Bloom b5f0e240ef made gg better 1 month ago
docs d26781b279 render of unicodes fixed (editing still broken) 8 months ago
scripts b5f0e240ef made gg better 1 month ago
.gitignore 80fa94f2c1 use spaces instead of tabs 1 year ago
AE_LICENSE e97a1e4a48 licenses 1 year ago
BSD_LICENSE 3b51442c13 year bump; termbox update 8 months ago
LICENSE 3b51442c13 year bump; termbox update 8 months ago
NEWS 8dd7039675 reverted to the old string functions 3 months ago
README.md de6aa04066 added new kill ring to README 3 months ago
ait.1 dad91511e7 highlight freshly typed bracket match 2 months ago
buffer.c 8dd7039675 reverted to the old string functions 3 months ago
command.c b5f0e240ef made gg better 1 month ago
complete.c b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
display.c b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
gap.c cec35c6aa0 Revert "replaced all strcpy and strncpy with faster or safer options" 3 months ago
header.h b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
hilite.c 5a9f314235 fixed issues with hilite 7 months ago
key.c b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
main.c a2fe3a9d89 fixed my idiocy 2 months ago
makefile 23ec907d9c redid the backup file by adding -b flag 5 months ago
replace.c cec35c6aa0 Revert "replaced all strcpy and strncpy with faster or safer options" 3 months ago
search.c b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
shell.c b7781091f8 fixed crash in the msgline; fixed bug with multiline comment missing 2 months ago
termbox.h 8d53fb4fe2 Closes #78, revert termbox update 8 months ago
unicode.h 7e13e331c0 fixed remaining issues with unicode 8 months ago
util.c 8dd7039675 reverted to the old string functions 3 months ago
util.h 33dfde8b18 Revert "more refactoring (much is probably broken)" 3 months ago
window.c 33dfde8b18 Revert "more refactoring (much is probably broken)" 3 months ago

README.md

ait - small yet mighty GNU Emacs style editor

ait is inspired by GNU Emacs, acme, mle, microEMACS, mg, and vi/vim/neovim. Based on Atto. Started as a fork of Atto but was then ported to Termbox2 to become what it is now. ait can be compiled with no dependencies other than libc. It should work on all unix-like systems although at this point it only works on GNU/Linux (glibc & musl), macOS, FreeBSD, and NetBSD.

Features

  • Emacs-like keybindings (see key.c)
  • basic window/buffer support
  • isearch
  • find/replace
  • M-x to run shell commands
    • shell commands are either inserted at the point or replace the region. For example, if you ran the scripts/spell command on a word, it would replace the word.
  • M-o to open files with external command
  • basic unlimited undo/redo
  • keyboard macros
  • jump/zap to char
  • bracket highlighting
  • basic syntax highlighting (see buffer.c & hilite.c)
  • quick jump to line and word (similar to avy)
  • UTF-8/Unicode Support
  • GNU Emacs-like kill ring

Goals

  • simplicity but don't suck
  • portability
  • reasonably small
  • support the most important core GNU Emacs keybinding
  • UTF8 & unicode
  • don't reinvent the wheel
  • don't be total trash

Non-goals

  • customizability
  • extension language
  • be Emacs
  • be Vim
  • IDE-like features
  • rewriting things that work

Abstract

The purpose of this editor is to be similar enough to Emacs but without the extra stuff. It focuses on using the existing system to do things, and having smaller footprint without lacking in important editor features. To do this, most of the keybindings are the vanilla Emacs bindings with a few exceptions, having similar buffer and cursor controls, and having a familiar look. Instead of rewriting everything in C, ait allows you to use shell commands as an pseudo-extension language. See scripts/ for more information.

The codebase comes from 2 other authors, most of which was written back in the 90s. That being said, some of the code is clearly outdated but since it works, I have no desire to rewrite it. There is also no reason for me to support things that I don't actually use or things that can easily be done using an existing function. For example, multiple cursors is really great but a complicated feature to add when most situations can be solved using keyboard macros.

Why the name ait?

ait stands for Atto In Termbox or Atto Implemented in Termbox. Also, an ait is a small island usually found in rivers. I thought about calling it simply At but there is already a program called at1 2 3 4 5. My wife also came up with the name of aint, standing for Atto IN Termbox and having the catch phrase of "because it ain't your editor."

Derivation

From Atto's README: "Atto is based on the public domain code of Anthony Howe's editor (commonly known as Anthony's Editor or AE, [2]). Rather than representing a file as a linked list of lines, the AE Editor uses the concept of a Buffer-Gap [4,5,6]. A Buffer-Gap editor stores the file in a single piece of contiguous memory with some extra unused space known as the buffer gap. On character insertion and deletion the gap is first moved to the current point. A character deletion then extends the gap by moving the gap pointer back by 1 OR the gap is reduced by 1 when a character is inserted. The Buffer-Gap technique is elegant and significantly reduces the amount of code required to load a file, modify it and redraw the display. The proof of this is seen when you consider that Atto supports almost the same command set that Pico supports, but Pico requires almost 17 times the amount of code."

ait comes from Atto so the derivation is trival. I just ported it to termbox and started hacking in my own changes for fun.

Known Issues

See issues.

Copying

ait code is released under the BSD 3-Clause License. Atto code is released to the public domain. Anthony's Editor code claims to be public domain but contains a questionable (see AE_LICENSE) license that isn't actually public domain. See the LICENSE file for the offical statements.

Acknowledgements

Hugh Barney for writing Atto.

Anthony Howe for writing Anthony's Editor.

GNU Emacs for keybindings, power, and inspritation.

Plan 9's acme for inspiration.

mle for inspiration and guidance.

Termbox2 for being nice.

Adam Saponara for making the previous 2.