diff options
Diffstat (limited to '')
-rw-r--r-- | i_events.go | 40 | ||||
-rw-r--r-- | i_ui.go | 9 |
2 files changed, 25 insertions, 24 deletions
diff --git a/i_events.go b/i_events.go index 23d2db3..d1cd8e4 100644 --- a/i_events.go +++ b/i_events.go @@ -76,7 +76,7 @@ func i_list_follow_cursor(litems *ItemsList, ui *HardUI) { func i_set_unfold(data *HardData, item *ItemsNode) { delete(data.folds, item.Dirs) - for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next { + for ptr := data.litems.head; ptr != nil && ptr.next != nil; ptr = ptr.next { ptr.next.ID = ptr.ID + 1 } } @@ -124,7 +124,7 @@ func i_set_fold(data *HardData, curr, start, end *ItemsNode) { } folds[curr.Dirs] = &tmp - for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next { + for ptr := data.litems.head; ptr != nil && ptr.next != nil; ptr = ptr.next { ptr.next.ID = ptr.ID + 1 } } @@ -180,13 +180,16 @@ func i_delete_dir(data *HardData) { return } curr := data.litems.curr + dir_path := data.data_dir + data.litems.curr.Dirs.path() if data.folds[curr.Dirs] == nil { i_fold_dir(data, curr) } delete(data.folds, curr.Dirs) if curr == data.litems.head { data.litems.head = curr.next - curr.next.prev = nil + if curr.next != nil { + curr.next.prev = nil + } if data.litems.draw == curr { data.litems.draw = curr.next } @@ -200,23 +203,13 @@ func i_delete_dir(data *HardData) { data.litems.last = curr.prev data.litems.curr = curr.prev } - for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next { + for ptr := data.litems.head; ptr != nil && ptr.next != nil; ptr = ptr.next { ptr.next.ID = ptr.ID + 1 } - // dir_path := data.data_dir + dir.path() - // if err := os.RemoveAll(dir_path); err != nil { - // data.ui.s.Fini() - // c_die("can't remove " + dir_path, err) - // } - // TODO: delete folds map reference if folded - OK - // TEST: single empty dir OK - // TEST: single non-empty dir OK - // TEST: first dir OK - // TEST: first dir is also head - // TEST: last dir - // TEST: last dir is also last - // TEST: last dir 4m+ - // TEST: folded + if err := os.RemoveAll(dir_path); err != nil { + data.ui.s.Fini() + c_die("can't remove " + dir_path, err) + } } func i_delete_host(data *HardData) { @@ -298,8 +291,7 @@ func i_events(data *HardData) { event.Key() == tcell.KeyEnd { data.litems.curr = data.litems.last } else if event.Rune() == 'D' && - data.ldirs.head != nil && - ui.sel_max != 0 { + data.ldirs.head != nil { ui.mode = DELETE_MODE } else if event.Key() == tcell.KeyEnter { if data.litems.curr == nil { @@ -348,6 +340,14 @@ func i_events(data *HardData) { } else if event.Rune() == 'y' { i_delete_host(data) ui.mode = NORMAL_MODE + // data.ui.s.Fini() + // fmt.Println( + // "head:", data.litems.head, + // "\nlast:", data.litems.last, + // "\ncurr:", data.litems.curr, + // "\ndraw:", data.litems.draw, + // ) + // os.Exit(0) } } } @@ -281,8 +281,10 @@ func i_host_panel(ui HardUI, icons bool, litems *ItemsList, data *HardData) { ui.dim[W] / 3, ui.dim[H] - 2, " Hosts ", false) line := 1 - ptr := litems.draw - for ; ptr != nil && line < ui.dim[H] - 2; ptr = ptr.next { + if litems.head == nil { + return + } + for ptr := litems.draw; ptr != nil && line < ui.dim[H] - 2; ptr = ptr.next { if ptr.is_dir() == false && ptr.Host != nil { i_host_panel_host(ui, icons, @@ -303,7 +305,7 @@ func i_host_panel(ui HardUI, icons bool, litems *ItemsList, data *HardData) { line++ } } - if ui.sel_max != 0 { + if litems.head == nil { i_draw_text(ui.s, 1, ui.dim[H] - 2, (ui.dim[W] / 3) - 1, ui.dim[H] - 2, ui.def_style, @@ -525,7 +527,6 @@ func i_info_panel(ui HardUI, litems *ItemsList) { func i_ui(data *HardData) { var err error ui := &data.ui - ui.sel_max = data.litems.last.ID ui.s, err = tcell.NewScreen() if err != nil { |