mirror of
https://github.com/Hopiu/micro.git
synced 2026-03-22 00:40:23 +00:00
Merge pull request #960 from nitsakh/insert-issue
Changes to add support for Insert Key Press
This commit is contained in:
commit
649e5799c2
3 changed files with 32 additions and 1 deletions
|
|
@ -1697,6 +1697,22 @@ func (v *View) CommandMode(usePlugin bool) bool {
|
|||
return false
|
||||
}
|
||||
|
||||
// ToggleOverwriteMode lets the user toggle the text overwrite mode
|
||||
func (v *View) ToggleOverwriteMode(usePlugin bool) bool {
|
||||
if v.mainCursor() {
|
||||
if usePlugin && !PreActionCall("ToggleOverwriteMode", v) {
|
||||
return false
|
||||
}
|
||||
|
||||
v.isOverwriteMode = !v.isOverwriteMode
|
||||
|
||||
if usePlugin {
|
||||
return PostActionCall("ToggleOverwriteMode", v)
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
// Escape leaves current mode
|
||||
func (v *View) Escape(usePlugin bool) bool {
|
||||
if v.mainCursor() {
|
||||
|
|
|
|||
|
|
@ -90,6 +90,7 @@ var bindingActions = map[string]func(*View, bool) bool{
|
|||
"ClearStatus": (*View).ClearStatus,
|
||||
"ShellMode": (*View).ShellMode,
|
||||
"CommandMode": (*View).CommandMode,
|
||||
"ToggleOverwriteMode": (*View).ToggleOverwriteMode,
|
||||
"Escape": (*View).Escape,
|
||||
"Quit": (*View).Quit,
|
||||
"QuitAll": (*View).QuitAll,
|
||||
|
|
@ -563,6 +564,7 @@ func DefaultBindings() map[string]string {
|
|||
"CtrlW": "NextSplit",
|
||||
"CtrlU": "ToggleMacro",
|
||||
"CtrlJ": "PlayMacro",
|
||||
"Insert": "ToggleOverwriteMode",
|
||||
|
||||
// Emacs-style keybindings
|
||||
"Alt-f": "WordRight",
|
||||
|
|
|
|||
|
|
@ -73,6 +73,8 @@ type View struct {
|
|||
// mouse release events
|
||||
mouseReleased bool
|
||||
|
||||
// We need to keep track of insert key press toggle
|
||||
isOverwriteMode bool
|
||||
// This stores when the last click was
|
||||
// This is useful for detecting double and triple clicks
|
||||
lastClickTime time.Time
|
||||
|
|
@ -245,6 +247,9 @@ func (v *View) OpenBuffer(buf *Buffer) {
|
|||
// Set mouseReleased to true because we assume the mouse is not being pressed when
|
||||
// the editor is opened
|
||||
v.mouseReleased = true
|
||||
// Set isOverwriteMode to false, because we assume we are in the default mode when editor
|
||||
// is opened
|
||||
v.isOverwriteMode = false
|
||||
v.lastClickTime = time.Time{}
|
||||
}
|
||||
|
||||
|
|
@ -564,6 +569,7 @@ func (v *View) HandleEvent(event tcell.Event) {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
if !isBinding && e.Key() == tcell.KeyRune {
|
||||
// Check viewtype if readonly don't insert a rune (readonly help and log view etc.)
|
||||
if v.Type.Readonly == false {
|
||||
|
|
@ -575,7 +581,14 @@ func (v *View) HandleEvent(event tcell.Event) {
|
|||
v.Cursor.DeleteSelection()
|
||||
v.Cursor.ResetSelection()
|
||||
}
|
||||
v.Buf.Insert(v.Cursor.Loc, string(e.Rune()))
|
||||
|
||||
if v.isOverwriteMode {
|
||||
next := v.Cursor.Loc
|
||||
next.X++
|
||||
v.Buf.Replace(v.Cursor.Loc, next, string(e.Rune()))
|
||||
} else {
|
||||
v.Buf.Insert(v.Cursor.Loc, string(e.Rune()))
|
||||
}
|
||||
|
||||
for pl := range loadedPlugins {
|
||||
_, err := Call(pl+".onRune", string(e.Rune()), v)
|
||||
|
|
|
|||
Loading…
Reference in a new issue