aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/e_events.go48
-rw-r--r--src/e_keys.go155
-rw-r--r--src/i_ui.go45
3 files changed, 145 insertions, 103 deletions
diff --git a/src/e_events.go b/src/e_events.go
index e7bbb19..99813ab 100644
--- a/src/e_events.go
+++ b/src/e_events.go
@@ -279,21 +279,45 @@ func e_delete_host(data *HardData) error {
}
func e_readline(event tcell.EventKey, buffer *Buffer) {
- if len(buffer.str) > 0 &&
+ if len(buffer.data) > 0 &&
(event.Key() == tcell.KeyBackspace ||
event.Key() == tcell.KeyBackspace2) {
- buffer.str = (buffer.str)[:len(buffer.str) - 1]
+ if buffer.cursor == 0 {
+ return
+ } else if buffer.cursor == buffer.len() {
+ buffer.data = (buffer.data)[:buffer.cursor - 1]
+ }
+ buffer.cursor -= 1
} else if event.Key() == tcell.KeyCtrlU {
- buffer.str = ""
+ buffer.empty()
} else if event.Rune() >= 32 && event.Rune() <= 126 {
- buffer.str += string(event.Rune())
+ if buffer.cursor == buffer.len() {
+ buffer.data = append(buffer.data, event.Rune())
+ } else {
+ buffer.data = append(buffer.data[:buffer.cursor],
+ append([]rune{event.Rune()}, buffer.data[buffer.cursor:]...)...)
+ }
+ buffer.cursor += 1
} else if event.Key() == tcell.KeyCtrlA {
+ buffer.cursor = 0
} else if event.Key() == tcell.KeyCtrlE {
+ buffer.cursor = buffer.len()
+ } else if event.Key() == tcell.KeyLeft ||
+ event.Key() == tcell.KeyCtrlB {
+ buffer.cursor -= 1
+ } else if event.Key() == tcell.KeyRight ||
+ event.Key() == tcell.KeyCtrlF {
+ buffer.cursor += 1
+ }
+ if buffer.cursor > buffer.len() {
+ buffer.cursor = buffer.len()
+ } else if buffer.cursor < 0 {
+ buffer.cursor = 0
}
}
func e_mkdir(data *HardData, ui *HardUI) {
- if len(ui.buff.str) == 0 {
+ if ui.buff.len() == 0 {
return
}
path := "/"
@@ -302,15 +326,15 @@ func e_mkdir(data *HardData, ui *HardUI) {
}
if err := os.MkdirAll(data.data_dir +
path +
- ui.buff.str, os.ModePerm); err != nil {
- c_error_mode("mkdir " + path[1:] + ui.buff.str + " failed",
+ ui.buff.str(), os.ModePerm); err != nil {
+ c_error_mode("mkdir " + path[1:] + ui.buff.str() + " failed",
err, ui)
return
}
e_reload_data(data)
for curr := data.litems.head; curr != nil; curr = curr.next {
if curr.is_dir() == true &&
- curr.Dirs.Name == ui.buff.str &&
+ curr.Dirs.Name == ui.buff.str() &&
curr.Dirs.Parent.path() == path {
data.litems.curr = curr
return
@@ -327,12 +351,12 @@ func e_rename(data *HardData, ui *HardUI) error {
name = tmp.Dirs.Name
}
- if len(ui.buff.str) == 0 || tmp == nil || ui.buff.str == name {
+ if ui.buff.len() == 0 || tmp == nil || ui.buff.str() == name {
return nil
}
if tmp.is_dir() == false {
new_host := e_deep_copy_host(data.litems.curr.Host)
- new_host.Name = ui.buff.str
+ new_host.Name = ui.buff.str()
ui.insert_method = INSERT_MOVE
i_insert_host(data, &new_host)
data.litems.del(tmp)
@@ -344,7 +368,7 @@ func e_rename(data *HardData, ui *HardUI) error {
return nil
} else {
old_path := data.data_dir + tmp.Dirs.path()
- new_path := data.data_dir + tmp.Dirs.Parent.path() + data.ui.buff.str
+ new_path := data.data_dir + tmp.Dirs.Parent.path() + data.ui.buff.str()
if err := os.Rename(old_path, new_path); err != nil {
c_error_mode("can't rename " + old_path, err, &data.ui)
return err
@@ -353,7 +377,7 @@ func e_rename(data *HardData, ui *HardUI) error {
e_reload_data(data)
for curr := data.litems.head; curr != nil; curr = curr.next {
if curr.is_dir() == true &&
- curr.Dirs.Name == ui.buff.str &&
+ curr.Dirs.Name == ui.buff.str() &&
curr.Dirs.Parent.path() == path {
data.litems.curr = curr
return nil
diff --git a/src/e_keys.go b/src/e_keys.go
index f721cf7..cac2872 100644
--- a/src/e_keys.go
+++ b/src/e_keys.go
@@ -245,9 +245,9 @@ func e_normal_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
data.litems.curr != nil {
ui.mode = RENAME_MODE
if data.litems.curr.is_dir() == false {
- ui.buff.str = data.litems.curr.Host.Name
+ ui.buff.insert(data.litems.curr.Host.Name)
} else {
- ui.buff.str = data.litems.curr.Dirs.Name
+ ui.buff.insert(data.litems.curr.Dirs.Name)
}
} else if event.Rune() == '?' {
ui.mode = HELP_MODE
@@ -317,13 +317,13 @@ func e_mkdir_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
event.Key() == tcell.KeyCtrlC {
ui.s.HideCursor()
ui.mode = NORMAL_MODE
- ui.buff.str = ""
+ ui.buff.empty()
data.insert = nil
} else if event.Key() == tcell.KeyEnter {
e_mkdir(data, ui)
ui.s.HideCursor()
ui.mode = NORMAL_MODE
- ui.buff.str = ""
+ ui.buff.empty()
} else {
e_readline(event, &ui.buff)
}
@@ -338,22 +338,22 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
ui.mode = NORMAL_MODE
ui.insert_sel = 0
data.insert = nil
- ui.buff.str = ""
+ ui.buff.empty()
} else if event.Key() == tcell.KeyEnter {
- if ui.buff.str == "" {
+ if ui.buff.len() == 0 {
ui.s.HideCursor()
ui.mode = NORMAL_MODE
ui.insert_sel = 0
ui.insert_sel_ok = false
data.insert = nil
- ui.buff.str = ""
+ ui.buff.empty()
return true
}
ui.s.HideCursor()
data.insert = &HostNode{}
e_set_protocol_defaults(data, data.insert)
- data.insert.Name = ui.buff.str
- ui.buff.str = ""
+ data.insert.Name = ui.buff.str()
+ ui.buff.empty()
if data.litems.curr != nil {
data.insert.parent = data.litems.curr.path_node()
} else {
@@ -377,7 +377,7 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
ui.mode = NORMAL_MODE
ui.insert_sel = 0
data.insert = nil
- ui.buff.str = ""
+ ui.buff.empty()
} else if event.Rune() == 'j' ||
event.Key() == tcell.KeyDown ||
event.Key() == tcell.KeyTab {
@@ -467,42 +467,41 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_SSH_HOST,
INS_RDP_HOST,
INS_OS_HOST:
- ui.buff.str = data.insert.Host
+ ui.buff.insert(data.insert.Host)
case INS_SSH_PORT,
INS_RDP_PORT:
if data.insert.Port > 0 {
- ui.buff.str = strconv.Itoa(int(data.insert.Port))
+ ui.buff.insert(strconv.Itoa(int(data.insert.Port)))
}
case INS_SSH_USER,
INS_RDP_USER,
INS_OS_USER:
- ui.buff.str = data.insert.User
+ ui.buff.insert(data.insert.User)
case INS_SSH_PASS,
INS_RDP_PASS,
INS_OS_PASS:
return true
- case INS_SSH_PRIV: ui.buff.str = data.insert.Priv
- case INS_SSH_EXEC: ui.buff.str = data.insert.Exec
+ case INS_SSH_PRIV: ui.buff.insert(data.insert.Priv)
+ case INS_SSH_EXEC: ui.buff.insert(data.insert.Exec)
case INS_SSH_JUMP_HOST,
INS_RDP_JUMP_HOST + len(data.insert.Drive):
- ui.buff.str = data.insert.Jump.Host
+ ui.buff.insert(data.insert.Jump.Host)
case INS_SSH_JUMP_PORT,
INS_RDP_JUMP_PORT + len(data.insert.Drive):
if data.insert.Jump.Port > 0 {
- ui.buff.str = strconv.Itoa(int(
- data.insert.Jump.Port))
+ ui.buff.insert(strconv.Itoa(int(data.insert.Jump.Port)))
}
case INS_SSH_JUMP_USER,
INS_RDP_JUMP_USER + len(data.insert.Drive):
- ui.buff.str = data.insert.Jump.User
+ ui.buff.insert(data.insert.Jump.User)
case INS_SSH_JUMP_PASS,
INS_RDP_JUMP_PASS + len(data.insert.Drive):
return true
case INS_SSH_JUMP_PRIV,
INS_RDP_JUMP_PRIV + len(data.insert.Drive):
- ui.buff.str = data.insert.Jump.Priv
- case INS_RDP_DOMAIN: ui.buff.str = data.insert.Domain
- case INS_RDP_FILE: ui.buff.str = data.insert.RDPFile
+ ui.buff.insert(data.insert.Jump.Priv)
+ case INS_RDP_DOMAIN: ui.buff.insert(data.insert.Domain)
+ case INS_RDP_FILE: ui.buff.insert(data.insert.RDPFile)
case INS_RDP_SCREENSIZE: return true
case INS_RDP_DYNAMIC:
ui.insert_sel_ok = false
@@ -530,8 +529,8 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
return true
case INS_RDP_QUALITY: return true
case INS_RDP_DRIVE + len(data.insert.Drive): return true
- case INS_CMD_CMD: ui.buff.str = data.insert.Host
- case INS_CMD_SHELL: ui.buff.str = data.insert.Shell[0]
+ case INS_CMD_CMD: ui.buff.insert(data.insert.Host)
+ case INS_CMD_SHELL: ui.buff.insert(data.insert.Shell[0])
case INS_CMD_SILENT:
ui.insert_sel_ok = false
if data.insert.Silent == true {
@@ -541,35 +540,35 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
}
return true
case INS_OS_USERDOMAINID:
- ui.buff.str = data.insert.Stack.UserDomainID
+ ui.buff.insert(data.insert.Stack.UserDomainID)
case INS_OS_PROJECTID:
- ui.buff.str = data.insert.Stack.ProjectID
+ ui.buff.insert(data.insert.Stack.ProjectID)
case INS_OS_REGION:
- ui.buff.str = data.insert.Stack.RegionName
+ ui.buff.insert(data.insert.Stack.RegionName)
case INS_OS_ENDTYPE:
- ui.buff.str = data.insert.Stack.EndpointType
+ ui.buff.insert(data.insert.Stack.EndpointType)
case INS_OS_INTERFACE:
- ui.buff.str = data.insert.Stack.Interface
+ ui.buff.insert(data.insert.Stack.Interface)
case INS_OS_IDAPI:
- ui.buff.str = data.insert.Stack.IdentityAPI
+ ui.buff.insert(data.insert.Stack.IdentityAPI)
case INS_OS_IMGAPI:
- ui.buff.str = data.insert.Stack.ImageAPI
+ ui.buff.insert(data.insert.Stack.ImageAPI)
case INS_OS_NETAPI:
- ui.buff.str = data.insert.Stack.NetworkAPI
+ ui.buff.insert(data.insert.Stack.NetworkAPI)
case INS_OS_VOLAPI:
- ui.buff.str = data.insert.Stack.VolumeAPI
+ ui.buff.insert(data.insert.Stack.VolumeAPI)
case INS_SSH_NOTE,
INS_RDP_NOTE + len(data.insert.Drive),
INS_CMD_NOTE,
INS_OS_NOTE:
- ui.buff.str = data.insert.Note
+ ui.buff.insert(data.insert.Note)
}
}
} else {
if event.Key() == tcell.KeyEscape ||
event.Key() == tcell.KeyCtrlC {
ui.insert_sel_ok = false
- ui.buff.str = ""
+ ui.buff.empty()
ui.drives_buff = ""
ui.s.HideCursor()
}
@@ -595,7 +594,7 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_PROTOCOL:
if event.Rune() < '1' || event.Rune() > '4' {
ui.insert_sel_ok = false
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
return true
} else {
@@ -615,7 +614,7 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_RDP_SCREENSIZE:
if event.Rune() < '1' || event.Rune() > '7' {
ui.insert_sel_ok = false
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
return true
} else {
@@ -635,7 +634,7 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_RDP_QUALITY:
if event.Rune() < '1' || event.Rune() > '3' {
ui.insert_sel_ok = false
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
return true
} else {
@@ -646,35 +645,35 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_RDP_DRIVE + len(data.insert.Drive):
if len(ui.drives_buff) == 0 {
if event.Key() == tcell.KeyEnter {
- if len(ui.buff.str) == 0 {
+ if ui.buff.len() == 0 {
ui.insert_sel_ok = false
ui.drives_buff = ""
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
return true
}
- ui.drives_buff = ui.buff.str
- ui.buff.str = ""
+ ui.drives_buff = ui.buff.str()
+ ui.buff.empty()
} else {
e_readline(event, &ui.buff)
}
} else {
if event.Key() == tcell.KeyEnter {
- if len(ui.buff.str) == 0 {
+ if ui.buff.len() == 0 {
ui.insert_sel_ok = false
ui.drives_buff = ""
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
return true
}
if len(data.insert.Drive) == 0 {
data.insert.Drive = make(map[string]string)
}
- data.insert.Drive[ui.drives_buff] = ui.buff.str
+ data.insert.Drive[ui.drives_buff] = ui.buff.str()
e_set_drive_keys(data)
ui.insert_sel_ok = false
ui.drives_buff = ""
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
} else {
e_readline(event, &ui.buff)
@@ -725,87 +724,87 @@ func e_insert_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
case INS_SSH_HOST,
INS_RDP_HOST,
INS_OS_HOST:
- data.insert.Host = ui.buff.str
+ data.insert.Host = ui.buff.str()
case INS_SSH_PORT,
INS_RDP_PORT:
- tmp, _ := strconv.Atoi(ui.buff.str)
+ tmp, _ := strconv.Atoi(ui.buff.str())
data.insert.Port = uint16(tmp)
case INS_SSH_USER,
INS_RDP_USER,
INS_OS_USER:
- data.insert.User = ui.buff.str
+ data.insert.User = ui.buff.str()
case INS_SSH_PASS,
INS_RDP_PASS,
INS_OS_PASS:
- if len(ui.buff.str) == 0 {
+ if ui.buff.len() == 0 {
data.insert.Pass = ""
return true
} else {
- data.insert.Pass, _ = c_encrypt_str(ui.buff.str,
+ data.insert.Pass, _ = c_encrypt_str(ui.buff.str(),
data.opts.GPG)
}
- case INS_SSH_PRIV: data.insert.Priv = ui.buff.str
- case INS_SSH_EXEC: data.insert.Exec = ui.buff.str
+ case INS_SSH_PRIV: data.insert.Priv = ui.buff.str()
+ case INS_SSH_EXEC: data.insert.Exec = ui.buff.str()
case INS_SSH_JUMP_HOST,
INS_RDP_JUMP_HOST + len(data.insert.Drive):
- data.insert.Jump.Host = ui.buff.str
- if len(ui.buff.str) > 0 {
+ data.insert.Jump.Host = ui.buff.str()
+ if len(ui.buff.str()) > 0 {
data.insert.Jump.Port = 22
} else {
data.insert.Jump.Port = 0
}
case INS_SSH_JUMP_PORT,
INS_RDP_JUMP_PORT + len(data.insert.Drive):
- tmp, _ := strconv.Atoi(ui.buff.str)
+ tmp, _ := strconv.Atoi(ui.buff.str())
data.insert.Jump.Port = uint16(tmp)
case INS_SSH_JUMP_USER,
INS_RDP_JUMP_USER + len(data.insert.Drive):
- data.insert.Jump.User = ui.buff.str
+ data.insert.Jump.User = ui.buff.str()
case INS_SSH_JUMP_PASS,
INS_RDP_JUMP_PASS + len(data.insert.Drive):
- if len(ui.buff.str) == 0 {
+ if len(ui.buff.str()) == 0 {
data.insert.Jump.Pass = ""
} else {
- data.insert.Jump.Pass, _ = c_encrypt_str(ui.buff.str,
- data.opts.GPG)
+ data.insert.Jump.Pass, _ =
+ c_encrypt_str(ui.buff.str(), data.opts.GPG)
}
case INS_SSH_JUMP_PRIV,
INS_RDP_JUMP_PRIV + len(data.insert.Drive):
- data.insert.Jump.Priv = ui.buff.str
+ data.insert.Jump.Priv = ui.buff.str()
case INS_RDP_DOMAIN:
- data.insert.Domain = ui.buff.str
+ data.insert.Domain = ui.buff.str()
case INS_RDP_FILE:
- data.insert.RDPFile = ui.buff.str
+ data.insert.RDPFile = ui.buff.str()
case INS_CMD_CMD:
- data.insert.Host = ui.buff.str
+ data.insert.Host = ui.buff.str()
case INS_CMD_SHELL:
- data.insert.Shell[0] = ui.buff.str
+ data.insert.Shell[0] = ui.buff.str()
case INS_OS_USERDOMAINID:
- data.insert.Stack.UserDomainID = ui.buff.str
+ data.insert.Stack.UserDomainID = ui.buff.str()
case INS_OS_PROJECTID:
- data.insert.Stack.ProjectID = ui.buff.str
+ data.insert.Stack.ProjectID = ui.buff.str()
case INS_OS_REGION:
- data.insert.Stack.RegionName = ui.buff.str
+ data.insert.Stack.RegionName = ui.buff.str()
case INS_OS_ENDTYPE:
- data.insert.Stack.EndpointType = ui.buff.str
+ data.insert.Stack.EndpointType = ui.buff.str()
case INS_OS_INTERFACE:
- data.insert.Stack.Interface = ui.buff.str
+ data.insert.Stack.Interface = ui.buff.str()
case INS_OS_IDAPI:
- data.insert.Stack.IdentityAPI = ui.buff.str
+ data.insert.Stack.IdentityAPI = ui.buff.str()
case INS_OS_IMGAPI:
- data.insert.Stack.ImageAPI = ui.buff.str
+ data.insert.Stack.ImageAPI = ui.buff.str()
case INS_OS_NETAPI:
- data.insert.Stack.NetworkAPI = ui.buff.str
+ data.insert.Stack.NetworkAPI = ui.buff.str()
case INS_OS_VOLAPI:
- data.insert.Stack.VolumeAPI = ui.buff.str
+ data.insert.Stack.VolumeAPI = ui.buff.str()
case INS_SSH_NOTE,
INS_RDP_NOTE + len(data.insert.Drive),
INS_CMD_NOTE,
INS_OS_NOTE:
- data.insert.Note = ui.buff.str
+ data.insert.Note = ui.buff.str()
}
ui.insert_sel_ok = false
- ui.buff.str = ""
+ ui.buff.empty()
ui.s.HideCursor()
} else {
e_readline(event, &ui.buff)
@@ -823,7 +822,7 @@ func e_rename_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
} else if event.Key() == tcell.KeyEnter {
if err := e_rename(data, ui); err != nil {
ui.s.HideCursor()
- ui.buff.str = ""
+ ui.buff.empty()
return true
}
} else {
@@ -832,7 +831,7 @@ func e_rename_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
}
ui.s.HideCursor()
ui.mode = NORMAL_MODE
- ui.buff.str = ""
+ ui.buff.empty()
return false
}
diff --git a/src/i_ui.go b/src/i_ui.go
index 4e589d4..f4d4a60 100644
--- a/src/i_ui.go
+++ b/src/i_ui.go
@@ -61,7 +61,7 @@ import (
)
type Buffer struct {
- str string
+ data []rune
cursor int
}
@@ -88,6 +88,25 @@ type Quad struct {
L, T, R, B int
}
+func (buffer *Buffer)empty() {
+ buffer.data = []rune{}
+ buffer.cursor = 0
+}
+
+func (buffer *Buffer)insert(str string) {
+ buffer.data = []rune(str)
+ // TODO: uncomment
+ // buffer.cursor = len(buffer.data)
+}
+
+func (buffer *Buffer)str() string {
+ return string(buffer.data)
+}
+
+func (buffer *Buffer)len() int {
+ return len(buffer.data)
+}
+
func i_left_right(text_len int, ui *HardUI) (int, int) {
left := (ui.dim[W] / 2) - text_len / 2
right := ui.dim[W] - 1
@@ -372,9 +391,9 @@ func i_prompt_mkdir(ui HardUI, curr *ItemsNode) {
ui.style[DEF_STYLE], path)
i_draw_text(ui.s, len(prompt) + 1 + len(path),
ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1,
- ui.style[DEF_STYLE].Bold(true), ui.buff.str)
+ ui.style[DEF_STYLE].Bold(true), ui.buff.str())
ui.s.ShowCursor(len(prompt) + 1 + len(path) +
- len(ui.buff.str), ui.dim[H] - 1)
+ len(ui.buff.str()), ui.dim[H] - 1)
}
func i_prompt_list(ui HardUI, name, prompt string, list []string) {
@@ -401,8 +420,8 @@ func i_prompt_generic(ui HardUI, prompt string, secret bool, home_dir string) {
return
}
style := ui.style[DEF_STYLE].Bold(true)
- if len(home_dir) > 0 && len(ui.buff.str) > 0 {
- file := ui.buff.str
+ if len(home_dir) > 0 && ui.buff.len() > 0 {
+ file := ui.buff.str()
if file[0] == '~' {
file = home_dir + file[1:]
}
@@ -419,8 +438,8 @@ func i_prompt_generic(ui HardUI, prompt string, secret bool, home_dir string) {
}
i_draw_text(ui.s, len(prompt) + 1,
ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1,
- style, ui.buff.str)
- ui.s.ShowCursor(len(prompt) + 1 + len(ui.buff.str), ui.dim[H] - 1)
+ style, ui.buff.str())
+ ui.s.ShowCursor(len(prompt) + 1 + ui.buff.len(), ui.dim[H] - 1)
}
func i_prompt_dir(ui HardUI, prompt string, home_dir string) {
@@ -428,8 +447,8 @@ func i_prompt_dir(ui HardUI, prompt string, home_dir string) {
1, ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1,
ui.style[DEF_STYLE], prompt)
style := ui.style[DEF_STYLE].Bold(true)
- if len(home_dir) > 0 && len(ui.buff.str) > 0 {
- file := ui.buff.str
+ if len(home_dir) > 0 && ui.buff.len() > 0 {
+ file := ui.buff.str()
if file[0] == '~' {
file = home_dir + file[1:]
}
@@ -444,8 +463,8 @@ func i_prompt_dir(ui HardUI, prompt string, home_dir string) {
}
i_draw_text(ui.s, len(prompt) + 1,
ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1,
- style, ui.buff.str)
- ui.s.ShowCursor(len(prompt) + 1 + len(ui.buff.str), ui.dim[H] - 1)
+ style, ui.buff.str())
+ ui.s.ShowCursor(len(prompt) + 1 + ui.buff.len(), ui.dim[H] - 1)
}
func i_prompt_insert(ui HardUI, curr *ItemsNode) {
@@ -471,9 +490,9 @@ func i_prompt_insert(ui HardUI, curr *ItemsNode) {
ui.style[DEF_STYLE], path)
i_draw_text(ui.s, len(prompt) + 1 + len(path),
ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1,
- ui.style[DEF_STYLE].Bold(true), ui.buff.str)
+ ui.style[DEF_STYLE].Bold(true), ui.buff.str())
ui.s.ShowCursor(len(prompt) + 1 + len(path) +
- len(ui.buff.str), ui.dim[H] - 1)
+ ui.buff.cursor, ui.dim[H] - 1)
}
func i_draw_remove_share(ui HardUI) {