aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--c_ldirs.go14
-rw-r--r--i_events.go17
2 files changed, 24 insertions, 7 deletions
diff --git a/c_ldirs.go b/c_ldirs.go
index d707686..d7628e7 100644
--- a/c_ldirs.go
+++ b/c_ldirs.go
@@ -110,9 +110,21 @@ func (dir *DirsNode) path() string {
return path
}
+// returns the number of hosts of the dir
func (dir *DirsNode) count_hosts() int {
- if dir.lhost.head == nil {
+ if dir.lhost.head == nil || dir.lhost.last == nil {
return 0
}
return dir.lhost.last.ID + 1
}
+
+// return the number of hosts and subfolders of the dir
+func (dir *DirsNode) count_elements() 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
+ }
+ return items
+}
diff --git a/i_events.go b/i_events.go
index 900bc19..62c93d7 100644
--- a/i_events.go
+++ b/i_events.go
@@ -52,7 +52,7 @@
package main
import (
- "fmt"
+ // "fmt"
"os"
"github.com/gdamore/tcell/v2"
@@ -61,15 +61,11 @@ import (
func i_update_folded_count(dir *DirsNode, ui *HardUI) {
delta := 0
- delta += dir.count_hosts()
- for ptr := dir.next; ptr.Depth > dir.Depth && ptr != nil; ptr = ptr.next {
- delta += ptr.count_hosts() + 1
- }
+ delta += dir.count_elements()
if dir.Folded == false {
delta *= -1
}
ui.folded_count += delta
- fmt.Println(">>>>> COUNT:", ui.folded_count)
}
func i_list_follow_cursor(litems *ItemsList, ui *HardUI) {
@@ -86,6 +82,15 @@ func i_list_follow_cursor(litems *ItemsList, ui *HardUI) {
litems.draw_start.prev != nil {
litems.draw_start = litems.draw_start.prev
}
+ // fmt.Println(">>>>> DRAW_START:", litems.draw_start.ID, "<<<<<<< >>>>>>>> VIRT_ID:", virt_id)
+ if litems.draw_start.prev != nil &&
+ litems.draw_start.prev.is_dir() == true &&
+ litems.draw_start.prev.Dirs.Folded == true {
+ tmp := litems.draw_start.prev.Dirs.count_elements()
+ for i := 0; i < tmp && litems.draw_start != nil; i++ {
+ litems.draw_start = litems.draw_start.next
+ }
+ }
}
func i_reload_data(data *HardData) {