diff options
-rw-r--r-- | c_hardflip.go | 1 | ||||
-rw-r--r-- | c_init.go | 6 | ||||
-rw-r--r-- | i_events.go | 10 | ||||
-rw-r--r-- | i_ui.go | 36 |
4 files changed, 34 insertions, 19 deletions
diff --git a/c_hardflip.go b/c_hardflip.go index 7e75444..b040727 100644 --- a/c_hardflip.go +++ b/c_hardflip.go @@ -63,7 +63,6 @@ type HardData struct { } func main() { - // TODO: replace everything ui with litems data_dir := c_get_data_dir() opts := HardOpts{true, true, false} ldirs := c_load_data_dir(data_dir, opts) @@ -115,9 +115,14 @@ func c_load_data_dir(dir string, opts HardOpts) *DirsList { // fills litems sorting with dirs last // other sorting algos are concievable +// this func also sets the root folder to unfolded as it may never be folded +// this func also sets the default litems.curr func c_load_litems(ldirs *DirsList) *ItemsList { litems := ItemsList{} + if ldirs.head != nil { + ldirs.head.Folded = false + } for ptr := ldirs.head; ptr != nil; ptr = ptr.next { item := ItemsNode{ Dirs: ptr, Host: nil } litems.add_back(&item) @@ -126,5 +131,6 @@ func c_load_litems(ldirs *DirsList) *ItemsList { litems.add_back(&item) } } + litems.curr = litems.head.next return &litems } diff --git a/i_events.go b/i_events.go index 3afbac0..9d86366 100644 --- a/i_events.go +++ b/i_events.go @@ -98,18 +98,20 @@ func i_events(data *HardData) { os.Exit(0) } else if event.Rune() == 'j' || event.Key() == tcell.KeyDown { - if ui.line < ui.sel_max - 1 { + if ui.sel_id < ui.sel_max - 1 { ui.inc_sel(1, data) } } else if event.Rune() == 'k' || event.Key() == tcell.KeyUp { - if ui.line > 0 { + if ui.sel_id > 0 { ui.inc_sel(-1, data) } } else if event.Rune() == 'g' { - ui.line = 0 + // TODO: litems.curr + ui.sel_id = 0 } else if event.Rune() == 'G' { - ui.line = ui.sel_max - 1 + // TODO: litems.curr + ui.sel_id = ui.sel_max - 1 } else if event.Rune() == 'D' && data.ldirs.head != nil && ui.sel_max != 0 { @@ -43,7 +43,7 @@ * POSSIBILITY OF SUCH DAMAGE. * * hardflip: src/i_ui.go - * Thu Jan 04 16:20:24 2024 + * Fri Jan 05 16:40:33 2024 * Joe * * interfacing with the user @@ -63,7 +63,7 @@ type HardUI struct { list_start int mode uint8 sel_max int - line int + sel_id int count_dirs int count_hosts int def_style tcell.Style @@ -73,16 +73,21 @@ type HardUI struct { } func (ui *HardUI) inc_sel(n int, data *HardData) { - if ui.line + n < 1 || - ui.line + n >= ui.sel_max { + // HACK: ui.sel_id and litems.curr.ID are essentially the same thing + // NOTE: maybe keep only one there, see later + if data.litems.curr == nil { + return + } + if ui.sel_id + n < 1 || + ui.sel_id + n >= ui.sel_max { n = 0 } - ui.line += n data.litems.curr = data.litems.curr.inc(n) - if ui.line > ui.list_start + ui.dim[H] - 4 { - ui.list_start = (ui.line + 1) - (ui.dim[H] + 3) - } else if ui.line < ui.list_start { - ui.list_start = ui.line + ui.sel_id = data.litems.curr.ID + if ui.sel_id > ui.list_start + ui.dim[H] - 4 { + ui.list_start = (ui.sel_id + 1) - (ui.dim[H] + 3) + } else if ui.sel_id < ui.list_start { + ui.list_start = ui.sel_id } } @@ -236,7 +241,7 @@ func i_draw_delete_box(ui HardUI, host *HostNode) { func i_host_panel_dirs(ui HardUI, icons bool, dirs *DirsNode, line int) { style := ui.dir_style - if ui.line == dirs.ID { + if ui.sel_id == dirs.ID { style = style.Reverse(true) } text := "" @@ -266,7 +271,7 @@ func i_host_panel_dirs(ui HardUI, icons bool, dirs *DirsNode, line int) { func i_host_panel_host(ui HardUI, icons bool, dirs *DirsNode, host *HostNode, line int) { style := ui.def_style - if ui.line == host.ID { + if ui.sel_id == host.ID { style = style.Reverse(true) } text := "" @@ -319,7 +324,7 @@ func i_host_panel(ui HardUI, icons bool, 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.line + 1)) + "/" + + " " + strconv.Itoa(int(ui.sel_id + 1)) + "/" + strconv.Itoa(int(ui.sel_max)) + " hosts ") } } @@ -338,7 +343,7 @@ func i_info_panel(ui HardUI, lhost *HostList) { if lhost.head == nil { return } - host = lhost.sel(ui.line) + host = lhost.sel(ui.sel_id) host_type = host.protocol_str() // name, type i_draw_text(ui.s, @@ -504,11 +509,14 @@ func i_get_sel_max(ldirs *DirsList) (int, int, int) { } func i_ui(data *HardData) { + // TODO: replace everything ui with litems var err error ui := &data.ui - ui.s, err = tcell.NewScreen() + // TODO: get better counts + // NOTE: put this in c_load_data and also produce better code ui.sel_max, ui.count_dirs, ui.count_hosts = i_get_sel_max(data.ldirs) + ui.s, err = tcell.NewScreen() if err != nil { c_die("view", err) } |