diff options
-rw-r--r-- | c_ldirs.go | 8 | ||||
-rw-r--r-- | i_events.go | 39 | ||||
-rw-r--r-- | i_ui.go | 2 |
3 files changed, 37 insertions, 12 deletions
@@ -120,12 +120,16 @@ func (dir *DirsNode) count_hosts() int { } // return the number of hosts and subfolders of the dir -func (dir *DirsNode) count_elements() int { +func (dir *DirsNode) count_elements(skip_folds bool) int { items := 0 items += dir.count_hosts() for ptr := dir.next; ptr != nil && ptr.Depth > dir.Depth; ptr = ptr.next { - items += ptr.count_hosts() + 1 + if skip_folds == true && ptr.Folded == true { + items += 1 + } else { + items += ptr.count_hosts() + 1 + } } return items } diff --git a/i_events.go b/i_events.go index 587aefa..cdfb5e5 100644 --- a/i_events.go +++ b/i_events.go @@ -92,16 +92,38 @@ func i_list_follow_cursor(litems *ItemsList, ui *HardUI) { // } } -func i_fold_dir(data *HardData, item *ItemsNode) { +func i_unfold_dir(data *HardData, item *ItemsNode) { if item == nil { return } - litems := data.litems + fold := data.folds[item] + if fold == nil { + return + } + after := item.next + item.next = fold.head + fold.head.prev = item + fold.last.next = after + if after != nil { + after.prev = fold.last + } else { + data.litems.last = fold.last + } + delete(data.folds, item) + for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next { + ptr.next.ID = ptr.ID + 1 + } +} + +func i_fold_dir(data *HardData, item *ItemsNode) { + if item == nil || item.Dirs == nil { + return + } folds := data.folds folded_start := item.next folded_start.prev = nil folded_end := item - for i := 0; i < item.Dirs.count_elements() && folded_end != nil; i++ { + for i := 0; i < item.Dirs.count_elements(true) && folded_end != nil; i++ { folded_end = folded_end.next } after := folded_end.next @@ -113,14 +135,14 @@ func i_fold_dir(data *HardData, item *ItemsNode) { nil, } item.next = after - if after == nil { - litems.last = item - } else { + if after != nil { after.prev = item + } else { + data.litems.last = item } folds[item] = &tmp - for ptr := litems.head; ptr.next != nil; ptr = ptr.next { + for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next { ptr.next.ID = ptr.ID + 1 } } @@ -225,10 +247,11 @@ func i_events(data *HardData) { } else { if data.litems.curr.Dirs.Folded == false { data.litems.curr.Dirs.Folded = true + i_fold_dir(data, data.litems.curr) } else { data.litems.curr.Dirs.Folded = false + i_unfold_dir(data, data.litems.curr) } - i_fold_dir(data, data.litems.curr) } } else if event.Rune() == ' ' { if data.litems.curr == nil || @@ -52,8 +52,6 @@ package main import ( - // "fmt" - // "os" "strconv" "github.com/gdamore/tcell/v2" |