diff options
-rw-r--r-- | c_hardflip.go | 17 | ||||
-rw-r--r-- | c_init.go | 2 | ||||
-rw-r--r-- | c_ldirs.go | 18 | ||||
-rw-r--r-- | c_lhosts.go | 28 | ||||
-rw-r--r-- | i_events.go | 28 | ||||
-rw-r--r-- | i_ui.go | 68 |
6 files changed, 89 insertions, 72 deletions
diff --git a/c_hardflip.go b/c_hardflip.go index c2270d8..6e33d98 100644 --- a/c_hardflip.go +++ b/c_hardflip.go @@ -51,7 +51,13 @@ package main -import "fmt" +// import "fmt" + +type HardPtr interface { + is_dir() bool + get_self_dirs() *DirsNode + get_self_host() *HostNode +} // the main data structure, holds up everything important type HardData struct { @@ -60,12 +66,9 @@ type HardData struct { ui HardUI opts HardOpts data_dir string + ptr HardPtr } -// type HardPtr interface { -// is_dir() bool -// } - func main() { data_dir := c_get_data_dir() opts := HardOpts{true, true, false} @@ -76,10 +79,9 @@ func main() { HardUI{}, opts, data_dir, + nil, } - - // var ptr HardPtr // for ptr = ldirs.head; ptr != nil ; ptr = ptr.next { // spaces := "" // for i := 0; i < int(ptr.Depth - 1) * 2; i++ { @@ -115,6 +117,5 @@ func main() { // } // PERF: test performance over a large amount of hosts with litems - return i_ui(&data) } @@ -63,7 +63,7 @@ type HardOpts struct { } -var global_id uint64 +var global_id int // this function recurses into the specified root directory in order to load // every yaml file into memory @@ -52,7 +52,7 @@ package main type DirsNode struct { - ID uint64 + ID int Name string Parent *DirsNode Depth uint16 @@ -85,7 +85,7 @@ func (ldirs *DirsList) add_back(node *DirsNode) { } // return the list node with the according id -func (ldirs *DirsList) sel(id uint64) *DirsNode { +func (ldirs *DirsList) sel(id int) *DirsNode { curr := ldirs.head if curr == nil { @@ -115,10 +115,10 @@ func (ldirs *DirsList) path(node *DirsNode) string { return path } -func (ldirs *DirsList) count() (uint64, uint64) { +func (ldirs *DirsList) count() (int, int) { curr := ldirs.head - var count_dirs uint64 - var count_hosts uint64 + var count_dirs int + var count_hosts int for count_dirs = 0; curr != nil; count_dirs++ { count_hosts += curr.lhost.count() @@ -130,3 +130,11 @@ func (ldirs *DirsList) count() (uint64, uint64) { func (dir *DirsNode) is_dir() bool { return true } + +func (dir *DirsNode) get_self_dirs() *DirsNode { + return dir +} + +func (dir *DirsNode) get_self_host() *HostNode { + return nil +} diff --git a/c_lhosts.go b/c_lhosts.go index bd02643..986fd71 100644 --- a/c_lhosts.go +++ b/c_lhosts.go @@ -54,7 +54,7 @@ package main // 0: ssh // 1: rdp type HostNode struct { - ID uint64 + ID int Protocol int8 `yaml:"type"` Name string `yaml:"name"` Host string `yaml:"host"` @@ -104,13 +104,13 @@ func (lhost *HostList) add_back(node *HostNode) { func (lhost *HostList) reset_id() { curr := lhost.head for i := 0; curr != nil; i++ { - curr.ID = uint64(i) + curr.ID = i curr = curr.next } } // removes a host node from the list -func (lhost *HostList) del(id uint64) { +func (lhost *HostList) del(id int) { if lhost.head == nil { return } @@ -128,7 +128,7 @@ func (lhost *HostList) del(id uint64) { } // return the list node with the according id -func (lhost *HostList) sel(id uint64) *HostNode { +func (lhost *HostList) sel(id int) *HostNode { curr := lhost.head if curr == nil { @@ -143,9 +143,9 @@ func (lhost *HostList) sel(id uint64) *HostNode { return curr } -func (lhost *HostList) count() uint64 { +func (lhost *HostList) count() int { curr := lhost.head - var count uint64 + var count int for count = 0; curr != nil; count++ { curr = curr.next @@ -156,3 +156,19 @@ func (lhost *HostList) count() uint64 { func (host *HostNode) is_dir() bool { return false } + +func (host *HostNode) get_self_dirs() *DirsNode { + return nil +} + +func (host *HostNode) get_self_host() *HostNode { + return host +} + +func (host *HostNode) protocol_str() string { + switch host.Protocol { + case 0: return "SSH" + case 1: return "RDP" + default: return "" + } +} diff --git a/i_events.go b/i_events.go index 436706d..7f585de 100644 --- a/i_events.go +++ b/i_events.go @@ -53,6 +53,7 @@ package main import ( "os" + "github.com/gdamore/tcell/v2" ) @@ -96,37 +97,38 @@ func i_events(data *HardData) { os.Exit(0) } else if event.Rune() == 'j' || event.Key() == tcell.KeyDown { - if ui.sel.line < ui.sel_max - 1 { + if ui.line < ui.sel_max - 1 { ui.inc_sel(1) } } else if event.Rune() == 'k' || event.Key() == tcell.KeyUp { - if ui.sel.line > 0 { + if ui.line > 0 { ui.inc_sel(-1) } } else if event.Rune() == 'g' { - ui.sel.line = 0 + ui.line = 0 } else if event.Rune() == 'G' { - ui.sel.line = ui.sel_max - 1 + ui.line = ui.sel_max - 1 } else if event.Rune() == 'D' && data.ldirs.head != nil && ui.sel_max != 0 { ui.mode = DELETE_MODE } else if event.Key() == tcell.KeyEnter { - if ui.sel.host_ptr != nil { + if data.ptr != nil && data.ptr.is_dir() == false { ui.s.Fini() - c_exec(ui.sel.host_ptr) + c_exec(data.ptr.get_self_host()) if data.opts.Loop == false { os.Exit(0) + } else { + if ui.s, err = tcell.NewScreen(); err != nil { + c_die("view", err) + } + if err := ui.s.Init(); err != nil { + c_die("view", err) + } + ui.s.SetStyle(ui.def_style) } } - if ui.s, err = tcell.NewScreen(); err != nil { - c_die("view", err) - } - if err := ui.s.Init(); err != nil { - c_die("view", err) - } - ui.s.SetStyle(ui.def_style) } if event.Key() == tcell.KeyCtrlR { i_reload_data(data) @@ -43,7 +43,7 @@ * POSSIBILITY OF SUCH DAMAGE. * * hardflip: src/i_ui.go - * Wed Dec 27 18:19:37 2023 + * Thu 04 Jan 2024 12:03:11 PM CET * Joe * * interfacing with the user @@ -63,23 +63,17 @@ type HardUI struct { list_start int mode uint8 sel_max int - count_dirs uint64 - count_hosts uint64 + line int + count_dirs int + count_hosts int def_style tcell.Style dir_style tcell.Style title_style tcell.Style dim [2]int - sel HardSelector -} - -type HardSelector struct { - line int - dirs_ptr *DirsNode - host_ptr *HostNode } func (ui *HardUI) inc_sel(n int) { - ui.sel.line += n + ui.line += n } func i_draw_text(s tcell.Screen, @@ -230,9 +224,9 @@ func i_draw_delete_box(ui HardUI, host *HostNode) { // ui.def_style, "o") } -func i_host_panel_dirs(ui HardUI, opts HardOpts, dirs *DirsNode, line int) { +func i_host_panel_dirs(ui HardUI, icons bool, dirs *DirsNode, line int) { style := ui.dir_style - if &ui.sel.dirs_ptr == &dirs { + if ui.line == dirs.ID { style = style.Reverse(true) } text := "" @@ -241,7 +235,7 @@ func i_host_panel_dirs(ui HardUI, opts HardOpts, dirs *DirsNode, line int) { text += " " } } - if opts.Icon == true { + if icons == true { var fold_var uint8 if dirs.Folded == true { fold_var = 1 @@ -259,17 +253,17 @@ func i_host_panel_dirs(ui HardUI, opts HardOpts, dirs *DirsNode, line int) { style, text) } -func i_host_panel_host(ui HardUI, opts HardOpts, +func i_host_panel_host(ui HardUI, icons bool, dirs *DirsNode, host *HostNode, line int) { style := ui.def_style - if &ui.sel.host_ptr == &host { + if ui.line == host.ID { style = style.Reverse(true) } text := "" for i := 0; i < int(dirs.Depth) - 2; i++ { text += " " } - if opts.Icon == true { + if icons == true { text += HOST_ICONS[int(host.Protocol)] } text += host.Name @@ -283,7 +277,7 @@ func i_host_panel_host(ui HardUI, opts HardOpts, style, text) } -func i_host_panel(ui HardUI, opts HardOpts, ldirs *DirsList) { +func i_host_panel(ui HardUI, icons bool, ldirs *DirsList) { // TODO: this must work i_draw_box(ui.s, 0, 0, ui.dim[W] / 3, ui.dim[H] - 2, @@ -293,17 +287,17 @@ func i_host_panel(ui HardUI, opts HardOpts, ldirs *DirsList) { for host := dirs.lhost.head; dirs.Folded == false && host != nil; host = host.next { - i_host_panel_host(ui, opts, dirs, host, line) + i_host_panel_host(ui, icons, dirs, host, line) line++ } dirs = dirs.next for line = line; line < ui.dim[H] - 2 && dirs != nil; dirs = dirs.next { - i_host_panel_dirs(ui, opts, dirs, line) + i_host_panel_dirs(ui, icons, dirs, line) line++ for host := dirs.lhost.head; dirs.Folded == false && host != nil; host = host.next { - i_host_panel_host(ui, opts, dirs, host, line) + i_host_panel_host(ui, icons, dirs, host, line) line++ } } @@ -316,7 +310,7 @@ func i_host_panel(ui HardUI, opts HardOpts, ldirs *DirsList) { i_draw_text(ui.s, 1, ui.dim[H] - 2, (ui.dim[W] / 3) - 1, ui.dim[H] - 2, ui.def_style, - " " + strconv.Itoa(int(ui.sel.line + 1)) + "/" + + " " + strconv.Itoa(int(ui.line + 1)) + "/" + strconv.Itoa(int(ui.sel_max)) + " hosts ") } } @@ -335,12 +329,8 @@ func i_info_panel(ui HardUI, lhost *HostList) { if lhost.head == nil { return } - host = ui.sel.host_ptr - if host.Protocol == 0 { - host_type = "SSH" - } else if host.Protocol == 1 { - host_type = "RDP" - } + host = lhost.sel(ui.line) + host_type = host.protocol_str() // name, type i_draw_text(ui.s, (ui.dim[W] / 3) + 4, curr_line, ui.dim[W] - 2, curr_line, @@ -498,10 +488,10 @@ func i_info_panel(ui HardUI, lhost *HostList) { } } -func i_get_sel_max(ldirs *DirsList) (int, uint64, uint64) { +func i_get_sel_max(ldirs *DirsList) (int, int, int) { count_dirs, count_hosts := ldirs.count() - return int(count_dirs + count_hosts), count_dirs, count_hosts + return count_dirs + count_hosts, count_dirs, count_hosts } func i_ui(data *HardData) { @@ -530,7 +520,7 @@ func i_ui(data *HardData) { ui.dim[W], ui.dim[H], _ = term.GetSize(0) ui.s.Clear() i_bottom_text(*ui) - i_host_panel(data.ui, data.opts, data.ldirs) + i_host_panel(data.ui, data.opts.Icon, data.ldirs) // TODO: info panel // i_info_panel(data.ui, data.lhost) if data.ldirs.head.lhost.head == nil && data.ldirs.head.next == nil { @@ -543,15 +533,15 @@ func i_ui(data *HardData) { } ui.s.Show() i_events(data) - if ui.sel.line >= ui.sel_max { - ui.sel.line = ui.sel_max - 1 - } else if ui.sel.line < 0 { - ui.sel.line = 0 + if ui.line >= ui.sel_max { + ui.line = ui.sel_max - 1 + } else if ui.line < 0 { + ui.line = 0 } - if int(ui.sel.line) > ui.list_start + ui.dim[H] - 4 { - ui.list_start = int(ui.sel.line + 1) - ui.dim[H] + 3 - } else if int(ui.sel.line) < ui.list_start { - ui.list_start = int(ui.sel.line) + if int(ui.line) > ui.list_start + ui.dim[H] - 4 { + ui.list_start = int(ui.line + 1) - ui.dim[H] + 3 + } else if int(ui.line) < ui.list_start { + ui.list_start = int(ui.line) } } } |