This library is a modern, pure Go readline implementation, enhanced with editing and user interface features commonly found in modern shells, all in little more than 10K lines of code. Its kemap-based model and completion engine is heavily inspired from the Z-Shell architecture. It is used, between others, to power the console library.
- Near-native Emacs and Vim modes.
- Configurable bind keymaps, with live reload and sane defaults.
- Extended list of edition/movement/control widgets (Emacs and Vim).
- Extended surround select/change/add fonctionality, with highlighting.
- Keywords switching (operators, booleans, hex/binary/digit) with iterations.
- Support for Vim Visual/Operator pending mode & cursor styles indications.
- Vim Insert and Replace (once/many).
- Many Vim text objects.
- All Vim registers, with completion support.
- Undo/redo history.
- Command-line edition in
$EDITOR
. - Support for an arbitrary number of history sources.
- Support for most of oh-my-posh prompts (PS1/PS2/RPROMPT/transient/tooltip).
- Extended completion system, keymap-based and configurable, easy to populate & use.
- Multiple completion display styles, with color support.
- Completion & History incremental search system & highlighting (fuzzy-search).
- Automatic & context-aware suffix removal for efficient flags/path/list completion.
- Optional asynchronous autocomplete.
- Usage/hint message display.
- Support for syntax highlighting
Readline is used by the console library and its example binary. To get a grasp of the functionality provided by readline and its default configuration, install and start the binary.
- Introduction
- Configuration file
- Keymaps & Widgets
- Prompts
- History Sources
- Vim mode
- Custom callbacks
- Completions & Hints
- Other features
- Emacs edition
data:image/s3,"s3://crabby-images/88b07/88b0784f84a8fa1f57a5dbc6a4ade70609c53d77" alt=""
- Vim surround (selection and change)
data:image/s3,"s3://crabby-images/5447f/5447f7a8365ab9362f0104fb3e1c3266d86c21d1" alt=""
data:image/s3,"s3://crabby-images/d2567/d25679a118a913076707a47c4f34a0dd89a90f61" alt=""
- History movements/completion/use/search
data:image/s3,"s3://crabby-images/f9575/f957547001a0c266de83b80ce434fa26e90f04e6" alt=""
data:image/s3,"s3://crabby-images/8c864/8c864a83f778970d22c5c990d62e8b8d8fc661bb" alt=""
This library is in a pre-release status, although pretending to be quite bug-free as compared to its feature set. Please open a PR or an issue if you wish to bring enhancements to it. Other contributions, as well as bug fixes and reviews are also welcome.
- While most of the code has been rewritten from scratch, the original library used is lmorg/readline. I would have never ventured myself doing this if he had not ventured writing a Vim mode core in the first place.
- Some of the Vim code is inspired or translated from zsh-vi-mode.