Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/peterh/liner
Pure Go line editor with history, inspired by linenoise
https://github.com/peterh/liner
Last synced: 4 days ago
JSON representation
Pure Go line editor with history, inspired by linenoise
- Host: GitHub
- URL: https://github.com/peterh/liner
- Owner: peterh
- License: mit
- Created: 2012-08-15T16:34:55.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-06-23T14:09:49.000Z (over 1 year ago)
- Last Synced: 2025-01-01T22:06:50.485Z (11 days ago)
- Language: Go
- Size: 236 KB
- Stars: 1,057
- Watchers: 23
- Forks: 132
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: COPYING
Awesome Lists containing this project
- awesome-go - liner - Go readline-like library for command-line interfaces. (Command Line / Standard CLI)
- fucking-awesome-go - liner - Go readline-like library for command-line interfaces. (Command Line / Standard CLI)
- awesome-go - liner - Go readline-like library for command-line interfaces. (Command Line / Standard CLI)
- awesome-go - liner - Go readline-like library for command-line interfaces. Stars:`1.1K`. (Command Line / Standard CLI)
- awesome-go - liner - Go readline-like library for command-line interfaces. (Command Line / Standard CLI)
- awesome-go - liner - Pure Go line editor with history, inspired by linenoise - ★ 489 (Command Line)
- awesome-go-extra - liner - 08-15T16:34:55Z|2022-02-10T02:11:32Z| (Build Automation / Standard CLI)
- awesome-go-with-stars - liner - Go readline-like library for command-line interfaces. (Command Line / Standard CLI)
- awesome-go-plus - liner - Go readline-like library for command-line interfaces. ![stars](https://img.shields.io/badge/stars-1057-blue) (Command Line / Standard CLI)
- awesome-go-cn - liner - like的命令行接口库。 [![godoc][D]](https://godoc.org/github.com/peterh/liner) (命令行 / 标准CLI)
- awesome-go-plus - liner - Go readline-like library for command-line interfaces. ![stars](https://img.shields.io/badge/stars-1049-blue) (Command Line / Standard CLI)
README
Liner
=====Liner is a command line editor with history. It was inspired by linenoise;
everything Unix-like is a VT100 (or is trying very hard to be). If your
terminal is not pretending to be a VT100, change it. Liner also support
Windows.Liner is intended for use by cross-platform applications. Therefore, the
decision was made to write it in pure Go, avoiding cgo, for ease of cross
compilation. Furthermore, features only supported on some platforms have
been intentionally omitted. For example, Ctrl-Z is "suspend" on Unix, but
"EOF" on Windows. In the interest of making an application behave the same
way on every supported platform, Ctrl-Z is ignored by Liner.Liner is released under the X11 license (which is similar to the new BSD
license).Line Editing
------------The following line editing commands are supported on platforms and terminals
that Liner supports:Keystroke | Action
--------- | ------
Ctrl-A, Home | Move cursor to beginning of line
Ctrl-E, End | Move cursor to end of line
Ctrl-B, Left | Move cursor one character left
Ctrl-F, Right| Move cursor one character right
Ctrl-Left, Alt-B | Move cursor to previous word
Ctrl-Right, Alt-F | Move cursor to next word
Ctrl-D, Del | (if line is *not* empty) Delete character under cursor
Ctrl-D | (if line *is* empty) End of File - usually quits application
Ctrl-C | Reset input (create new empty prompt)
Ctrl-L | Clear screen (line is unmodified)
Ctrl-T | Transpose previous character with current character
Ctrl-H, BackSpace | Delete character before cursor
Ctrl-W, Alt-BackSpace | Delete word leading up to cursor
Alt-D | Delete word following cursor
Ctrl-K | Delete from cursor to end of line
Ctrl-U | Delete from start of line to cursor
Ctrl-P, Up | Previous match from history
Ctrl-N, Down | Next match from history
Ctrl-R | Reverse Search history (Ctrl-S forward, Ctrl-G cancel)
Ctrl-Y | Paste from Yank buffer (Alt-Y to paste next yank instead)
Tab | Next completion
Shift-Tab | (after Tab) Previous completionNote that "Previous" and "Next match from history" will retain the part of
the line that the user has already typed, similar to zsh's
"up-line-or-beginning-search" (which is the default on some systems) or
bash's "history-search-backward" (which is my preferred behaviour, but does
not appear to be the default `Up` keybinding on any system).Getting started
-----------------```go
package mainimport (
"log"
"os"
"path/filepath"
"strings""github.com/peterh/liner"
)var (
history_fn = filepath.Join(os.TempDir(), ".liner_example_history")
names = []string{"john", "james", "mary", "nancy"}
)func main() {
line := liner.NewLiner()
defer line.Close()line.SetCtrlCAborts(true)
line.SetCompleter(func(line string) (c []string) {
for _, n := range names {
if strings.HasPrefix(n, strings.ToLower(line)) {
c = append(c, n)
}
}
return
})if f, err := os.Open(history_fn); err == nil {
line.ReadHistory(f)
f.Close()
}if name, err := line.Prompt("What is your name? "); err == nil {
log.Print("Got: ", name)
line.AppendHistory(name)
} else if err == liner.ErrPromptAborted {
log.Print("Aborted")
} else {
log.Print("Error reading line: ", err)
}if f, err := os.Create(history_fn); err != nil {
log.Print("Error writing history file: ", err)
} else {
line.WriteHistory(f)
f.Close()
}
}
```For documentation, see http://godoc.org/github.com/peterh/liner