forked from tiborvass/uniline
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdoc.go
75 lines (60 loc) · 1.26 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
Author: Tibor Vass (gh: @tiborvass)
License: MIT
*/
/*
Package uniline provides a simple readline API written in pure Go with Unicode support.
It allows users to interactively input and edit a line from the terminal.
Most of the usual GNU readline capabilities and control keys are implemented.
If the provided input source is not a TTY or not an ANSI-compatible TTY, uniline falls back to scanning each line using bufio.ScanLines.
Features
Unicode
Optional History (search coming soon)
Fallback for non-TTY or Dumb terminals
Single line editing (multiline coming soon)
Supported Keys
Left / Ctrl-B
Right / Ctrl-F
Up / Ctrl-P
Down / Ctrl-N
Meta-Left
Meta-Right
Backspace / Ctrl-H
Delete
Ctrl-A
Ctrl-E
Ctrl-T
Ctrl-W
Ctrl-K
Ctrl-U
Ctrl-Y
Ctrl-L
Ctrl-C
Ctrl-D
Echo Example (available in examples/echo/echo.go):
package main
import (
"fmt"
"github.com/tiborvass/uniline"
)
func main() {
prompt := "> "
scanner := uniline.DefaultScanner()
for scanner.Scan(prompt) {
line := scanner.Text()
if len(line) > 0 {
scanner.AddToHistory(line)
fmt.Println(line)
}
}
if err := scanner.Err(); err != nil {
panic(err)
}
}
TODO:
Multiline
History search
Tab completion
Catch SIGWINCH when window resizes
*/
package uniline