diff options
author | delthas <delthas@dille.cc> | 2021-07-12 19:54:52 +0200 |
---|---|---|
committer | Hubert Hirtz <hubert@hirtz.pm> | 2021-07-13 19:21:08 +0200 |
commit | c078fbbb029fd248756ea5d7726f9ae6090a4ee3 (patch) | |
tree | 22577d5ea43eb26d75cdbd065bfbdcd4088884fc | |
parent | Ratelimit +typing and send +typing=done once only (diff) |
Clear the input on CTRL+C instead of quitting
We have /QUIT for quitting. Most well-known IRC clients don't quit on
CTRL+C but they do on QUIT.
Clearing the editor input on CTRL+C is useful for shell-like behaviour
"abort current line, let me start my line again".
-rw-r--r-- | app.go | 3 | ||||
-rw-r--r-- | ui/editor.go | 12 | ||||
-rw-r--r-- | ui/ui.go | 4 |
3 files changed, 18 insertions, 1 deletions
@@ -320,7 +320,8 @@ func (app *App) handleMouseEvent(ev *tcell.EventMouse) { func (app *App) handleKeyEvent(ev *tcell.EventKey) { switch ev.Key() { case tcell.KeyCtrlC: - app.win.Exit() + app.win.InputClear() + app.typing() case tcell.KeyCtrlL: app.win.Resize() case tcell.KeyCtrlU, tcell.KeyPgUp: diff --git a/ui/editor.go b/ui/editor.go index bf21f85..15785e8 100644 --- a/ui/editor.go +++ b/ui/editor.go @@ -164,6 +164,18 @@ func (e *Editor) Flush() (content string) { return } +func (e *Editor) Clear() { + if e.TextLen() == 0 { + return + } + e.text[e.lineIdx] = []rune{} + e.textWidth = e.textWidth[:1] + e.cursorIdx = 0 + e.offsetIdx = 0 + e.autoCache = nil + return +} + func (e *Editor) Right() { e.right() e.autoCache = nil @@ -228,6 +228,10 @@ func (ui *UI) InputEnter() (content string) { return ui.e.Flush() } +func (ui *UI) InputClear() { + ui.e.Clear() +} + func (ui *UI) Resize() { w, h := ui.screen.Size() ui.e.Resize(w - 9 - ui.config.ChanColWidth - ui.config.NickColWidth) |