aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--i_events.go40
-rw-r--r--i_ui.go9
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)
}
}
}
diff --git a/i_ui.go b/i_ui.go
index 608b6a6..2177ce3 100644
--- a/i_ui.go
+++ b/i_ui.go
@@ -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 {