aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/ui/textinput.go29
1 files changed, 29 insertions, 0 deletions
diff --git a/lib/ui/textinput.go b/lib/ui/textinput.go
index e5a2337..00e91ee 100644
--- a/lib/ui/textinput.go
+++ b/lib/ui/textinput.go
@@ -151,6 +151,29 @@ func (ti *TextInput) deleteWord() {
ti.onChange()
}
+func (ti *TextInput) deleteLineForward() {
+ if len(ti.text) == 0 || len(ti.text) == ti.index {
+ return
+ }
+
+ ti.text = ti.text[:ti.index]
+ ti.ensureScroll()
+ ti.Invalidate()
+ ti.onChange()
+}
+
+func (ti *TextInput) deleteLineBackward() {
+ if len(ti.text) == 0 || ti.index == 0 {
+ return
+ }
+
+ ti.text = ti.text[ti.index:]
+ ti.index = 0
+ ti.ensureScroll()
+ ti.Invalidate()
+ ti.onChange()
+}
+
func (ti *TextInput) deleteChar() {
if len(ti.text) > 0 && ti.index != len(ti.text) {
ti.text = append(ti.text[:ti.index], ti.text[ti.index+1:]...)
@@ -249,9 +272,15 @@ func (ti *TextInput) Event(event tcell.Event) bool {
ti.index = len(ti.text)
ti.ensureScroll()
ti.Invalidate()
+ case tcell.KeyCtrlK:
+ ti.invalidateCompletions()
+ ti.deleteLineForward()
case tcell.KeyCtrlW:
ti.invalidateCompletions()
ti.deleteWord()
+ case tcell.KeyCtrlU:
+ ti.invalidateCompletions()
+ ti.deleteLineBackward()
case tcell.KeyTab:
if ti.tabcomplete != nil {
ti.nextCompletion()